From 291f66df5621f0644ce9d15548eb6590045691f0 Mon Sep 17 00:00:00 2001 From: wankeda <Administrator@DESKTOP-HAU3ST3> Date: 星期一, 14 四月 2025 09:26:43 +0800 Subject: [PATCH] 添加PDA下发输送线回流任务 --- 代码管理/NEWCode/WIDESEAWCS_PDA/pages.json | 8 代码管理/WIDESEA_WCSServer/WIDESEA_WCSServer/Download/Logger/Queue/WriteError/20250412.txt | 8 代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/RoastJob/CommonRoastJob.cs | 172 +------ 代码管理/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/ToMesggeThreeHKZJ.cs | 24 代码管理/NEWCode/WIDESEAWCS_PDA/pages/index/index.vue | 5 代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskCZService.cs | 40 + 代码管理/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/AgvAndEquiWorkF.cs | 2 代码管理/WIDESEA_WCSServer/WIDESEA_WCSServer/Download/Logger/Queue/WriteError/20250411.txt | 8 代码管理/NEWCode/WIDESEAWCS_PDA/pages/叫料/输送线回流.vue | 201 ++++++++ 代码管理/WIDESEA_WCSServer/WIDESEA_WCSServer/Download/Logger/Queue/WriteError/20250413.txt | 8 代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/PDA/PDAController.cs | 6 代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ITaskInfoService/ITaskCZService.cs | 7 代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ElevatorJob/ElevatorJob.cs | 69 +- 代码管理/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/AgvAndEquiWorkThreeHKFJ.cs | 2 代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/RoastZJob/CommonRoastZJob.cs | 251 ++++++++++ 代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_QuartzJob/RoastZ/CommonRoastZ.cs | 295 ++++++++++++ 代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs | 7 代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_QuartzJob/RoastZ/IRoastZ.cs | 99 ++++ 代码管理/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/AgvAndEquiWorkThree.cs | 128 ++-- 19 files changed, 1,088 insertions(+), 252 deletions(-) diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages.json" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages.json" index 67c6ebc..0f5533e 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages.json" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages.json" @@ -38,7 +38,13 @@ "navigationBarTitleText": "璐熸瀬鍙枡", "enablePullDownRefresh": false } - + }, + { + "path": "pages/鍙枡/杈撻�佺嚎鍥炴祦", + "style": { + "navigationBarTitleText": "杈撻�佺嚎鍥炴祦", + "enablePullDownRefresh": false + } }, { "path" : "pages/SetAddress/SetAddress", diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/index/index.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/index/index.vue" index c29ca09..a784728 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/index/index.vue" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/index/index.vue" @@ -27,6 +27,11 @@ url: 'pages/鍙枡/璐熸瀬鍙枡', image: "" }, + { + text: '涓夋ゼ杈撻�佺嚎鍥炴祦', + url: 'pages/鍙枡/杈撻�佺嚎鍥炴祦', + image: "" + }, // { // text: '浜屾ゼ鍐插彔浠诲姟', // url: 'pages/createTask/jjkto2F', diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/\345\217\253\346\226\231/\350\276\223\351\200\201\347\272\277\345\233\236\346\265\201.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/\345\217\253\346\226\231/\350\276\223\351\200\201\347\272\277\345\233\236\346\265\201.vue" new file mode 100644 index 0000000..e159bf1 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/\345\217\253\346\226\231/\350\276\223\351\200\201\347\272\277\345\233\236\346\265\201.vue" @@ -0,0 +1,201 @@ +<template> + <view> + <uni-segmented-control :current="current" :values="items" @clickItem="onClickItem"> + </uni-segmented-control> + <view class="content"> + <view v-if="current === 0" class="headerstyle"> + <view class="itemstyle"> + <uni-forms label-width="120"> + <uni-forms-item label="璧风偣鍦板潃"> + <!-- <uni-easyinput type="text" :focus="!addressFocus" v-model="sourceAddress" + placeholder="璇锋壂鐬勮捣鐐瑰湴鍧�" ref='midInput' @input="inputChangebarcode" /> --> + <uni-data-select v-model="value" :localdata="rangs"></uni-data-select> + </uni-forms-item> + <uni-forms-item label="缁堢偣鍦板潃"> + <uni-easyinput type="text" :focus="!addressFocus" v-model="targetAddress" + placeholder="璇锋壂鎻忕粓鐐瑰湴鍧�" ref='midInput' @input="inputChangebarcode" /> + </uni-forms-item> + <uni-forms-item> + <button @click="inbound" type="primary" size="default" + style="margin-top: 2%;">杈撻�佺嚎鎼繍纭</button> + </uni-forms-item> + </uni-forms> + </view> + </view> + </view> + <u-toast ref="uToast" /> + </view> +</template> + +<script> + const innerAudioContext = uni.createInnerAudioContext(); + export default { + data() { + return { + items: ['杈撻�佺嚎鎼繍'], + current: 0, + matTotal: [], + matInfos: [], + orderNo: "", + label: "", + orderDetail: [], + focus: false, + barcode: "", + materSn: "", + sns: [], + addressFocus: false, + targetAddress: "", + sourceAddress: "", + address: "", + check: true, + value: "", + matInfo: [], + value2: "", + matTotals: [], + value: 0, + rangs: [{ + value: "FJXL-KPHLX001", + text: "FJXL-KPHLX001" + }, + { + value: "ZJXL-KPHLX001", + text: "ZJXL-KPHLX001" + }, + ], + // range: [], + } + }, + onShow() {}, + // onLoad(res) { + // this.focus = false; + // this.addressFocus = false; + // this.orderNo = res.orderNo; + // this.label = "鍗曟嵁缂栧彿锛�" + this.orderNo; + // this.getData(); + // // this.getEndLocations(); + // }, + methods: { + voiceSpeech(src) { + innerAudioContext.src = src; // '../../static/success.mp3'; + innerAudioContext.play(); + }, + + updateFocus() { + this.$nextTick(() => { + this.materSn = ''; + if (!this.focus) { + this.focus = true; + } + }); + }, + barcodeFocus() { + this.barcode = ''; + if (this.focus) { + this.focus = false; + } + }, + // getData() { + // var postData = this.orderNo + + // this.$u.post('/api/InboundOrder/GetInboundOrderDetail', postData).then((res) => { + // if (res.status) { + // this.orderDetail = res.data; + // if (this.orderDetail.length > 3) { + // this.loadVisible = true; + // } + // } + // }) + // }, + onClickItem(e) { + this.focus = false; + this.addressFocus = false; + if (this.current !== e.currentIndex) { + this.current = e.currentIndex; + if (this.current == 2) { + this.getData(); + } + } + }, + barcodeInput() { + this.$nextTick(function(x) { + if (this.barcode.length > 0) { + this.focus = true; + } + }) + }, + inbound() { + var postData = { + MainData: { + "sourceAddress": this.value, + "targetAddress": this.targetAddress, + } + } + + this.$u.post('/api/PDA/EmptyTask', postData).then(res => { + if (res.code == 200) { + uni.$showMsg("浠诲姟娣诲姞鎴愬姛"); + this.sourceAddress = ""; + this.targetAddress = ""; + setTimeout(() => { + // this.materialtype = false; + }, 200); + } else { + this.$refs.uToast.show({ + title: res.message, + type: "error" + }) + } + }).catch(err => { + this.$refs.uToast.show({ + title: err.message, + type: "error" + }) + }) + }, + + inputChangebarcode() { + this.addressFocus = false; + this.$nextTick(function(x) { + if (this.sourceAddress != '') { + this.addressFocus = true; + } + }) + }, + // getEndLocations() { + // this.$u.post('/api/CachePoint/GetEndPoints', null).then(res => { + // if (res.status) { + // this.range = res.data; + // } else { + // this.$refs.uToast.show({ + // title: res.message, + // type: "error" + // }) + // } + // }) + // } + } + } +</script> + +<style lang="scss"> + @import '@/common/uni-ui.scss'; + + .content { + display: flex; + height: 150px; + } + + .content-text { + font-size: 14px; + color: #666; + } + + .itemstyle { + margin-top: 30px; + margin-left: 5%; + } + + .headerstyle { + width: 90%; + } +</style> \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ITaskInfoService/ITaskCZService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ITaskInfoService/ITaskCZService.cs" index 50558a3..b80d4c2 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ITaskInfoService/ITaskCZService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ITaskInfoService/ITaskCZService.cs" @@ -42,5 +42,12 @@ /// <param name="dto"></param> /// <returns></returns> public Task<WebResponseContent> FinishTask(CZTaskFinshDto dto); + /// <summary> + /// 杈撻�佺嚎鍥炴祦 + /// </summary> + /// <param name="dto"></param> + /// <returns></returns> + public Task<WebResponseContent> EmptyTask(SaveModel saveModel); + } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_QuartzJob/RoastZ/CommonRoastZ.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_QuartzJob/RoastZ/CommonRoastZ.cs" new file mode 100644 index 0000000..5e673a2 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_QuartzJob/RoastZ/CommonRoastZ.cs" @@ -0,0 +1,295 @@ +锘�#region << 鐗� 鏈� 娉� 閲� >> + +/*---------------------------------------------------------------- + * 鍛藉悕绌洪棿锛歐IDESEAWCS_QuartzJob + * 鍒涘缓鑰咃細鑳$搴� + * 鍒涘缓鏃堕棿锛�2024/8/2 16:13:36 + * 鐗堟湰锛歏1.0.0 + * 鎻忚堪锛氫竴鑸儤鐑ゅ疄鐜扮被 + * + * ---------------------------------------------------------------- + * 淇敼浜猴細 + * 淇敼鏃堕棿锛� + * 鐗堟湰锛歏1.0.1 + * 淇敼璇存槑锛� + * + *----------------------------------------------------------------*/ + +#endregion << 鐗� 鏈� 娉� 閲� >> + +using HslCommunication; +using System.ComponentModel; +using WIDESEAWCS_Communicator; +using WIDESEAWCS_QuartzJob.ConveyorLine.Enum; +using WIDESEAWCS_QuartzJob.DeviceBase; +using WIDESEAWCS_QuartzJob.DTO; + +namespace WIDESEAWCS_QuartzJob +{ + /// <summary> + /// 鐑樼儰瀹炵幇瀵硅薄 + /// </summary> + [Description("Roast鐑樼儰璁惧")] + public class CommonRoastZ : IRoastZ + { + #region Private Member + + /// <summary> + /// 鐑樼儰閫氳瀵硅薄 + /// </summary> + private readonly BaseCommunicator _communicator; + + /// <summary> + /// 鐑樼儰鍗忚淇℃伅 + /// </summary> + private readonly List<DeviceProDTO> _deviceProDTOs; + + /// <summary> + /// 鐑樼儰鍗忚鏄庣粏淇℃伅 + /// </summary> + private readonly List<DeviceProtocolDetailDTO> _deviceProtocolDetailDTOs; + + /// <summary> + /// 璁惧缂栧彿 + /// </summary> + public readonly string _deviceCode; + + /// <summary> + /// 璁惧鍚嶇О + /// </summary> + public readonly string _deviceName; + + private bool _heartStatr = true; + + private bool _isConnected = true; + + #endregion + + #region Public Member + + /// <summary> + /// 鐑樼儰閫氳瀵硅薄 + /// </summary> + public BaseCommunicator Communicator => _communicator; + + /// <summary> + /// 鐑樼儰鍗忚淇℃伅 + /// </summary> + public List<DeviceProDTO> DeviceProDTOs => _deviceProDTOs; + + /// <summary> + /// 鐑樼儰鍗忚鏄庣粏淇℃伅 + /// </summary> + public List<DeviceProtocolDetailDTO> DeviceProtocolDetailDTOs => _deviceProtocolDetailDTOs; + + /// <summary> + /// 璁惧缂栧彿 + /// </summary> + public string DeviceCode => _deviceCode; + + /// <summary> + /// 璁惧鍚嶇О + /// </summary> + public string DeviceName => _deviceName; + + /// <summary> + /// 閫氳鏄惁宸茶繛鎺� + /// </summary> + public bool IsConnected => Communicator.IsConnected && _isConnected; + + #endregion + + #region Constructor Function + + /// <summary> + /// 鏋勯�犲嚱鏁� + /// </summary> + /// <param name="communicator">鐑樼儰閫氳瀵硅薄</param> + /// <param name="deviceProDTOs">鐑樼儰鍗忚淇℃伅</param> + /// <param name="deviceProtocolDetailDTOs">鐑樼儰鍗忚鏄庣粏淇℃伅</param> + /// <param name="deviceCode">璁惧缂栧彿</param> + /// <param name="deviceName">璁惧鍚嶇О</param> + public CommonRoastZ(BaseCommunicator communicator, List<DeviceProDTO> deviceProDTOs, List<DeviceProtocolDetailDTO> deviceProtocolDetailDTOs, string deviceCode, string deviceName) + { + _communicator = communicator; + _deviceProDTOs = deviceProDTOs; + _deviceProtocolDetailDTOs = deviceProtocolDetailDTOs; + _deviceCode = deviceCode; + _deviceName = deviceName; + CheckConnect(); + } + + #endregion + + #region Private Method + + private void CheckConnect() + { + Task.Run(() => + { + while (_heartStatr) + { + try + { + DeviceProDTO? devicePro = _deviceProDTOs.FirstOrDefault(); + if (devicePro == null) + _isConnected = false; + else + Communicator.ReadAsObj(devicePro.DeviceProAddress, devicePro.DeviceDataType); + _isConnected = true; + } + catch (Exception ex) + { + _isConnected = false; + } + Thread.Sleep(500); + } + }); + } + + #endregion + + #region Public Method + + /// <summary> + /// 璇诲彇PLC鍗忚鍦板潃鐨勬暟鎹� + /// </summary> + /// <typeparam name="TEnum">鍗忚淇℃伅鐨勬灇涓惧璞′俊鎭��</typeparam> + /// <typeparam name="TResult">璇诲彇鏁版嵁鐨勭被鍨嬪璞′俊鎭��</typeparam> + /// <param name="value">鏋氫妇鍊�</param> + /// <param name="deviceChildCode">璁惧瀛愮紪鍙�</param> + /// <returns>璇诲彇鍒扮殑鏁版嵁</returns> + public TResult GetValue<TEnum, TResult>(TEnum value, string deviceChildCode) where TEnum : Enum + { + if (!IsConnected) throw new Exception($"閫氳杩炴帴閿欒锛岃妫�鏌ョ綉缁�"); + DeviceProDTO? devicePro = _deviceProDTOs.FirstOrDefault(x => x.DeviceProParamName == value.ToString() && x.DeviceChildCode == deviceChildCode); + return devicePro == null ? throw new Exception($"璇诲彇鏁版嵁閿欒,鏈湪鍗忚淇℃伅閲岄潰鎵惧埌鍙傛暟{value.ToString()}") : (TResult)Communicator.ReadAsObj(devicePro.DeviceProAddress, devicePro.DeviceDataType); + } + + /// <summary> + /// 涓庤澶囩殑蹇冭烦 + /// </summary> + public void Heartbeat() + { + throw new NotImplementedException(); + } + + /// <summary> + /// + /// </summary> + /// <typeparam name="T"></typeparam> + /// <param name="command"></param> + /// <param name="deviceChildCode"></param> + /// <returns></returns> + /// <exception cref="Exception"></exception> + public bool SendCommand<T>(T command, string deviceChildCode) where T : IDataTransfer, new() + { + if (Communicator is MelsecA1ENetCommunicator) + { + if (!IsConnected) throw new Exception($"閫氳杩炴帴閿欒锛岃妫�鏌ョ綉缁�"); + DeviceProDTO? devicePro = _deviceProDTOs.Where(x => x.DeviceProParamType == nameof(DeviceCommand) && x.DeviceChildCode == deviceChildCode).OrderBy(x => x.DeviceProOffset).FirstOrDefault(); + if (devicePro == null) + { + return false; + } + if (Communicator.WriteCustomer(devicePro.DeviceProAddress, command)) + { + return true; + } + return false; + } + else + { + throw new Exception("鏆備笉鏀寔闄よタ闂ㄥ瓙涔嬪鐨凱LC"); + } + } + + /// <summary> + /// 璇诲彇PLC鏁版嵁锛岃繑鍥炶嚜瀹氫箟瀵硅薄 + /// </summary> + /// <typeparam name="T">娉涘瀷</typeparam> + /// <param name="deviceChildCode">瀛愯澶囩紪鍙�</param> + /// <returns>杩斿洖鑷畾涔夊璞℃垨鎶涘嚭寮傚父</returns> + /// <exception cref="Exception"></exception> + public T ReadCustomer<T>(string deviceChildCode) where T : IDataTransfer, new() + { + if (!IsConnected) throw new Exception($"閫氳杩炴帴閿欒锛岃妫�鏌ョ綉缁�"); + DeviceProDTO? devicePro = _deviceProDTOs.Where(x => x.DeviceProParamType == "ReadDeviceCommand" && x.DeviceChildCode == deviceChildCode).OrderBy(x => x.DeviceProOffset).FirstOrDefault(); + + if (devicePro == null) + { + throw new Exception("鏈壘鍒板崗璁俊鎭�"); + } + else + { + return Communicator.ReadCustomer<T>(devicePro.DeviceProAddress); + } + } + + /// <summary> + /// 鏍规嵁鍙傛暟鍚嶇О銆佽澶囧瓙缂栧彿鍐欏叆瀵瑰簲鐨勬暟鎹�� + /// </summary> + /// <typeparam name="TEnum">鍙傛暟鍚嶇О鏋氫妇绫诲瀷銆�</typeparam> + /// <typeparam name="TValue">瑕佸啓鍏ョ殑鏁版嵁绫诲瀷銆�</typeparam> + /// <param name="enum">鍙傛暟鍚嶇О銆�</param> + /// <param name="value">瑕佸啓鍏ョ殑鏁版嵁銆�</param> + /// <param name="deviceChildCode">璁惧瀛愮紪鍙峰啓</param> + /// <returns>杩斿洖鍐欏叆鎴愬姛鎴栧け璐�</returns> + public bool SetValue<TEnum, TValue>(TEnum @enum, TValue value, string deviceChildCode) + where TEnum : Enum + where TValue : notnull + { + if (!IsConnected) throw new Exception($"閫氳杩炴帴閿欒锛岃妫�鏌ョ綉缁�"); + DeviceProDTO? devicePro = _deviceProDTOs.FirstOrDefault(x => x.DeviceProParamName == @enum.ToString() && x.DeviceChildCode == deviceChildCode); + return devicePro == null ? throw new Exception($"鍐欏叆鏁版嵁閿欒,鏈湪鍗忚淇℃伅閲岄潰鎵惧埌鍙傛暟{value.ToString()}") : Communicator.WriteObj(devicePro.DeviceProAddress, devicePro.DeviceDataType, value); + } + + /// <summary> + /// 鏄惁鍗犱綅 + /// </summary> + /// <param name="deviceChildCode">璁惧瀛愮紪鍙�</param> + /// <returns></returns> + /// <exception cref="Exception"></exception> + public bool IsOccupied(string deviceChildCode) + { + if (Communicator.IsConnected) + { + List<DeviceProDTO> devicePros = _deviceProDTOs.Where(x => x.DeviceProParamType == ConveyorLineStatus.IsOccupied.ToString()).ToList(); + if (devicePros.Count == 0) + { + //todo 鍗忚淇℃伅鏈幏鍙栧埌鏃舵姏鍑哄紓甯� + throw new Exception(); + } + for (int i = 0; i < devicePros.Count; i++) + { + object readStatus = Communicator.ReadAsObj(devicePros[i].DeviceProAddress, devicePros[i].DeviceDataType); + //todo 鍗忚鏄庣粏淇℃伅鏈幏鍙栧埌鏃舵姏鍑哄紓甯� + DeviceProtocolDetailDTO? deviceProtocolDetail = _deviceProtocolDetailDTOs.FirstOrDefault(x => x.DeviceProParamName == devicePros[i].DeviceProParamName) ?? throw new Exception(); + deviceProtocolDetail = _deviceProtocolDetailDTOs.FirstOrDefault(x => x.DeviceProParamName == devicePros[i].DeviceProParamType && x.ProtocalDetailValue.Equals(readStatus.ToString())); + if (deviceProtocolDetail != null) + { + return true; + } + return false; + } + } + //todo 閫氳鏈繛鎺ユ椂鎶涘嚭寮傚父 + return false; + } + + /// <summary> + /// 閲婃斁瀵硅薄 + /// </summary> + public void Dispose() + { + // 璁剧疆蹇冭烦鐘舵�佷负false + _heartStatr = false; + // 閲婃斁閫氫俊鍣ㄨ祫婧� + _communicator.Dispose(); + // 鍛婅瘔鍨冨溇鍥炴敹鍣ㄤ笉鍐嶈皟鐢ㄧ粓缁撳櫒 + GC.SuppressFinalize(this); + } + + #endregion + } +} \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_QuartzJob/RoastZ/IRoastZ.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_QuartzJob/RoastZ/IRoastZ.cs" new file mode 100644 index 0000000..aa7182e --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_QuartzJob/RoastZ/IRoastZ.cs" @@ -0,0 +1,99 @@ +锘�#region << 鐗� 鏈� 娉� 閲� >> + +/*---------------------------------------------------------------- + * 鍛藉悕绌洪棿锛歐IDESEAWCS_QuartzJob + * 鍒涘缓鑰咃細鑳$搴� + * 鍒涘缓鏃堕棿锛�2024/8/2 16:13:36 + * 鐗堟湰锛歏1.0.0 + * 鎻忚堪锛氳緭閫佺嚎鎺ュ彛灞� + * + * ---------------------------------------------------------------- + * 淇敼浜猴細 + * 淇敼鏃堕棿锛� + * 鐗堟湰锛歏1.0.1 + * 淇敼璇存槑锛� + * + *----------------------------------------------------------------*/ + +#endregion << 鐗� 鏈� 娉� 閲� >> + +using HslCommunication; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using WIDESEAWCS_Communicator; +using WIDESEAWCS_QuartzJob.DeviceBase; +using WIDESEAWCS_QuartzJob.DTO; + +namespace WIDESEAWCS_QuartzJob +{ + /// <summary> + /// AGV鎺ュ彛灞� + /// </summary> + public interface IRoastZ : IDevice + { + /// <summary> + /// 閫氳瀵硅薄 + /// </summary> + BaseCommunicator Communicator { get; } + + /// <summary> + /// 閫氳鍗忚淇℃伅 + /// </summary> + List<DeviceProDTO> DeviceProDTOs { get; } + + /// <summary> + /// 閫氳鍗忚鏄庣粏淇℃伅 + /// </summary> + List<DeviceProtocolDetailDTO> DeviceProtocolDetailDTOs { get; } + + /// <summary> + /// 璁惧鏄惁宸茶繛鎺� + /// </summary> + bool IsConnected { get; } + + /// <summary> + /// 涓庤澶囩殑蹇冭烦 + /// </summary> + void Heartbeat(); + + /// <summary> + /// 璇诲彇PLC鍗忚鍦板潃鐨勬暟鎹� + /// </summary> + /// <typeparam name="TEnum">鍗忚淇℃伅鐨勬灇涓惧璞′俊鎭��</typeparam> + /// <typeparam name="TResult">璇诲彇鏁版嵁鐨勭被鍨嬪璞′俊鎭��</typeparam> + /// <param name="value">鏋氫妇鍊�</param> + /// <param name="deviceChildCode">璁惧瀛愮紪鍙�</param> + /// <returns>璇诲彇鍒扮殑鏁版嵁</returns> + TResult GetValue<TEnum, TResult>(TEnum value, string deviceChildCode) where TEnum : Enum; + + /// <summary> + /// 鏍规嵁鍙傛暟鍚嶇О銆佽澶囧瓙缂栧彿鍐欏叆瀵瑰簲鐨勬暟鎹�� + /// </summary> + /// <typeparam name="TEnum">鍙傛暟鍚嶇О鏋氫妇绫诲瀷銆�</typeparam> + /// <typeparam name="TValue">瑕佸啓鍏ョ殑鏁版嵁绫诲瀷銆�</typeparam> + /// <param name="enum">鍙傛暟鍚嶇О銆�</param> + /// <param name="value">瑕佸啓鍏ョ殑鏁版嵁銆�</param> + /// <param name="deviceChildCode">璁惧瀛愮紪鍙峰啓</param> + /// <returns>杩斿洖鍐欏叆鎴愬姛鎴栧け璐�</returns> + bool SetValue<TEnum, TValue>(TEnum @enum, TValue value, string deviceChildCode) where TEnum : Enum where TValue : notnull; + + /// <summary> + /// 璇诲彇绔欏彴鏄惁琚崰鐢� + /// </summary> + /// <param name="deviceChildCode">璁惧瀛愮紪鍙�</param> + /// <returns></returns> + bool IsOccupied(string deviceChildCode); + + /// <summary> + /// 鍙戦�佷换鍔″懡浠� + /// </summary> + /// <typeparam name="T">浠诲姟鍛戒护瀵硅薄鐨勭被鍨嬫硾鍨�</typeparam> + /// <param name="command">浠诲姟鍛戒护</param> + /// <param name="deviceChildCode">璁惧瀛愮紪鍙�</param> + /// <returns></returns> + bool SendCommand<T>(T command, string deviceChildCode) where T : IDataTransfer, new(); + } +} \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/PDA/PDAController.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/PDA/PDAController.cs" index 1e2307b..7e6581f 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/PDA/PDAController.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/PDA/PDAController.cs" @@ -43,5 +43,11 @@ { return _taskCZService.AddTaskCZAsync(czTaskDto); } + + [HttpPost, Route("EmptyTask"), AllowAnonymous] + public Task<WebResponseContent> EmptyTask([FromBody] SaveModel saveModel) + { + return _taskCZService.EmptyTask(saveModel); + } } } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskCZService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskCZService.cs" index d209795..342bfba 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskCZService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskCZService.cs" @@ -17,6 +17,7 @@ #endregion << 鐗� 鏈� 娉� 閲� >> +using OfficeOpenXml.FormulaParsing.Excel.Functions.Logical; using WIDESEAWCS_Common.TaskEnum; using WIDESEAWCS_Core; using WIDESEAWCS_Core.BaseServices; @@ -29,8 +30,10 @@ { public class TaskCZService : ServiceBase<DtCZTask, ITaskCZRepository>, ITaskCZService { - public TaskCZService(ITaskCZRepository BaseDal) : base(BaseDal) + private readonly ITaskRepository _taskRepository; + public TaskCZService(ITaskCZRepository BaseDal, ITaskRepository taskRepository) : base(BaseDal) { + _taskRepository = taskRepository; } public Task<WebResponseContent> AddTaskCZAsync(CZTaskDto dto) @@ -56,7 +59,7 @@ TaskNumber = dto.Number, TaskExecutor = "CZ", TaskOrderNo = dto.OrderNo, - TaskOwner = "KH", + TaskOwner = "KH", TaskProductCode = dto.ProductCode, Creater = "KH" }; @@ -122,5 +125,38 @@ } return Task.FromResult(response); } + /// <summary> + /// 杈撻�佺嚎鍥炴祦 + /// </summary> + /// <param name="saveModel"></param> + /// <returns></returns> + public Task<WebResponseContent> EmptyTask(SaveModel saveModel) + { + WebResponseContent webResponseContent = new WebResponseContent(); + try + { + string Saddress = saveModel.MainData["sourceAddress"].ToString(); + string Taddress = saveModel.MainData["targetAddress"].ToString(); + + Dt_Task task = _taskRepository.QueryFirst(x => x.SourceAddress == Saddress && x.TaskState == (int)TaskInStatusEnum.InPending && x.TargetAddress == "WaitBind"); + if (task == null) + { + webResponseContent.Error("浠诲姟涓嶅瓨鍦紒"); + return Task.FromResult(webResponseContent); + } + task.TargetAddress = Taddress; + task.TaskState = (int)TaskInStatusEnum.InNew; + var isTrue = _taskRepository.UpdateData(task); + if (isTrue) + { + webResponseContent.OK("浠诲姟涓嬪彂鎴愬姛锛�"); + } + } + catch (Exception ex) + { + webResponseContent.Error(ex.Message); + } + return Task.FromResult(webResponseContent); + } } } \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs" index 33541af..68847ca 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs" @@ -148,7 +148,7 @@ } string fromAdd = request.Value; - string taskType = request.Value.Contains("ZJXL") ? "姝f瀬" : "璐熸瀬"; + string taskType = "璐熸瀬"; //request.Value.Contains("ZJXL") ? "姝f瀬" : // 鏍规嵁浠诲姟绫诲瀷纭畾璇锋眰鍦板潃 (string upRequest, string gmRequest, string gmState) = GetRequestAddresses(taskType); @@ -193,6 +193,11 @@ // 杈呭姪鏂规硶锛氬垱寤轰换鍔″璞� private Dt_Task CreateTask(string currentAddress, string targetAddress, string remark, string palletCode, string taskType) { + Dt_Task dt_Task = _taskRepository.QueryFirst(x => x.SourceAddress == currentAddress); + if (dt_Task != null) + { + return null; + } return new Dt_Task { TaskNum = _taskService.GetTaskNum(), diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ElevatorJob/ElevatorJob.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ElevatorJob/ElevatorJob.cs" index 05fbea8..2091ed8 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ElevatorJob/ElevatorJob.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ElevatorJob/ElevatorJob.cs" @@ -14,37 +14,46 @@ public Task Execute(IJobExecutionContext context) { - // 浠庝笂涓嬫枃涓幏鍙� JobParams 骞惰浆鎹负 Roast 绫诲瀷 - //CommonElevator elevator = (CommonElevator)context.JobDetail.JobDataMap.Get("JobParams"); - CommonRoast elevator = (CommonRoast)context.JobDetail.JobDataMap.Get("JobParams"); - // 鍒濆鍖� AGV 鍙橀噺 - AGV agv = null; - - if (elevator == null) + try { - throw new Exception("鏈壘鍒版彁鍗囨満璁惧鍙傛暟銆�"); + // 浠庝笂涓嬫枃涓幏鍙� JobParams 骞惰浆鎹负 Roast 绫诲瀷 + //CommonElevator elevator = (CommonElevator)context.JobDetail.JobDataMap.Get("JobParams"); + CommonRoast elevator = (CommonRoast)context.JobDetail.JobDataMap.Get("JobParams"); + // 鍒濆鍖� AGV 鍙橀噺 + AGV agv = null; + + if (elevator == null) + { + throw new Exception("鏈壘鍒版彁鍗囨満璁惧鍙傛暟銆�"); + } + + // 杩炴帴 AGV + // 鏍规嵁璁惧鍚嶇О鍐冲畾鏄鏋佽繕鏄礋鏋� AGV + List<string> agvNames = new List<string>() { "姝f瀬AGV", "璐熸瀬AGV" }; //"姝f瀬AGV", + foreach (var agvName in agvNames) + { + // 浠庡瓨鍌ㄤ腑鏌ユ壘鎸囧畾鍚嶇О鐨勮澶� + IDevice? device = Storage.Devices.FirstOrDefault(x => x.DeviceName == agvName); + if (device != null) + { + agv = (AGV)device; + } + else + { + ConsoleHelper.WriteErrorLine($"鏈壘鍒皗agvName}璁惧鍙傛暟銆�"); + continue; + } + var elevatorNamesValues = GetDBElevatorNamesValues(agvName); + var agvNamesValues = GetDBAGVNamesValues(agvName); + DeviceInteraction(elevator, agv, elevatorNamesValues, agvNamesValues); + } + } + catch (Exception ex) + { + + throw; } - // 杩炴帴 AGV - // 鏍规嵁璁惧鍚嶇О鍐冲畾鏄鏋佽繕鏄礋鏋� AGV - List<string> agvNames = new List<string>() { "璐熸瀬AGV" }; //"姝f瀬AGV", - foreach (var agvName in agvNames) - { - // 浠庡瓨鍌ㄤ腑鏌ユ壘鎸囧畾鍚嶇О鐨勮澶� - IDevice? device = Storage.Devices.FirstOrDefault(x => x.DeviceName == agvName); - if (device != null) - { - agv = (AGV)device; - } - else - { - ConsoleHelper.WriteErrorLine($"鏈壘鍒皗agvName}璁惧鍙傛暟銆�"); - continue; - } - var elevatorNamesValues = GetDBElevatorNamesValues(agvName); - var agvNamesValues = GetDBAGVNamesValues(agvName); - DeviceInteraction(elevator, agv, elevatorNamesValues, agvNamesValues); - } return Task.CompletedTask; } @@ -68,7 +77,7 @@ var agvSignal = agv.Communicator.Read(agvNames[1], 100); agv.Communicator.Write(agvNames[0], elevatorSignal); - elevator.Communicator.Write(agvNames[1], agvSignal); + elevator.Communicator.Write(elevatorNames[1], agvSignal); ConsoleHelper.WriteInfoLine($"姝f瀬AGV浜や簰: 鍐欏叆鐢垫淇″彿[{elevatorSignal}]鍒皗agvNames[0]}锛�" + $"鍐欏叆AGV淇″彿[{agvSignal}]鍒皗agvNames[1]}"); @@ -261,10 +270,10 @@ "DB1002.18600", "DB1002.18500", "DB1002.18700", + "DB1002.18000", "DB1002.18800", "DB1002.19000", "DB1002.18200", - "DB1002.18000", "DB1002.18900", "DB1002.19100" }; diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/RoastJob/CommonRoastJob.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/RoastJob/CommonRoastJob.cs" index 44a3ac5..a6e17eb 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/RoastJob/CommonRoastJob.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/RoastJob/CommonRoastJob.cs" @@ -15,116 +15,6 @@ GC.SuppressFinalize(this); } - public Task Execute1(IJobExecutionContext context) - { - CommonRoast roast = (CommonRoast)context.JobDetail.JobDataMap.Get("JobParams"); - AGV agv = null; - if (roast.DeviceName.Contains("姝f瀬")) - { - IDevice? device = Storage.Devices.FirstOrDefault(x => x.DeviceName == "姝f瀬AGV"); - if (device != null) - { - agv = (AGV)device; - } - else - throw new Exception("No such device found."); - - MatchCollection matches = Regex.Matches(roast.DeviceName, @"\d+"); - int number = int.Parse(matches[0].Value); - // 鍒涘缓涓�涓寘鍚墍鏈� double 鍊肩殑闆嗗悎 - List<double> doubleValues = new List<double>(); - - if (number < 3) - { - doubleValues = new List<double> - { - 8093.6, 8093.7, 3493.6, 3493.7, 8094.0, 8095.0, 8096.0, 8097.0, 8098.0, - 8194.0, 8195.0, 8196.0, 8197.0, 3494.0, 3495.0, 3496.0, 3594.0, 3595.0, - 3596.0, 3597.0, 3598.0, 3599.0, 8192.2, 3592.2 - }; - } - else - { - doubleValues = new List<double> - { - 1693.6, 1693.7, 293.6, 293.6, 1694.0, 1695.0, 1696.0, 1697.0, 1698.0, - 1794.0, 1795.0, 1796.0, 1797.0, 294.0, 295.0, 296.0, 394.0, 395.0, 396.0, - 397.0,398.0,399.0,1792.2,392.2 - }; - } - - if (number < 3) - { - // 鏍规嵁 number 鐨勫�艰皟鏁撮泦鍚堜腑鐨勬瘡涓厓绱� - for (int i = 0; i < doubleValues.Count; i++) - { - doubleValues[i] += (number - 1) * 400; - } - } - else - {// 鏍规嵁 number 鐨勫�艰皟鏁撮泦鍚堜腑鐨勬瘡涓厓绱� - for (int i = 0; i < doubleValues.Count; i++) - { - doubleValues[i] += (number - 3) * 400; - } - } - } - else if (roast.DeviceName.Contains("璐熸瀬")) - { - IDevice? device = Storage.Devices.FirstOrDefault(x => x.DeviceName == "璐熸瀬AGV"); - if (device != null) - { - agv = (AGV)device; - } - else - throw new Exception("No such device found."); - - MatchCollection matches = Regex.Matches(roast.DeviceName, @"\d+"); - int number = int.Parse(matches[0].Value); - - List<double> doubleValues = new List<double>(); - - if (number < 3) - { - doubleValues = new List<double> - { - 8893.6, 8893.7, 9093.6, 9093.7, 8894.0, 8895.0, 8896.0, 8897.0, 8898.0, - 8994.0, 8995.0, 8996.0, 8997.0, 9094.0, 9095.0, 9096.0, 9194.0, 9195.0, - 9196.0, 9197.0, 9198.0, 9199.0, 8992.2, 9192.2 - }; - } - else - { - doubleValues = new List<double> - { - 4893.6, 4893.7, 5093.6, 5093.6, 4894.0, 4895.0, 4896.0, 4897.0, 4898.0, - 4994.0, 4995.0, 4996.0, 4997.0, 5094.0, 5095.0, 5096.0, 5194.0, 5195.0, - 5196.0, 5197.0, 5198.0, 5199.0, 4992.2, 5192.2 - }; - } - if (number < 3) - { - // 鏍规嵁 number 鐨勫�艰皟鏁撮泦鍚堜腑鐨勬瘡涓厓绱� - for (int i = 0; i < doubleValues.Count; i++) - { - doubleValues[i] += (number - 1) * 400; - } - } - else - { - // 鏍规嵁 number 鐨勫�艰皟鏁撮泦鍚堜腑鐨勬瘡涓厓绱� - for (int i = 0; i < doubleValues.Count; i++) - { - doubleValues[i] += (number - 3) * 400; - } - } - } - else - throw new Exception("No such device found."); - - throw new NotImplementedException(); - } - public Task Execute(IJobExecutionContext context) { try @@ -140,7 +30,7 @@ } // 鏍规嵁璁惧鍚嶇О鍐冲畾鏄鏋佽繕鏄礋鏋� AGV - string devicePrefix = roast.DeviceName.Contains("姝f瀬") ? "姝f瀬" : "璐熸瀬"; + string devicePrefix = roast.DeviceCode.Contains("FJ") ? "璐熸瀬" : "姝f瀬"; string agvName = $"{devicePrefix}AGV"; // 浠庡瓨鍌ㄤ腑鏌ユ壘鎸囧畾鍚嶇О鐨勮澶� @@ -280,22 +170,25 @@ } // 璇籄GV鍏ユ枡 - byte[] RFAGVup = new byte[] - { - agv.Communicator.Read<byte>($"DB1002.{doubleValues[9]}"), - agv.Communicator.Read<byte>($"DB1002.{doubleValues[10]}"), - agv.Communicator.Read<byte>($"DB1002.{doubleValues[11]}"), - agv.Communicator.Read<byte>($"DB1002.{doubleValues[12]}"), - agv.Communicator.Read<byte>($"DB1002.{doubleValues[22]}") - }; + + short RFAGVa = agv.Communicator.Read<byte>($"DB1002.{doubleValues[9]}"); + short RFAGVb = agv.Communicator.Read<byte>($"DB1002.{doubleValues[10]}"); + short RFAGVc = agv.Communicator.Read<byte>($"DB1002.{doubleValues[11]}"); + short RFAGVd = agv.Communicator.Read<byte>($"DB1002.{doubleValues[12]}"); + bool RFAGVe = agv.Communicator.Read<bool>($"DB1002.{doubleValues[22]}"); + // 鍐欑儤鐑ゅ叆鏂� - string[] writeAddressesUp = new string[] { "D1940", "D1941", "D1955", "D1956", "M691" }; - for (int i = 0; i < RFAGVup.Length; i++) - { - roast.Communicator.Write(writeAddressesUp[i], RFAGVup[i]); - } - + //string[] writeAddressesUp = new string[] { "D1940", "D1941", "D1955", "D1956", "M691" }; + //for (int i = 0; i < RFAGVup.Length; i++) + //{ + // roast.Communicator.Write(writeAddressesUp[i], RFAGVup[i]); + //} + roast.Communicator.Write("D1940", RFAGVa); + roast.Communicator.Write("D1941", RFAGVb); + roast.Communicator.Write("D1955", RFAGVc); + roast.Communicator.Write("D1956", RFAGVd); + roast.Communicator.Write("M691", RFAGVe); // 璇荤儤鐑ゅ嚭鏂� short[] RFHKdown = new short[] { @@ -311,24 +204,23 @@ } // 璇籄GV鍑烘枡 - byte[] RFAGVdown = new byte[] - { - agv.Communicator.Read<byte>($"DB1002.{doubleValues[16]}"), - agv.Communicator.Read<byte>($"DB1002.{doubleValues[17]}"), - agv.Communicator.Read<byte>($"DB1002.{doubleValues[18]}"), - agv.Communicator.Read<byte>($"DB1002.{doubleValues[19]}"), - agv.Communicator.Read<byte>($"DB1002.{doubleValues[20]}"), - agv.Communicator.Read<byte>($"DB1002.{doubleValues[21]}") - }; + short RFAGVdowna = agv.Communicator.Read<byte>($"DB1002.{doubleValues[16]}"); + short RFAGVdownb = agv.Communicator.Read<byte>($"DB1002.{doubleValues[17]}"); + short RFAGVdownc = agv.Communicator.Read<byte>($"DB1002.{doubleValues[18]}"); + short RFAGVdownd = agv.Communicator.Read<byte>($"DB1002.{doubleValues[19]}"); + short RFAGVdowne = agv.Communicator.Read<byte>($"DB1002.{doubleValues[20]}"); + short RFAGVdownf = agv.Communicator.Read<byte>($"DB1002.{doubleValues[21]}"); bool RFAGVdowng = agv.Communicator.Read<bool>($"DB1002.{doubleValues[23]}"); // 鍐欑儤鐑ゅ嚭鏂� - string[] writeAddressesDown = new string[] { "D1940", "D1941", "D1957", "D1952", "D1953", "D1958", "M692" }; - for (int i = 0; i < RFAGVdown.Length; i++) - { - roast.Communicator.Write(writeAddressesDown[i], RFAGVdown[i]); - } - roast.Communicator.Write(writeAddressesDown[6], RFAGVdowng); + //string[] writeAddressesDown = new string[] { "D1940", "D1941", "D1957", "D1952", "D1953", "D1958", "M692" }; + roast.Communicator.Write("D1940", RFAGVdowna); + roast.Communicator.Write("D1941", RFAGVdownb); + roast.Communicator.Write("D1957", RFAGVdownc); + roast.Communicator.Write("D1952", RFAGVdownd); + roast.Communicator.Write("D1953", RFAGVdowne); + roast.Communicator.Write("D1958", RFAGVdownf); + roast.Communicator.Write("M692", RFAGVdowng); } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/RoastZJob/CommonRoastZJob.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/RoastZJob/CommonRoastZJob.cs" new file mode 100644 index 0000000..7c85a97 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/RoastZJob/CommonRoastZJob.cs" @@ -0,0 +1,251 @@ +锘縰sing Quartz; +using System.Text.RegularExpressions; +using WIDESEAWCS_QuartzJob; + +namespace WIDESEAWCS_Tasks +{ + internal class CommonRoastZJob : JobBase, IJob, IDisposable + { + public CommonRoastZJob() + { + } + + public void Dispose() + { + GC.SuppressFinalize(this); + } + + public Task Execute(IJobExecutionContext context) + { + try + { + // 浠庝笂涓嬫枃涓幏鍙� JobParams 骞惰浆鎹负 Roast 绫诲瀷 + CommonRoastZ roast = (CommonRoastZ)context.JobDetail.JobDataMap.Get("JobParams"); + // 鍒濆鍖� AGV 鍙橀噺 + AGV agv = null; + + if (roast == null) + { + throw new Exception("鏈壘鍒扮儤鐑よ澶囧弬鏁般��"); + } + + // 鏍规嵁璁惧鍚嶇О鍐冲畾鏄鏋佽繕鏄礋鏋� AGV + string devicePrefix = roast.DeviceCode.Contains("FJ") ? "璐熸瀬" : "姝f瀬"; + string agvName = $"{devicePrefix}AGV"; + + // 浠庡瓨鍌ㄤ腑鏌ユ壘鎸囧畾鍚嶇О鐨勮澶� + IDevice? device = Storage.Devices.FirstOrDefault(x => x.DeviceName == agvName); + if (device != null) + { + agv = (AGV)device; + } + else + { + throw new Exception("鏈壘鍒癆GV璁惧鍙傛暟銆�"); + } + + // 浣跨敤姝e垯琛ㄨ揪寮忎粠璁惧鍚嶇О涓彁鍙栨暟瀛� + MatchCollection matches = Regex.Matches(roast.DeviceName, @"\d+"); + if (matches.Count == 0) + { + throw new Exception("No number found in device name."); + } + int number = int.Parse(matches[0].Value); + + + + // 鏍规嵁number鐨勫�奸�夋嫨鐩稿簲鐨刣ouble闆嗗悎骞惰皟鏁村�� + List<double> doubleValues = GetDoubleValues(roast.DeviceName.Contains("姝f瀬"), number); + + DeviceInteraction(roast, agv, doubleValues); + + } + catch (Exception ex) + { + Console.WriteLine(ex.Message); + } + return Task.CompletedTask; + } + + public static void DeviceInteraction(CommonRoastZ roast, AGV agv, List<double> doubleValues) + { + #region + ////璇荤儤鐑ゆ粴绛掓槸鍚﹁浆鍔� + //bool RHKupFGTZ1 = roast.Communicator.Read<bool>("YC"); + //bool RHKupFGTZ2 = roast.Communicator.Read<bool>("YD"); + //bool RHKupFGTZ3 = roast.Communicator.Read<bool>("YE"); + //bool RHKupFGTZ4 = roast.Communicator.Read<bool>("YF"); + ////鍐橝GV婊氱瓛杞姩 + //agv.Communicator.Write("DB1002." + doubleValues[0], RHKupFGTZ1); + //agv.Communicator.Write("DB1002." + doubleValues[1], RHKupFGTZ2); + //agv.Communicator.Write("DB1002." + doubleValues[2], RHKupFGTZ3); + //agv.Communicator.Write("DB1002." + doubleValues[3], RHKupFGTZ4); + + ////璇荤儤鐑ゅ叆鏂� + //var RFHKupa = roast.Communicator.Read<short>("D1960"); + //var RFHKupb = roast.Communicator.Read<short>("D15"); + //var RFHKupc = roast.Communicator.Read<short>("D1961"); + //var RFHKupd = roast.Communicator.Read<short>("D1950"); + //var RFHKupe = roast.Communicator.Read<short>("D1951"); + + ////鍐橝GV鍏ユ枡 + //agv.Communicator.Write("DB1002." + doubleValues[4], byte.Parse(RFHKupa.ToString())); + //agv.Communicator.Write("DB1002." + doubleValues[5], byte.Parse(RFHKupb.ToString())); + //agv.Communicator.Write("DB1002." + doubleValues[6], byte.Parse(RFHKupc.ToString())); + //agv.Communicator.Write("DB1002." + doubleValues[7], byte.Parse(RFHKupd.ToString())); + //agv.Communicator.Write("DB1002." + doubleValues[8], byte.Parse(RFHKupe.ToString())); + + ////璇籄GV鍏ユ枡 + //var RFAGVa = agv.Communicator.Read<byte>("DB1002." + doubleValues[9]); + //var RFAGVb = agv.Communicator.Read<byte>("DB1002." + doubleValues[10]); + //var RFAGVc = agv.Communicator.Read<byte>("DB1002." + doubleValues[11]); + //var RFAGVd = agv.Communicator.Read<byte>("DB1002." + doubleValues[12]); + //var RFAGVe = agv.Communicator.Read<byte>("DB1002." + doubleValues[22]); + + ////鍐欑儤鐑ゅ叆鏂� + //roast.Communicator.Write("D1940", RFAGVa); + //roast.Communicator.Write("D1941", RFAGVb); + //roast.Communicator.Write("D1955", RFAGVc); + //roast.Communicator.Write("D1956", RFAGVd); + //roast.Communicator.Write("M691", RFAGVe); + + ////璇荤儤鐑ゅ嚭鏂� + //var RFHKdowna = roast.Communicator.Read<short>("D1960"); + //var RFHKdownb = roast.Communicator.Read<short>("D35"); + //var RFHKdownc = roast.Communicator.Read<short>("D1962"); + + ////鍐橝GV鍑烘枡 + //agv.Communicator.Write("DB1002." + doubleValues[13], byte.Parse(RFHKdowna.ToString())); + //agv.Communicator.Write("DB1002." + doubleValues[14], byte.Parse(RFHKdownb.ToString())); + //agv.Communicator.Write("DB1002." + doubleValues[15], byte.Parse(RFHKdownc.ToString())); + + ////璇籄GV鍑烘枡 + //var RFAGVdowna = agv.Communicator.Read<byte>("DB1002." + doubleValues[16]); + //var RFAGVdownb = agv.Communicator.Read<byte>("DB1002." + doubleValues[17]); + //var RFAGVdownc = agv.Communicator.Read<byte>("DB1002." + doubleValues[18]); + //var RFAGVdownd = agv.Communicator.Read<byte>("DB1002." + doubleValues[19]); + //var RFAGVdowne = agv.Communicator.Read<byte>("DB1002." + doubleValues[20]); + //var RFAGVdownf = agv.Communicator.Read<byte>("DB1002." + doubleValues[21]); + //var RFAGVdowng = agv.Communicator.Read<bool>("DB1002." + doubleValues[23]); + + ////鍐欑儤鐑ゅ嚭鏂� + //roast.Communicator.Write("D1940", RFAGVdowna); + //roast.Communicator.Write("D1941", RFAGVdownb); + //roast.Communicator.Write("D1957", RFAGVdownc); + //roast.Communicator.Write("D1952", RFAGVdownd); + //roast.Communicator.Write("D1953", RFAGVdowne); + //roast.Communicator.Write("D1958", RFAGVdownf); + //roast.Communicator.Write("M692", RFAGVdowng); + #endregion + + // 璇荤儤鐑ゆ粴绛掓槸鍚﹁浆鍔� + bool[] RHKupFGTZ = new bool[] + { + roast.Communicator.Read<bool>("YC"), + roast.Communicator.Read<bool>("YD"), + roast.Communicator.Read<bool>("YE"), + roast.Communicator.Read<bool>("YF") + }; + + // 鍐橝GV婊氱瓛杞姩 + for (int i = 0; i < RHKupFGTZ.Length; i++) + { + agv.Communicator.Write($"DB1002.{doubleValues[i]}", RHKupFGTZ[i]); + } + + // 璇荤儤鐑ゅ叆鏂� + short[] RFHKup = new short[] + { + roast.Communicator.Read<short>("D1960"), + roast.Communicator.Read<short>("D15"), + roast.Communicator.Read<short>("D1961"), + roast.Communicator.Read<short>("D1950"), + roast.Communicator.Read<short>("D1951") + }; + + // 鍐橝GV鍏ユ枡 + for (int i = 0; i < RFHKup.Length; i++) + { + agv.Communicator.Write($"DB1002.{doubleValues[i + 4]}", (byte)RFHKup[i]); + } + + // 璇籄GV鍏ユ枡 + + short RFAGVa = agv.Communicator.Read<byte>($"DB1002.{doubleValues[9]}"); + short RFAGVb = agv.Communicator.Read<byte>($"DB1002.{doubleValues[10]}"); + short RFAGVc = agv.Communicator.Read<byte>($"DB1002.{doubleValues[11]}"); + short RFAGVd = agv.Communicator.Read<byte>($"DB1002.{doubleValues[12]}"); + bool RFAGVe = agv.Communicator.Read<bool>($"DB1002.{doubleValues[22]}"); + + + // 鍐欑儤鐑ゅ叆鏂� + //string[] writeAddressesUp = new string[] { "D1940", "D1941", "D1955", "D1956", "M691" }; + //for (int i = 0; i < RFAGVup.Length; i++) + //{ + // roast.Communicator.Write(writeAddressesUp[i], RFAGVup[i]); + //} + roast.Communicator.Write("D1940", RFAGVa); + roast.Communicator.Write("D1941", RFAGVb); + roast.Communicator.Write("D1955", RFAGVc); + roast.Communicator.Write("D1956", RFAGVd); + roast.Communicator.Write("M691", RFAGVe); + // 璇荤儤鐑ゅ嚭鏂� + short[] RFHKdown = new short[] + { + roast.Communicator.Read<short>("D1960"), + roast.Communicator.Read<short>("D35"), + roast.Communicator.Read<short>("D1962") + }; + + // 鍐橝GV鍑烘枡 + for (int i = 0; i < RFHKdown.Length; i++) + { + agv.Communicator.Write($"DB1002.{doubleValues[i + 13]}", (byte)RFHKdown[i]); + } + + // 璇籄GV鍑烘枡 + short RFAGVdowna = agv.Communicator.Read<byte>($"DB1002.{doubleValues[16]}"); + short RFAGVdownb = agv.Communicator.Read<byte>($"DB1002.{doubleValues[17]}"); + short RFAGVdownc = agv.Communicator.Read<byte>($"DB1002.{doubleValues[18]}"); + short RFAGVdownd = agv.Communicator.Read<byte>($"DB1002.{doubleValues[19]}"); + short RFAGVdowne = agv.Communicator.Read<byte>($"DB1002.{doubleValues[20]}"); + short RFAGVdownf = agv.Communicator.Read<byte>($"DB1002.{doubleValues[21]}"); + bool RFAGVdowng = agv.Communicator.Read<bool>($"DB1002.{doubleValues[23]}"); + + // 鍐欑儤鐑ゅ嚭鏂� + //string[] writeAddressesDown = new string[] { "D1940", "D1941", "D1957", "D1952", "D1953", "D1958", "M692" }; + roast.Communicator.Write("D1940", RFAGVdowna); + roast.Communicator.Write("D1941", RFAGVdownb); + roast.Communicator.Write("D1957", RFAGVdownc); + roast.Communicator.Write("D1952", RFAGVdownd); + roast.Communicator.Write("D1953", RFAGVdowne); + roast.Communicator.Write("D1958", RFAGVdownf); + roast.Communicator.Write("M692", RFAGVdowng); + } + + + // 鏍规嵁璁惧绫诲瀷鍜宯umber鐨勫�艰幏鍙栧苟璋冩暣double鍊奸泦鍚� + private List<double> GetDoubleValues(bool isPositivePole, int number) + { + List<double> doubleValues; + + if (isPositivePole) + { + doubleValues = number < 3 + ? new List<double> { 8093.6, 8093.7, 3493.6, 3493.7, 8094.0, 8095.0, 8096.0, 8097.0, 8098.0, 8194.0, 8195.0, 8196.0, 8197.0, 3494.0, 3495.0, 3496.0, 3594.0, 3595.0, 3596.0, 3597.0, 3598.0, 3599.0, 8192.2, 3592.2 } + : new List<double> { 1693.6, 1693.7, 293.6, 293.6, 1694.0, 1695.0, 1696.0, 1697.0, 1698.0, 1794.0, 1795.0, 1796.0, 1797.0, 294.0, 295.0, 296.0, 394.0, 395.0, 396.0, 397.0, 398.0, 399.0, 1792.2, 392.2 }; + } + else // 璐熸瀬 + { + doubleValues = number < 3 + ? new List<double> { 8893.6, 8893.7, 9093.6, 9093.7, 8894.0, 8895.0, 8896.0, 8897.0, 8898.0, 8994.0, 8995.0, 8996.0, 8997.0, 9094.0, 9095.0, 9096.0, 9194.0, 9195.0, 9196.0, 9197.0, 9198.0, 9199.0, 8992.2, 9192.2 } + : new List<double> { 4893.6, 4893.7, 5093.6, 5093.6, 4894.0, 4895.0, 4896.0, 4897.0, 4898.0, 4994.0, 4995.0, 4996.0, 4997.0, 5094.0, 5095.0, 5096.0, 5194.0, 5195.0, 5196.0, 5197.0, 5198.0, 5199.0, 4992.2, 5192.2 }; + } + + // 璋冩暣double闆嗗悎涓殑姣忎釜鍏冪礌 + int adjustmentFactor = (number < 3 ? (number - 1) : (number - 3)) * 400; + return doubleValues.Select(val => val + adjustmentFactor).ToList(); + + } + } +} \ No newline at end of file diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/AgvAndEquiWorkF.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/AgvAndEquiWorkF.cs" index cde8305..2191e19 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/AgvAndEquiWorkF.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/AgvAndEquiWorkF.cs" @@ -104,7 +104,7 @@ aa = tsjplc.SiemensPLCClient.SiemensS7NetClient.Write("DB1002.11400", agvkpbdownmes.Content.ToArray()); //璇籥gv - OperateResult<byte[]> agvkcpupmes = fagvthreeplc.SiemensPLCClient.SiemensS7NetClient.Read("DB1002.17900", 100); + OperateResult<byte[]> agvkcpupmes = fagvthreeplc.SiemensPLCClient.SiemensS7NetClient.Read("DB1002.17900", 100); //璐熸瀬绾夸綋 OperateResult<byte[]> agvkcpdownmes = fagvthreeplc.SiemensPLCClient.SiemensS7NetClient.Read("DB1002.18100", 100); //鍐欐彁鍗囨満 aa = tsjplc.SiemensPLCClient.SiemensS7NetClient.Write("DB1002.1900", agvkcpupmes.Content.ToArray()); diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/AgvAndEquiWorkThree.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/AgvAndEquiWorkThree.cs" index 395cbf9..f599e25 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/AgvAndEquiWorkThree.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/AgvAndEquiWorkThree.cs" @@ -121,35 +121,35 @@ OperateResult<byte> RAGVd = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvdbi + fornum)); OperateResult<bool> RAGVe = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadBool("DB1002." + (agvdby + fornum)); //鍏ユ枡鍙e啓鐑樼 - OperateResult Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1940", RAGVa.Content); - Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1941", RAGVb.Content); - Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1955", RAGVc.Content); - Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1956", RAGVd.Content); - Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("M691", RAGVe.Content); - //涓嬫枡鍙h鐑樼 - OperateResult<short> RHKdowna = ZHSSBone.MelsecPLCClient.readWriteNet.ReadInt16("D1960"); - OperateResult<short> RHKdownb = ZHSSBone.MelsecPLCClient.readWriteNet.ReadInt16("D35"); - OperateResult<short> RHKdownc = ZHSSBone.MelsecPLCClient.readWriteNet.ReadInt16("D1962"); - //涓嬫枡鍙e啓AGV - OperateResult Wdownresult = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvdbj + fornum), byte.Parse(RHKdowna.Content.ToString())); - Wdownresult = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvdbk + fornum), byte.Parse(RHKdownb.Content.ToString())); - Wdownresult = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvdbl + fornum), byte.Parse(RHKdownc.Content.ToString())); + //OperateResult Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1940", RAGVa.Content); + //Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1941", RAGVb.Content); + //Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1955", RAGVc.Content); + //Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1956", RAGVd.Content); + //Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("M691", RAGVe.Content); + ////涓嬫枡鍙h鐑樼 + //OperateResult<short> RHKdowna = ZHSSBone.MelsecPLCClient.readWriteNet.ReadInt16("D1960"); + //OperateResult<short> RHKdownb = ZHSSBone.MelsecPLCClient.readWriteNet.ReadInt16("D35"); + //OperateResult<short> RHKdownc = ZHSSBone.MelsecPLCClient.readWriteNet.ReadInt16("D1962"); + ////涓嬫枡鍙e啓AGV + //OperateResult Wdownresult = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvdbj + fornum), byte.Parse(RHKdowna.Content.ToString())); + //Wdownresult = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvdbk + fornum), byte.Parse(RHKdownb.Content.ToString())); + //Wdownresult = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvdbl + fornum), byte.Parse(RHKdownc.Content.ToString())); //涓嬫枡鍙hAGV - OperateResult<byte> RAGVdowna = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvdbm + fornum)); - OperateResult<byte> RAGVdownb = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvdbq + fornum)); - OperateResult<byte> RAGVdownc = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvdbr + fornum)); - OperateResult<byte> RAGVdownd = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvdbs + fornum)); - OperateResult<byte> RAGVdowne = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvdbt + fornum)); - OperateResult<byte> RAGVdownf = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvdbx + fornum)); - OperateResult<bool> RAGVdowng = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadBool("DB1002." + (agvdbz + fornum)); - //涓嬫枡鍙e啓鐑樼 - OperateResult Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1940", RAGVdowna.Content); - Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1941", RAGVdownb.Content); - Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1957", RAGVdownc.Content); - Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1952", RAGVdownd.Content); - Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1953", RAGVdowne.Content); - Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1958", RAGVdownf.Content); - Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("M692", RAGVdowng.Content); + //OperateResult<byte> RAGVdowna = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvdbm + fornum)); + //OperateResult<byte> RAGVdownb = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvdbq + fornum)); + //OperateResult<byte> RAGVdownc = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvdbr + fornum)); + //OperateResult<byte> RAGVdownd = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvdbs + fornum)); + //OperateResult<byte> RAGVdowne = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvdbt + fornum)); + //OperateResult<byte> RAGVdownf = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvdbx + fornum)); + //OperateResult<bool> RAGVdowng = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadBool("DB1002." + (agvdbz + fornum)); + ////涓嬫枡鍙e啓鐑樼 + //OperateResult Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1940", RAGVdowna.Content); + //Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1941", RAGVdownb.Content); + //Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1957", RAGVdownc.Content); + //Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1952", RAGVdownd.Content); + //Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1953", RAGVdowne.Content); + //Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1958", RAGVdownf.Content); + //Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("M692", RAGVdowng.Content); fornum += 400; } @@ -199,9 +199,9 @@ //鍐橝GV婊氱瓛杞姩 OperateResult WupresultGTZ1 = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbaZGT1 + fornumthree), RHKupGTZ1.Content); - WupresultGTZ1 = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbaZGT2 + fornumthree), RHKupGTZ2.Content); - WupresultGTZ1 = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbaZGT3 + fornumthree), RHKupGTZ3.Content); - WupresultGTZ1 = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbaZGT4 + fornumthree), RHKupGTZ4.Content); + //WupresultGTZ1 = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbaZGT2 + fornumthree), RHKupGTZ2.Content); + //WupresultGTZ1 = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbaZGT3 + fornumthree), RHKupGTZ3.Content); + //WupresultGTZ1 = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbaZGT4 + fornumthree), RHKupGTZ4.Content); //鍏ユ枡鍙h鐑樼 OperateResult<short> RHKupa = ZHSSBone.MelsecPLCClient.readWriteNet.ReadInt16("D1960"); @@ -211,10 +211,10 @@ OperateResult<short> RHKupe = ZHSSBone.MelsecPLCClient.readWriteNet.ReadInt16("D1951"); //鍏ユ枡鍙e啓AGV OperateResult Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedba + fornumthree), byte.Parse(RHKupa.Content.ToString())); - Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbb + fornumthree), byte.Parse(RHKupb.Content.ToString())); - Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbc + fornumthree), byte.Parse(RHKupc.Content.ToString())); - Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbd + fornumthree), byte.Parse(RHKupd.Content.ToString())); - Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbe + fornumthree), byte.Parse(RHKupe.Content.ToString())); + //Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbb + fornumthree), byte.Parse(RHKupb.Content.ToString())); + //Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbc + fornumthree), byte.Parse(RHKupc.Content.ToString())); + //Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbd + fornumthree), byte.Parse(RHKupd.Content.ToString())); + //Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbe + fornumthree), byte.Parse(RHKupe.Content.ToString())); //鍏ユ枡鍙hagv OperateResult<byte> RAGVa = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbf + fornumthree)); OperateResult<byte> RAGVb = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbg + fornumthree)); @@ -222,36 +222,36 @@ OperateResult<byte> RAGVd = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbi + fornumthree)); OperateResult<bool> RAGVe = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadBool("DB1002." + (agvthreedby + fornumthree)); //鍏ユ枡鍙e啓鐑樼 - OperateResult Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1940", RAGVa.Content); - Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1941", RAGVb.Content); - Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1955", RAGVc.Content); - Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1956", RAGVd.Content); - Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("M691", RAGVe.Content); - //涓嬫枡鍙h鐑樼 - OperateResult<short> RHKdowna = ZHSSBone.MelsecPLCClient.readWriteNet.ReadInt16("D1960"); - OperateResult<short> RHKdownb = ZHSSBone.MelsecPLCClient.readWriteNet.ReadInt16("D35"); - OperateResult<short> RHKdownc = ZHSSBone.MelsecPLCClient.readWriteNet.ReadInt16("D1962"); - //涓嬫枡鍙e啓AGV - OperateResult Wdownresult = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbj + fornumthree), byte.Parse(RHKdowna.Content.ToString())); + //OperateResult Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1940", RAGVa.Content); + //Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1941", RAGVb.Content); + //Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1955", RAGVc.Content); + //Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1956", RAGVd.Content); + //Whkresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("M691", RAGVe.Content); + ////涓嬫枡鍙h鐑樼 + //OperateResult<short> RHKdowna = ZHSSBone.MelsecPLCClient.readWriteNet.ReadInt16("D1960"); + //OperateResult<short> RHKdownb = ZHSSBone.MelsecPLCClient.readWriteNet.ReadInt16("D35"); + //OperateResult<short> RHKdownc = ZHSSBone.MelsecPLCClient.readWriteNet.ReadInt16("D1962"); + ////涓嬫枡鍙e啓AGV + //OperateResult Wdownresult = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbj + fornumthree), byte.Parse(RHKdowna.Content.ToString())); - Wdownresult = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbk + fornumthree), byte.Parse(RHKdownb.Content.ToString())); - Wdownresult = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbl + fornumthree), byte.Parse(RHKdownc.Content.ToString())); - //涓嬫枡鍙hAGV - OperateResult<byte> RAGVdowna = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbm + fornumthree)); - OperateResult<byte> RAGVdownb = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbq + fornumthree)); - OperateResult<byte> RAGVdownc = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbr + fornumthree)); - OperateResult<byte> RAGVdownd = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbs + fornumthree)); - OperateResult<byte> RAGVdowne = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbt + fornumthree)); - OperateResult<byte> RAGVdownf = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbx + fornumthree)); - OperateResult<bool> RAGVdowng = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadBool("DB1002." + (agvthreedbz + fornumthree)); - //涓嬫枡鍙e啓鐑樼 - OperateResult Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1940", RAGVdowna.Content); - Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1941", RAGVdownb.Content); - Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1957", RAGVdownc.Content); - Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1952", RAGVdownd.Content); - Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1953", RAGVdowne.Content); - Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1958", RAGVdownf.Content); - Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("M692", RAGVdowng.Content); + //Wdownresult = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbk + fornumthree), byte.Parse(RHKdownb.Content.ToString())); + //Wdownresult = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbl + fornumthree), byte.Parse(RHKdownc.Content.ToString())); + ////涓嬫枡鍙hAGV + //OperateResult<byte> RAGVdowna = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbm + fornumthree)); + //OperateResult<byte> RAGVdownb = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbq + fornumthree)); + //OperateResult<byte> RAGVdownc = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbr + fornumthree)); + //OperateResult<byte> RAGVdownd = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbs + fornumthree)); + //OperateResult<byte> RAGVdowne = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbt + fornumthree)); + //OperateResult<byte> RAGVdownf = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbx + fornumthree)); + //OperateResult<bool> RAGVdowng = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadBool("DB1002." + (agvthreedbz + fornumthree)); + ////涓嬫枡鍙e啓鐑樼 + //OperateResult Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1940", RAGVdowna.Content); + //Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1941", RAGVdownb.Content); + //Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1957", RAGVdownc.Content); + //Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1952", RAGVdownd.Content); + //Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1953", RAGVdowne.Content); + //Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("D1958", RAGVdownf.Content); + //Whkdownresult = ZHSSBone.MelsecPLCClient.readWriteNet.Write("M692", RAGVdowng.Content); fornumthree += 400; } diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/AgvAndEquiWorkThreeHKFJ.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/AgvAndEquiWorkThreeHKFJ.cs" index 68138ed..2035c09 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/AgvAndEquiWorkThreeHKFJ.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/AgvAndEquiWorkThreeHKFJ.cs" @@ -44,7 +44,7 @@ double agvthreedbFx = 5199.0; double agvthreedbFy = 4992.2; double agvthreedbFz = 5192.2; - List<string> FHKFQSBMegthree = new List<string> { "璐熸瀬6鍙风儤鐑ゆ満","璐熸瀬7鍙风儤鐑ゆ満", "璐熸瀬8鍙风儤鐑ゆ満", "璐熸瀬9鍙风儤鐑ゆ満", "璐熸瀬10鍙风儤鐑ゆ満" }; + List<string> FHKFQSBMegthree = new List<string> { "璐熸瀬7鍙风儤鐑ゆ満"}; foreach (var FHKSBthree in FHKFQSBMegthree) { if (fagvthreeplchk == null) diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/ToMesggeThreeHKZJ.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/ToMesggeThreeHKZJ.cs" index 91f04a2..709edfb 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/ToMesggeThreeHKZJ.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCS/SchedulerExecute/AGV/ToMesggeThreeHKZJ.cs" @@ -30,8 +30,8 @@ double agvthreedbc = 1696.0; double agvthreedbd = 1697.0; double agvthreedbe = 1698.0; - double agvthreedbf = 1794.0; - double agvthreedbg = 1795.0; + double agvthreedbf = 1794.0; + double agvthreedbg = 1795.0; double agvthreedbh = 1796.0; double agvthreedbi = 1797.0; double agvthreedbj = 294.0; @@ -64,9 +64,9 @@ //鍐橝GV婊氱瓛杞姩 OperateResult WupresultGTZ1 = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbaZGT1 + fornumthree), RHKupGTZ1.Content); - WupresultGTZ1 = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbaZGT2 + fornumthree), RHKupGTZ2.Content); - WupresultGTZ1 = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbaZGT3 + fornumthree), RHKupGTZ3.Content); - WupresultGTZ1 = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbaZGT4 + fornumthree), RHKupGTZ4.Content); + //WupresultGTZ1 = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbaZGT2 + fornumthree), RHKupGTZ2.Content); + //WupresultGTZ1 = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbaZGT3 + fornumthree), RHKupGTZ3.Content); + //WupresultGTZ1 = agvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbaZGT4 + fornumthree), RHKupGTZ4.Content); //鍏ユ枡鍙h鐑樼 OperateResult<short> RHKupa = ZHSSBone.MelsecPLCClient.readWriteNet.ReadInt16("D1960"); @@ -76,14 +76,14 @@ OperateResult<short> RHKupe = ZHSSBone.MelsecPLCClient.readWriteNet.ReadInt16("D1951"); //鍏ユ枡鍙e啓AGV OperateResult Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedba + fornumthree), byte.Parse(RHKupa.Content.ToString())); - Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbb + fornumthree), byte.Parse(RHKupb.Content.ToString())); - Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbc + fornumthree), byte.Parse(RHKupc.Content.ToString())); - Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbd + fornumthree), byte.Parse(RHKupd.Content.ToString())); - Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbe + fornumthree), byte.Parse(RHKupe.Content.ToString())); + //Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbb + fornumthree), byte.Parse(RHKupb.Content.ToString())); + //Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbc + fornumthree), byte.Parse(RHKupc.Content.ToString())); + //Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbd + fornumthree), byte.Parse(RHKupd.Content.ToString())); + //Wupresult = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.Write("DB1002." + (agvthreedbe + fornumthree), byte.Parse(RHKupe.Content.ToString())); //鍏ユ枡鍙hagv - OperateResult<byte> RAGVa = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbf + fornumthree)); - OperateResult<byte> RAGVb = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbg + fornumthree)); - OperateResult<byte> RAGVc = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbh + fornumthree)); + OperateResult<byte> RAGVa = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbf + fornumthree));//3394 + OperateResult<byte> RAGVb = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbg + fornumthree));//3395 + OperateResult<byte> RAGVc = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbh + fornumthree));//3396 1792.2+1600 OperateResult<byte> RAGVd = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadByte("DB1002." + (agvthreedbi + fornumthree)); OperateResult<bool> RAGVe = fagvthreeplcthree.SiemensPLCClient.SiemensS7NetClient.ReadBool("DB1002." + (agvthreedby + fornumthree)); //鍏ユ枡鍙e啓鐑樼 diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCSServer/Download/Logger/Queue/WriteError/20250411.txt" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCSServer/Download/Logger/Queue/WriteError/20250411.txt" new file mode 100644 index 0000000..06f3873 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCSServer/Download/Logger/Queue/WriteError/20250411.txt" @@ -0,0 +1,8 @@ +Cannot access destination table 'Sys_Log'. at System.Data.SqlClient.SqlBulkCopy.WriteToServerInternalRestAsync(CancellationToken cts, TaskCompletionSource`1 source) + at System.Data.SqlClient.SqlBulkCopy.WriteToServerInternalAsync(CancellationToken ctoken) + at System.Data.SqlClient.SqlBulkCopy.WriteRowSourceToServerAsync(Int32 columnCount, CancellationToken ctoken) + at System.Data.SqlClient.SqlBulkCopy.WriteToServer(DataTable table, DataRowState rowState) + at System.Data.SqlClient.SqlBulkCopy.WriteToServer(DataTable table) + at WIDESEA_Core.Dapper.SqlDapper.MSSqlBulkInsert(DataTable table, String tableName, SqlBulkCopyOptions sqlBulkCopyOptions, String dbKeyName) in E:\KHGITHUB\GanFengLiYeNew\浠g爜绠$悊\WIDESEA_WCSServer\WIDESEA_Core\Dapper\SqlDapper.cs:line 391 + at WIDESEA_Core.Dapper.SqlDapper.BulkInsert(DataTable table, String tableName, Nullable`1 sqlBulkCopyOptions, String fileName, String tmpPath) in E:\KHGITHUB\GanFengLiYeNew\浠g爜绠$悊\WIDESEA_WCSServer\WIDESEA_Core\Dapper\SqlDapper.cs:line 416 + at WIDESEA_Core.Services.Logger.Start() in E:\KHGITHUB\GanFengLiYeNew\浠g爜绠$悊\WIDESEA_WCSServer\WIDESEA_Core\Services\Logger.cs:line 143System.Data.SqlClient diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCSServer/Download/Logger/Queue/WriteError/20250412.txt" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCSServer/Download/Logger/Queue/WriteError/20250412.txt" new file mode 100644 index 0000000..06f3873 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCSServer/Download/Logger/Queue/WriteError/20250412.txt" @@ -0,0 +1,8 @@ +Cannot access destination table 'Sys_Log'. at System.Data.SqlClient.SqlBulkCopy.WriteToServerInternalRestAsync(CancellationToken cts, TaskCompletionSource`1 source) + at System.Data.SqlClient.SqlBulkCopy.WriteToServerInternalAsync(CancellationToken ctoken) + at System.Data.SqlClient.SqlBulkCopy.WriteRowSourceToServerAsync(Int32 columnCount, CancellationToken ctoken) + at System.Data.SqlClient.SqlBulkCopy.WriteToServer(DataTable table, DataRowState rowState) + at System.Data.SqlClient.SqlBulkCopy.WriteToServer(DataTable table) + at WIDESEA_Core.Dapper.SqlDapper.MSSqlBulkInsert(DataTable table, String tableName, SqlBulkCopyOptions sqlBulkCopyOptions, String dbKeyName) in E:\KHGITHUB\GanFengLiYeNew\浠g爜绠$悊\WIDESEA_WCSServer\WIDESEA_Core\Dapper\SqlDapper.cs:line 391 + at WIDESEA_Core.Dapper.SqlDapper.BulkInsert(DataTable table, String tableName, Nullable`1 sqlBulkCopyOptions, String fileName, String tmpPath) in E:\KHGITHUB\GanFengLiYeNew\浠g爜绠$悊\WIDESEA_WCSServer\WIDESEA_Core\Dapper\SqlDapper.cs:line 416 + at WIDESEA_Core.Services.Logger.Start() in E:\KHGITHUB\GanFengLiYeNew\浠g爜绠$悊\WIDESEA_WCSServer\WIDESEA_Core\Services\Logger.cs:line 143System.Data.SqlClient diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCSServer/Download/Logger/Queue/WriteError/20250413.txt" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCSServer/Download/Logger/Queue/WriteError/20250413.txt" new file mode 100644 index 0000000..06f3873 --- /dev/null +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEA_WCSServer/WIDESEA_WCSServer/Download/Logger/Queue/WriteError/20250413.txt" @@ -0,0 +1,8 @@ +Cannot access destination table 'Sys_Log'. at System.Data.SqlClient.SqlBulkCopy.WriteToServerInternalRestAsync(CancellationToken cts, TaskCompletionSource`1 source) + at System.Data.SqlClient.SqlBulkCopy.WriteToServerInternalAsync(CancellationToken ctoken) + at System.Data.SqlClient.SqlBulkCopy.WriteRowSourceToServerAsync(Int32 columnCount, CancellationToken ctoken) + at System.Data.SqlClient.SqlBulkCopy.WriteToServer(DataTable table, DataRowState rowState) + at System.Data.SqlClient.SqlBulkCopy.WriteToServer(DataTable table) + at WIDESEA_Core.Dapper.SqlDapper.MSSqlBulkInsert(DataTable table, String tableName, SqlBulkCopyOptions sqlBulkCopyOptions, String dbKeyName) in E:\KHGITHUB\GanFengLiYeNew\浠g爜绠$悊\WIDESEA_WCSServer\WIDESEA_Core\Dapper\SqlDapper.cs:line 391 + at WIDESEA_Core.Dapper.SqlDapper.BulkInsert(DataTable table, String tableName, Nullable`1 sqlBulkCopyOptions, String fileName, String tmpPath) in E:\KHGITHUB\GanFengLiYeNew\浠g爜绠$悊\WIDESEA_WCSServer\WIDESEA_Core\Dapper\SqlDapper.cs:line 416 + at WIDESEA_Core.Services.Logger.Start() in E:\KHGITHUB\GanFengLiYeNew\浠g爜绠$悊\WIDESEA_WCSServer\WIDESEA_Core\Services\Logger.cs:line 143System.Data.SqlClient -- Gitblit v1.9.3