From 4d2b6fea8d08c95bd6bb2b8c2b1228383110457e Mon Sep 17 00:00:00 2001
From: yanjinhui <3306209981@qq.com>
Date: 星期四, 09 四月 2026 12:48:46 +0800
Subject: [PATCH] 1

---
 代码管理/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/HKTaskMethods.cs |   82 +++++++++++++++++++++++++++++++----------
 1 files changed, 62 insertions(+), 20 deletions(-)

diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/HKTaskMethods.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/HKTaskMethods.cs"
index b87085b..bc292cc 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/HKTaskMethods.cs"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/HKTaskMethods.cs"
@@ -14,6 +14,7 @@
 using WIDESEAWCS_DTO.AGV.HIKROBOT;
 using System.Diagnostics.CodeAnalysis;
 using System.Reflection.PortableExecutable;
+using WIDESEAWCS_QuartzJob;
 
 namespace WIDESEAWCS_TaskInfoService
 {
@@ -43,6 +44,23 @@
                 //鑾峰彇璐т綅淇℃伅
                 else
                     hKLocationInfo = _hKLocationInfoService.GetFreeLocationInfo(taskDTO.toAreaCode) ?? throw new Exception($"鏈壘鍒扮粓鐐瑰簱鍖恒�恵taskDTO.toAreaCode}銆戝彲鐢ㄧ┖璐т綅锛�");
+                if (taskType==(int)TaskTypeEnum.Q1TSJ4)
+                {
+                    var device = Storage.Devices.FirstOrDefault(x => x.DeviceCode == "TSJ") as OtherDevice;
+                    if (device.IsConnected)
+                    {
+                        var reslu = device.GetValue<HoistEnum, string>(HoistEnum.Emptycontainernumber);
+                        var result = reslu?.TrimEnd('\0')?.Substring(2);
+                        if (reslu== taskDTO.containerCode&&result!=null)
+                        {
+                            throw new Exception($"褰撳墠鐨勬枡绠卞彿涓簕reslu}涓巤taskDTO.containerCode}鏂欑鍙蜂笉鍖归厤");
+                        }
+                    }
+                    else
+                    {
+                        throw new Exception("鎻愬崌鏈轰俊鎭澶囪繛鎺ュけ璐�");
+                    }
+                }
                 Dt_Task dt_Task = new Dt_Task()
                 {
                     TaskNum = GetTaskNum(nameof(SequenceEnum.SeqTaskNum)),
@@ -111,6 +129,8 @@
                 Dt_HKLocationInfo? hKLocationInfo = _hKLocationInfoService.Repository.QueryFirst(x => x.LocationCode == taskDTO.fromLocationCode) ?? throw new Exception($"鏈壘鍒拌捣鐐瑰簱浣嶃�恵taskDTO.fromLocationCode}銆戯紒");
                 if (hKLocationInfo.LocationStatus != LocationStatusEnum.InStock.ObjToInt()) throw new Exception($"璧风偣搴撲綅銆恵taskDTO.fromLocationCode}銆戝綋鍓嶅簱浣嶇姸鎬佷笉鍙嚭搴擄紒");
                 if (hKLocationInfo.PalletCode != taskDTO.containerCode) throw new Exception($"璧风偣搴撲綅銆恵taskDTO.fromLocationCode}銆戠粦瀹氭枡绠卞彿銆恵hKLocationInfo.PalletCode}銆戜笌浠诲姟鏂欑鍙枫�恵taskDTO.containerCode}銆戜笉鍖归厤锛�");
+                //搴撳唴鍒板簱澶栫殑鐐瑰埌鐐逛换鍔★紝鏄惁闇�瑕佸垽鏂揣浣嶇姸鎬侊紵
+
                 Dt_Task dt_Task = new Dt_Task()
                 {
                     TaskNum = GetTaskNum(nameof(SequenceEnum.SeqTaskNum)),
@@ -181,7 +201,7 @@
                 // 鍒涘缓Headers瀛楀吀
                 var headers = new Dictionary<string, string>
                 {
-                    { "X-lr-request-id", DateTimeOffset.Now.ToUnixTimeSeconds().ToString() }
+                    { "X-lr-request-id", DateTimeOffset.Now.ToUnixTimeSeconds().ToString()+task.TaskNum }
                     // 濡傛灉闇�瑕佸叾浠朒eader锛屽彲浠ョ户缁坊鍔�
                     // { "Content-Type", "application/json" }
                 };
@@ -221,18 +241,22 @@
             HIKROBOTTaskSubmit hIKROBOTTaskSubmit = new HIKROBOTTaskSubmit();
             try
             {
-                var tasktype = (TaskTypeEnum)Enum.GetValues(typeof(TaskTypeEnum)).GetValue(task.TaskType-1);
+                var tasktype = (TaskTypeEnum)Enum.GetValues(typeof(TaskTypeEnum)).GetValue(task.TaskType - 1);
 
                 hIKROBOTTaskSubmit.initPriority = task.Grade;
                 hIKROBOTTaskSubmit.robotTaskCode = task.WMSTaskNum;
                 hIKROBOTTaskSubmit.taskType = tasktype.ToString(); ExtraDto extraDto = new ExtraDto();
-                CarrierInfoDto carrierInfoDto = new CarrierInfoDto()
+                if (task.TaskType != (int)TaskTypeEnum.MOVE &&task.TaskType != (int)TaskTypeEnum.Q3RK && task.TaskType != (int)TaskTypeEnum.Q3CK &&
+                    task.TaskType != (int)TaskTypeEnum.F01)
                 {
-                    carrierCode = task.PalletCode,
-                    carrierType = task.PalletCode.Contains("LXM") ? "DX" : "SX"
-                };
-                extraDto.carrierInfo.Add(carrierInfoDto);
-                hIKROBOTTaskSubmit.extra = extraDto;
+                    CarrierInfoDto carrierInfoDto = new CarrierInfoDto()
+                    {
+                        carrierCode = task.PalletCode,
+                        carrierType = task.PalletCode.Contains("LXM") ? "DX" : "SX"
+                    };
+                    extraDto.carrierInfo.Add(carrierInfoDto);
+                    hIKROBOTTaskSubmit.extra = extraDto;
+                }
                 switch (tasktype)
                 {
                     case TaskTypeEnum.CPInbound:
@@ -240,11 +264,11 @@
                     case TaskTypeEnum.MLInbound:
                     case TaskTypeEnum.MLOutbound:
                         break;
-                    case TaskTypeEnum.F01:
-                        break;
                     case TaskTypeEnum.RK3F:
                     case TaskTypeEnum.CK3F:
                     case TaskTypeEnum.F02:
+                    case TaskTypeEnum.F03:
+                    case TaskTypeEnum.F04:
                         {
                             TargetRouteDto target = new TargetRouteDto()
                             {
@@ -264,6 +288,7 @@
                             hIKROBOTTaskSubmit.targetRoute.Add(targetRoute);
                         }
                         break;
+                    case TaskTypeEnum.STURR:
                     case TaskTypeEnum.Q1TSJ4:
                         {
                             TargetRouteDto target = new TargetRouteDto()
@@ -306,10 +331,27 @@
                         }
                         break;
                     case TaskTypeEnum.Q3RK:
-                        break;
                     case TaskTypeEnum.Q3CK:
-                        break;
-                    case TaskTypeEnum.Move:
+                    case TaskTypeEnum.MOVE:
+                    case TaskTypeEnum.F01:
+                        {
+                            TargetRouteDto target = new TargetRouteDto()
+                            {
+                                code = task.CurrentAddress,
+                                operation = "DELIVERY",//鍙栬揣
+                                seq = 0,
+                                type = "SITE",
+                            };
+                            TargetRouteDto targetRoute = new TargetRouteDto()
+                            {
+                                code = task.NextAddress,
+                                operation = "DELIVERY",//閫佽揣
+                                seq = 1,
+                                type = "SITE",
+                            };
+                            hIKROBOTTaskSubmit.targetRoute.Add(target);
+                            hIKROBOTTaskSubmit.targetRoute.Add(targetRoute);
+                        }
                         break;
                     case TaskTypeEnum.CPMoveInventory:
                         break;
@@ -330,11 +372,11 @@
         /// </summary>
         /// <param name="TaskCode">浠诲姟鍙�</param>
         /// <returns></returns>
-        public WebResponseContent Hikvisiontaskscontinue(string TaskCode,string Address=null)
+        public WebResponseContent Hikvisiontaskscontinue(string TaskCode, string Address = null)
         {
             WebResponseContent content = new WebResponseContent();
             HIKROBOTReturn hIKROBOTReturn = null;
-            HIKROBOTTaskContinue hIKROBOTTaskContinue =null;
+            HIKROBOTTaskContinue hIKROBOTTaskContinue = null;
             try
             {
                 // 1. 鍙傛暟楠岃瘉
@@ -346,8 +388,8 @@
                 hIKROBOTTaskContinue = new HIKROBOTTaskContinue()
                 {
                     triggerCode = TaskCode,
-                    triggerType="TASK",//鍥哄畾鍊�
-                    targetRoute=string.IsNullOrEmpty(Address)?null:
+                    triggerType = "TASK",//鍥哄畾鍊�
+                    targetRoute = string.IsNullOrEmpty(Address) ? null :
                     new TargetRouteDto()
                     {
                         code = Address,
@@ -356,11 +398,11 @@
                 };
                 var headers = new Dictionary<string, string>
                 {
-                    { "X-lr-request-id", DateTimeOffset.Now.ToUnixTimeSeconds().ToString() }
+                    { "X-lr-request-id", DateTimeOffset.Now.ToUnixTimeSeconds().ToString()+TaskCode }
                 };
-                string response = HttpHelper.Post(apiInfo.ApiAddress, hIKROBOTTaskContinue.Serialize(),headers: headers);
+                string response = HttpHelper.Post(apiInfo.ApiAddress, hIKROBOTTaskContinue.Serialize(), headers: headers);
                 hIKROBOTReturn = response.DeserializeObject<HIKROBOTReturn>();
-              
+
                 if (hIKROBOTReturn.code == "SUCCESS")
                 {
                     var data = hIKROBOTReturn.data.ToString().DeserializeObject<HIKROBOTReturnData>();

--
Gitblit v1.9.3