From d6969a2d987d798aadd7be32c53492704c6c1d26 Mon Sep 17 00:00:00 2001
From: 野心家 <1051256694@qq.com>
Date: 星期二, 27 五月 2025 12:44:54 +0800
Subject: [PATCH] #ZH
---
src/main/java/com/zy/asrs/utils/Utils.java | 169 +++++++++++++++++++++++++++++++++++++++++++++++++++-----
1 files changed, 154 insertions(+), 15 deletions(-)
diff --git a/src/main/java/com/zy/asrs/utils/Utils.java b/src/main/java/com/zy/asrs/utils/Utils.java
index 367f9ca..eda8910 100644
--- a/src/main/java/com/zy/asrs/utils/Utils.java
+++ b/src/main/java/com/zy/asrs/utils/Utils.java
@@ -2,12 +2,13 @@
import com.core.common.Arith;
import com.core.common.Cools;
+import com.core.common.SpringUtils;
+import com.zy.asrs.entity.LocMast;
+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
@@ -16,6 +17,50 @@
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浼犺緭鐨勫簱浣嶅彿
public static String getWcsLocNo(String locNo){
@@ -23,27 +68,51 @@
int[] wcsRow = getWcsRow(split[0]);
int[] ints = null;
if (split[3].equals("01")){
- ints = Arrays.copyOfRange(wcsRow, 0, wcsRow.length / 2);
+ 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,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 +223,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 +353,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 +382,48 @@
// slaveProperties.setGroupCount(4);
// Integer deepRow = getDeepRow(slaveProperties, 6);
// System.out.println(deepRow);
- String wcsLocNo = getWcsLocNo("03-52-01-01-02");
+ String wcsLocNo = getWcsLocNo("01-01-01-01-01");
System.out.println(wcsLocNo);
}
+
+ public static Integer StaNoCrnNo(Integer staNo) {
+ switch (staNo){
+ case 100:
+ case 101:
+ return 1;
+ case 102:
+ case 103:
+ return 2;
+ case 104:
+ case 105:
+ return 3;
+ case 106:
+ case 107:
+ return 4;
+ default:
+ return 0;
+ }
+ }
+
+ public static boolean locNoRowBoolean(Integer row) {
+ switch (row){
+ case 1:
+ case 2:
+ case 4:
+ case 5:
+ case 8:
+ case 9:
+ case 11:
+ case 12:
+ return true;
+ case 3:
+ case 6:
+ case 7:
+ case 10:
+ case 13:
+ default:
+ return false;
+ }
+ }
+
}
--
Gitblit v1.9.1