From 2ae5aa151f7b40a082e34aa7ed22b4b64edd1d3c Mon Sep 17 00:00:00 2001 From: dengjunjie <dengjunjie@hnkhzn.com> Date: 星期三, 11 六月 2025 17:13:56 +0800 Subject: [PATCH] 修改堆垛机通讯协议及交互逻辑 --- 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Service/LocationInfoService.cs | 204 ++++++++++++++++++++++++-------------------------- 1 files changed, 99 insertions(+), 105 deletions(-) diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Service/LocationInfoService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Service/LocationInfoService.cs" index e83cbd1..c2016d0 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Service/LocationInfoService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Service/LocationInfoService.cs" @@ -39,17 +39,17 @@ { try { - Dt_RoadwayInfo roadwayInfo = _basicRepository.RoadwayInfoRepository.QueryFirst(x => x.InStationCode == stationCode) ?? throw new Exception("鏈壘鍒拌绔欏彴瀵瑰簲鐨勫贩閬擄紝璇锋鏌ュ熀纭�閰嶇疆淇℃伅"); + Dt_RoadwayInfo roadwayInfo = _basicRepository.RoadwayInfoRepository.QueryFirst(x => x.InStationCode == stationCode) ?? throw new Exception("鏈壘鍒拌绔欏彴瀵瑰簲鐨勫贩閬擄紝璇锋鏌ュ熀纭�閰嶇疆淇℃伅!"); if (roadwayInfo.EnableStatus != EnableStatusEnum.Normal.ObjToInt() && roadwayInfo.EnableStatus != EnableStatusEnum.OnlyIn.ObjToInt()) { - throw new Exception("璇ュ贩閬撲笉鍙叆搴擄紝璇锋鏌ュ贩閬撶鐢ㄤ俊鎭�"); + throw new Exception("璇ュ贩閬撲笉鍙叆搴擄紝璇锋鏌ュ贩閬撶鐢ㄤ俊鎭�!"); } if (roadwayInfo.AreaId > 0) { Dt_AreaInfo areaInfo = _basicRepository.AreaInfoRepository.QueryFirst(x => x.Id == roadwayInfo.AreaId); if (areaInfo != null && areaInfo.AreaStatus == EnableEnum.Disable.ObjToInt()) { - throw new Exception("鍖哄煙琚鐢紝涓嶅彲鍏ュ簱"); + throw new Exception("鍖哄煙琚鐢紝涓嶅彲鍏ュ簱!"); } } if (inboundType == TaskTypeEnum.PalletInbound.ObjToInt())//绌虹洏鍏ュ簱鍒嗛厤閫昏緫 @@ -63,7 +63,7 @@ } catch (Exception ex) { - + throw new Exception(ex.Message); } return null; @@ -76,26 +76,28 @@ private Dt_LocationInfo EmptyAssignLocation(string roadway) { List<LocationGroupDTO> locationGroups = BaseDal.GetLocationGroups(roadway, LocationStatusEnum.Free, LocationStatusEnum.Pallet); + ///鏍规嵁宸烽亾杩涜鎺掑簭 if (locationGroups != null && locationGroups.Count > 0) { - LocationGroupDTO? locationGroup = locationGroups.FirstOrDefault(x => x.EnableStatusA == EnableStatusEnum.OnlyIn.ObjToInt() || x.EnableStatusA == EnableStatusEnum.Normal.ObjToInt()); + LocationGroupDTO? locationGroup = locationGroups.FirstOrDefault(x => x.EnableStatusA == EnableStatusEnum.Normal.ObjToInt()|| x.EnableStatusA == EnableStatusEnum.OnlyIn.ObjToInt()); int id = locationGroup?.IdA ?? 0; return BaseDal.QueryFirst(x => x.Id == id); } locationGroups = BaseDal.GetLocationGroups(roadway, LocationStatusEnum.Free, LocationStatusEnum.Free); if (locationGroups != null && locationGroups.Count > 0) { - LocationGroupDTO? locationGroup = locationGroups.FirstOrDefault(x => x.EnableStatusB == EnableStatusEnum.OnlyIn.ObjToInt() || x.EnableStatusB == EnableStatusEnum.Normal.ObjToInt()); + LocationGroupDTO? locationGroup = locationGroups.FirstOrDefault(x => x.EnableStatusB == EnableStatusEnum.Normal.ObjToInt()||x.EnableStatusB == EnableStatusEnum.OnlyIn.ObjToInt()); int id = locationGroup?.IdB ?? 0; return BaseDal.QueryFirst(x => x.Id == id); } - return BaseDal.QueryFirst(x => x.LocationStatus == LocationStatusEnum.Free.ObjToInt() && (x.EnableStatus == EnableStatusEnum.OnlyIn.ObjToInt() || x.EnableStatus == EnableStatusEnum.Normal.ObjToInt() && x.RoadwayNo == roadway), _emptyAssignOrderBy); + return BaseDal.QueryFirst(x => x.LocationStatus == LocationStatusEnum.Free.ObjToInt() && (x.EnableStatus == EnableStatusEnum.Normal.ObjToInt()||x.EnableStatus == EnableStatusEnum.OnlyIn.ObjToInt() && x.RoadwayNo == roadway), _emptyAssignOrderBy); } private Dt_LocationInfo StoredAssignLocation(string roadway) { List<LocationGroupDTO> locationGroups = BaseDal.GetLocationGroups(roadway, LocationStatusEnum.Free, LocationStatusEnum.InStock); + ///鏍规嵁宸烽亾杩涜鎺掑簭 if (locationGroups != null && locationGroups.Count > 0) { LocationGroupDTO? locationGroup = locationGroups.FirstOrDefault(x => x.EnableStatusA == EnableStatusEnum.OnlyIn.ObjToInt() || x.EnableStatusA == EnableStatusEnum.Normal.ObjToInt()); @@ -115,51 +117,50 @@ public Dt_LocationInfo AdjacentDepthLocation(string locationCode) { - Dt_LocationInfo locationInfo = BaseDal.QueryFirst(x => x.LocationCode == locationCode); - return AdjacentDepthLocation(locationInfo); + return AdjacentDepthLocation(BaseDal.QueryFirst(x => x.LocationCode == locationCode)); } public Dt_LocationInfo AdjacentDepthLocation(Dt_LocationInfo locationInfo) { - return BaseDal.QueryFirst(x => x.RoadwayNo == locationInfo.RoadwayNo && x.Column == locationInfo.Column && x.Layer == locationInfo.Layer && x.Depth != locationInfo.Depth && x.Row != locationInfo.Row && (SqlFunc.Abs(x.Row - locationInfo.Row) == 1)); + return BaseDal.QueryFirst(x => x.Column == locationInfo.Column && x.RoadwayNo == locationInfo.RoadwayNo && x.Layer == locationInfo.Layer && x.Depth != locationInfo.Depth && x.Row != locationInfo.Row && (SqlFunc.Abs(x.Row - locationInfo.Row) == 1)); } public void UpdateLocationLock(Dt_LocationInfo locations, int TaskNum,int changType,bool black) { try { + Dt_LocationInfo result = isDepth(locations); + int beforeStatusEnd = 0; if (black) { - (Dt_LocationInfo?, int?) result = isDepth(locations); - if (result.Item1 != null && (result.Item2 == LocationStatusEnum.Free.ObjToInt()|| result.Item2 == LocationStatusEnum.Lock.ObjToInt())) + if (result != null && (result.LocationStatus == LocationStatusEnum.Free.ObjToInt()|| result.LocationStatus == LocationStatusEnum.Lock.ObjToInt())) { - int beforeStatusEnd = result.Item1.LocationStatus; + beforeStatusEnd = result.LocationStatus; - result.Item1.LocationStatus = LocationStatusEnum.Lock.ObjToInt(); + result.LocationStatus = LocationStatusEnum.Lock.ObjToInt(); - BaseDal.UpdateData(result.Item1); + BaseDal.UpdateData(result); - _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(result.Item1, beforeStatusEnd, changType, "", TaskNum); + _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(result, beforeStatusEnd, changType, "", TaskNum); } } else { - (Dt_LocationInfo?, int?) result = isDepth(locations); - if (result.Item1 != null && result.Item2 == LocationStatusEnum.Free.ObjToInt()) + if (result != null && result.LocationStatus == LocationStatusEnum.Free.ObjToInt()) { - int beforeStatusEnd = result.Item1.LocationStatus; + beforeStatusEnd = result.LocationStatus; - result.Item1.LocationStatus = LocationStatusEnum.Lock.ObjToInt(); + result.LocationStatus = LocationStatusEnum.Lock.ObjToInt(); - BaseDal.UpdateData(result.Item1); + BaseDal.UpdateData(result); - _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(result.Item1, beforeStatusEnd, changType, "", TaskNum); + _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(result, beforeStatusEnd, changType, "", TaskNum); } } } catch (Exception ex) { - throw ex; + throw new Exception(ex.Message); } } @@ -167,120 +168,113 @@ { try { - (Dt_LocationInfo?, int?) result = isDepth(locations); - if (result.Item1 != null) + Dt_LocationInfo result = isDepth(locations); + if (!black) { - int beforeStatusEnd = result.Item1.LocationStatus; + if (result != null) + { + int beforeStatusEnd = result.LocationStatus; - result.Item1.LocationStatus = LocationStatusEnum.Free.ObjToInt(); + result.LocationStatus = LocationStatusEnum.Free.ObjToInt(); - BaseDal.UpdateData(result.Item1); + BaseDal.UpdateData(result); - _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(result.Item1, beforeStatusEnd, changType, "", TaskNum); + _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(result, beforeStatusEnd, changType, "", TaskNum); + } + } + else + { + if (result != null&&(result.LocationStatus== LocationStatusEnum.Lock.ObjToInt()|| result.LocationStatus==LocationStatusEnum.PalletLock.ObjToInt())) + { + int beforeStatusEnd = result.LocationStatus; + + result.LocationStatus = LocationStatusEnum.Free.ObjToInt(); + + BaseDal.UpdateData(result); + + _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(result, beforeStatusEnd, changType, "", TaskNum); + } } } catch (Exception ex) { - throw ex; + throw new Exception(ex.Message); } } - public (Dt_LocationInfo?,int?) isDepth(Dt_LocationInfo locationInfo) + public Dt_LocationInfo isDepth(Dt_LocationInfo locationInfo) { - if (locationInfo.Depth == 2) + try { - if (locationInfo.Row == 1 || locationInfo.Row == 5) + if (locationInfo.Depth == 2) { - Dt_LocationInfo dt_LocationInfo = BaseDal.QueryFirst(x => x.Row == locationInfo.Row + 1 && x.Layer == locationInfo.Layer && x.Column == locationInfo.Column && x.RoadwayNo == locationInfo.RoadwayNo); - - if (dt_LocationInfo != null&& dt_LocationInfo.LocationStatus==LocationStatusEnum.InStock.ObjToInt()) - { - return (dt_LocationInfo, LocationStatusEnum.InStock.ObjToInt()); - } - if (dt_LocationInfo != null && dt_LocationInfo.LocationStatus == LocationStatusEnum.Free.ObjToInt()) - { - return (dt_LocationInfo, LocationStatusEnum.Free.ObjToInt()); - } - if (dt_LocationInfo != null && dt_LocationInfo.LocationStatus == LocationStatusEnum.Lock.ObjToInt()) - { - return (dt_LocationInfo, LocationStatusEnum.Lock.ObjToInt()); - } - if (dt_LocationInfo != null && dt_LocationInfo.LocationStatus == LocationStatusEnum.PalletLock.ObjToInt()) - { - return (dt_LocationInfo, LocationStatusEnum.PalletLock.ObjToInt()); - } - if (dt_LocationInfo != null && dt_LocationInfo.LocationStatus == LocationStatusEnum.Pallet.ObjToInt()) - { - return (dt_LocationInfo, LocationStatusEnum.Pallet.ObjToInt()); - } + return AdjacentDepthLocation(locationInfo.LocationCode); } - else if (locationInfo.Row == 4 || locationInfo.Row == 8) + else { - Dt_LocationInfo dt_LocationInfo = BaseDal.QueryFirst(x => x.Row == locationInfo.Row + 1 && x.Layer == locationInfo.Layer && x.Column == locationInfo.Column && x.RoadwayNo == locationInfo.RoadwayNo); - - if (dt_LocationInfo != null && dt_LocationInfo.LocationStatus == LocationStatusEnum.InStock.ObjToInt()) - { - return (dt_LocationInfo, LocationStatusEnum.InStock.ObjToInt()); - } - if (dt_LocationInfo != null && dt_LocationInfo.LocationStatus == LocationStatusEnum.Free.ObjToInt()) - { - return (dt_LocationInfo, LocationStatusEnum.Free.ObjToInt()); - } - if (dt_LocationInfo != null && dt_LocationInfo.LocationStatus == LocationStatusEnum.Lock.ObjToInt()) - { - return (dt_LocationInfo, LocationStatusEnum.Lock.ObjToInt()); - } - if (dt_LocationInfo != null && dt_LocationInfo.LocationStatus == LocationStatusEnum.PalletLock.ObjToInt()) - { - return (dt_LocationInfo, LocationStatusEnum.PalletLock.ObjToInt()); - } - if (dt_LocationInfo != null && dt_LocationInfo.LocationStatus == LocationStatusEnum.Pallet.ObjToInt()) - { - return (dt_LocationInfo, LocationStatusEnum.Pallet.ObjToInt()); - } + return null; } } - return (null, LocationStatusEnum.Free.ObjToInt()); + catch (Exception ex) + { + throw new Exception(ex.Message); + } } public void RelocationLock(Dt_LocationInfo locationInfo, Dt_LocationInfo locationInfos, int TaskNum) { - int beforeStartStatus = locationInfo.LocationStatus; - int beforeEndStatus = locationInfos.LocationStatus; - - locationInfo.LocationStatus = LocationStatusEnum.Lock.ObjToInt(); - - if (locationInfos.LocationStatus == LocationStatusEnum.Pallet.ObjToInt()) + try { - locationInfos.LocationStatus = LocationStatusEnum.PalletLock.ObjToInt(); + int beforeStartStatus = locationInfo.LocationStatus; + int beforeEndStatus = locationInfos.LocationStatus; + + locationInfo.LocationStatus = LocationStatusEnum.Lock.ObjToInt(); + + if (beforeStartStatus == LocationStatusEnum.Pallet.ObjToInt()) + { + locationInfos.LocationStatus = LocationStatusEnum.PalletLock.ObjToInt(); + locationInfo.LocationStatus = LocationStatusEnum.PalletLock.ObjToInt(); + } + else + { + locationInfos.LocationStatus = LocationStatusEnum.Lock.ObjToInt(); + locationInfo.LocationStatus = LocationStatusEnum.Lock.ObjToInt(); + } + + BaseDal.UpdateData(locationInfo); + BaseDal.UpdateData(locationInfos); + + _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfo, beforeStartStatus, StockChangeType.Relocation.ObjToInt(), "", TaskNum); + _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfos, beforeEndStatus, StockChangeType.Relocation.ObjToInt(), "", TaskNum); } - else + catch (Exception ex) { - locationInfos.LocationStatus = LocationStatusEnum.Lock.ObjToInt(); + throw new Exception(ex.Message); } - - BaseDal.UpdateData(locationInfo); - BaseDal.UpdateData(locationInfos); - - _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfo, beforeStartStatus, StockChangeType.Relocation.ObjToInt(), "", TaskNum); - _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfos, beforeEndStatus, StockChangeType.Relocation.ObjToInt(), "", TaskNum); } public void RelocationFree(Dt_LocationInfo locations, int TaskNum) { - int beforeEndStatus = locations.LocationStatus; - - if(locations.LocationStatus== LocationStatusEnum.Lock.ObjToInt()) + try { - locations.LocationStatus = LocationStatusEnum.InStock.ObjToInt(); + int beforeEndStatus = locations.LocationStatus; + + if (locations.LocationStatus == LocationStatusEnum.Lock.ObjToInt()) + { + locations.LocationStatus = LocationStatusEnum.InStock.ObjToInt(); + } + else + { + locations.LocationStatus = LocationStatusEnum.Pallet.ObjToInt(); + } + + + BaseDal.UpdateData(locations); + + _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locations, beforeEndStatus, StockChangeType.Relocation.ObjToInt(), "", TaskNum); } - else + catch (Exception ex) { - locations.LocationStatus = LocationStatusEnum.Pallet.ObjToInt(); + throw new Exception(ex.Message); } - - - BaseDal.UpdateData(locations); - - _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locations, beforeEndStatus, StockChangeType.Relocation.ObjToInt(), "", TaskNum); } } } -- Gitblit v1.9.3