From b9927bd58cdc940069c7640f3cc04a60dd37ef87 Mon Sep 17 00:00:00 2001
From: lsh <1>
Date: 星期四, 21 三月 2024 10:05:49 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/asrs/utils/Utils.java |  125 +++++++++++++++++++++++++++++++++++++----
 1 files changed, 111 insertions(+), 14 deletions(-)

diff --git a/src/main/java/com/zy/asrs/utils/Utils.java b/src/main/java/com/zy/asrs/utils/Utils.java
index 4342fb5..da37396 100644
--- a/src/main/java/com/zy/asrs/utils/Utils.java
+++ b/src/main/java/com/zy/asrs/utils/Utils.java
@@ -2,12 +2,12 @@
 
 import com.core.common.Arith;
 import com.core.common.Cools;
+import com.core.common.SpringUtils;
+import com.zy.core.model.CrnSlave;
 import com.zy.core.properties.SlaveProperties;
 
 import java.text.DecimalFormat;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.List;
+import java.util.*;
 
 /**
  * Created by vincent on 2020/8/27
@@ -15,6 +15,50 @@
 public class Utils {
 
     private static final DecimalFormat fmt = new DecimalFormat("##0.00");
+
+    public static String getWmsLocNo(String locNo) {
+        String loc = null;
+        int row = Integer.parseInt(locNo.substring(0, 2));
+        int bay = Integer.parseInt(locNo.substring(2, 5))-1;
+        int lev = Integer.parseInt(locNo.substring(5, 7));
+        Integer sssc = getRowZ(row);
+        Integer fz = getFZ(row, sssc);
+        Integer fz1 = getFZ1(row, sssc);
+
+        //System.out.println(sssc + "-" + bay + "-" + lev + "-" + fz + "-" + fz1);
+        loc = String.format("%02d",sssc) + "-" + String.format("%02d",bay) + "-" + String.format("%02d",lev) + "-" + String.format("%02d",fz) + "-" + String.format("%02d",fz1);
+        return loc;
+    }
+
+    public static Integer getRowZ(int row) {
+        return row < 5 ? 1 : (row + 1) / 4 + 1;
+    }
+
+    public static Integer getFZ(int row, int crnNo) {
+        List<Integer> ii = new ArrayList<Integer>();
+        if (crnNo == 1) {
+            ii.add(3);
+            ii.add(0);
+        } else {
+            ii.add(2);
+            if (crnNo > 2) ii.add(1);
+        }
+        return ii.contains(row % 4) ? 2 : 1;
+    }
+
+    public static Integer getFZ1(int row, int crnNo) {
+        if (crnNo == 2) return 1;
+        List<Integer> ii = new ArrayList<Integer>();
+        ii.add(2);
+        ii.add(3);
+        int s = 2;
+        if (ii.contains(row % 4)) {
+            s = 1;
+        }
+        return crnNo == 1 ? s : 3 - s;
+    }
+
+
 
 
     //杞崲wms浼犺緭鐨勫簱浣嶅彿
@@ -25,25 +69,49 @@
         if (split[3].equals("01")){
             ints = Arrays.copyOfRange(wcsRow, 0, (wcsRow.length+2-1) / 2);
             if (split[4].equals("01")){
-                ints = Arrays.copyOfRange(ints, wcsRow.length / 2,wcsRow.length-1);
+                if (ints.length<2){
+
+                }else {
+                    ints = Arrays.copyOfRange(ints, ints.length / 2, ints.length);
+                }
             }else {
-                ints = Arrays.copyOfRange(ints, 0, wcsRow.length / 2);
+                if (ints.length<2){
+
+                }else {
+                    ints = Arrays.copyOfRange(ints, ints.length / 2-1,ints.length-1);
+                }
             }
         }else {
-            ints = Arrays.copyOfRange(wcsRow, (wcsRow.length+2-1) / 2,wcsRow.length-1 );
+            ints = Arrays.copyOfRange(wcsRow, (wcsRow.length+2-1) / 2,wcsRow.length );
             if (split[4].equals("01")){
+                if (ints.length<2){
 
-                ints = Arrays.copyOfRange(ints, 0, wcsRow.length / 2);
+                }else {
+                    ints = Arrays.copyOfRange(ints, ints.length / 2-1,ints.length-1);
+                }
             }else {
-                ints = Arrays.copyOfRange(ints, wcsRow.length / 2,wcsRow.length-1);
+                if (ints.length<2){
+
+                }else {
+                    ints = Arrays.copyOfRange(ints, ints.length / 2, ints.length);
+                }
+
+
             }
         }
         int i = ints[0];
         String wcsLocNo = "";
-        if (i>9){
-            wcsLocNo = i+"0"+split[1]+split[2];
+        Integer bay = Integer.parseInt(split[1])+1;
+        String bay2 = "";
+        if (bay>9){
+            bay2 = bay.toString();
         }else {
-            wcsLocNo = "0"+i+"0"+split[1]+split[2];
+            bay2 = "0"+bay;
+        }
+        if (i>9){
+            wcsLocNo = i+"0"+bay2+split[2];
+        }else {
+            wcsLocNo = "0"+i+"0"+bay2+split[2];
         }
 
 
@@ -154,9 +222,18 @@
      */
     public static String getShallowLoc(SlaveProperties slaveProperties, String deepLoc) {
         int row = getRow(deepLoc);
-        int remainder = (int) Arith.remainder(row, slaveProperties.getGroupCount());
-        int shallowRow = remainder == 1 ? (row + 1) : (row - 1);
+//        int remainder = (int) Arith.remainder(row, slaveProperties.getGroupCount());
+        int shallowRow  = getShallowRow(row);
         return zerofill(String.valueOf(shallowRow), 2) + deepLoc.substring(2);
+    }
+    public static int getShallowRow(Integer row){
+        Map<Integer, Integer> map = new HashMap<>();
+        map.put(1,2);map.put(4,3);
+        map.put(7,8);map.put(10,9);
+        map.put(11,12);map.put(14,13);
+        map.put(15,16);map.put(18,17);
+        map.put(19,20);
+        return map.get(row);
     }
 
     /**
@@ -275,6 +352,26 @@
 
     }
 
+    public static CrnSlave.CrnStn getCrnStnByStaNo(Integer staNo, Boolean pakIn) {
+        SlaveProperties slaveProperties = SpringUtils.getBean(SlaveProperties.class);
+        for (CrnSlave crn : slaveProperties.getCrn()) {
+            List<CrnSlave.CrnStn> crnInStn = null;
+            if (pakIn) {
+                crnInStn = crn.getCrnInStn();
+            }else {
+                crnInStn = crn.getCrnOutStn();
+            }
+
+            for (CrnSlave.CrnStn crnStn : crnInStn) {
+                if (crnStn.getStaNo().equals(staNo)) {
+                    return crnStn;
+                }
+            }
+        }
+
+        return null;
+    }
+
     public static void main(String[] args) {
 //        SlaveProperties slaveProperties = new SlaveProperties();
 //        slaveProperties.setDoubleDeep(true);
@@ -284,7 +381,7 @@
 //        slaveProperties.setGroupCount(4);
 //        Integer deepRow = getDeepRow(slaveProperties, 6);
 //        System.out.println(deepRow);
-        String wcsLocNo = getWcsLocNo("06-52-01-01-01");
+        String wcsLocNo = getWcsLocNo("01-01-01-01-01");
         System.out.println(wcsLocNo);
     }
 }

--
Gitblit v1.9.1