From 30304784e82d4bba24121328da8eb8490aec4f4f Mon Sep 17 00:00:00 2001
From: hjg <hjg@123.com>
Date: 星期二, 09 七月 2024 18:05:21 +0800
Subject: [PATCH] 更改进厂为待装

---
 JavaSource/com/mandi/webservice/service/impl/FdXSTDService.java |  423 ++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 356 insertions(+), 67 deletions(-)

diff --git a/JavaSource/com/mandi/webservice/service/impl/FdXSTDService.java b/JavaSource/com/mandi/webservice/service/impl/FdXSTDService.java
index c12852f..83f1a1f 100644
--- a/JavaSource/com/mandi/webservice/service/impl/FdXSTDService.java
+++ b/JavaSource/com/mandi/webservice/service/impl/FdXSTDService.java
@@ -1,60 +1,37 @@
 package com.mandi.webservice.service.impl;
 
-import java.util.ArrayList;
-import java.util.Date;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-import java.util.UUID;
-import java.util.stream.Collectors;
-
-import javax.annotation.Resource;
-
-import com.mandi.basicconfig.persist.*;
-import com.mandi.fendan.util.ConvertTool;
-import com.mandi.fendan.util.ThreadPoolUtil;
-import com.mandi.servlet.file.impl.FileLoadImpl;
-import javafx.concurrent.Task;
-import org.apache.commons.lang3.StringUtils;
-import org.apache.log4j.Logger;
-import org.springframework.stereotype.Service;
-import org.springframework.transaction.annotation.Transactional;
-
 import com.google.gson.JsonArray;
 import com.google.gson.JsonElement;
 import com.google.gson.JsonObject;
 import com.google.gson.JsonParser;
 import com.mandi.basicconfig.mapper.FdRepertoryNexusMapper;
 import com.mandi.basicconfig.mapper.NczsjMapper;
+import com.mandi.basicconfig.persist.*;
 import com.mandi.common.JSONobj;
-import com.mandi.common.Wxhtmethod;
+import com.mandi.common.Jacksonmethod;
 import com.mandi.common.ParamFileter.BigDecimalfiter;
+import com.mandi.common.SpringContext;
+import com.mandi.common.Wxhtmethod;
 import com.mandi.dao.common.ObjectResult;
 import com.mandi.dao.common.PageResult;
-import com.mandi.fendan.mapper.BsheetEcgbMapper;
-import com.mandi.fendan.mapper.BusinessMapper;
-import com.mandi.fendan.mapper.Fd_BsheetMapper;
-import com.mandi.fendan.mapper.Fd_CompanyMapper;
-import com.mandi.fendan.mapper.Fd_GbxstdMapper;
-import com.mandi.fendan.mapper.Fd_GbxstdmxMapper;
-import com.mandi.fendan.mapper.Fd_VehicleMapper;
-import com.mandi.fendan.mapper.Fd_XSTDMXMapper;
-import com.mandi.fendan.mapper.Fd_XSTDMapper;
-import com.mandi.fendan.mapper.Fd_YKTMapper;
-import com.mandi.fendan.mapper.VehicleXSTDMapper;
-import com.mandi.fendan.persist.BsheetEcgb;
-import com.mandi.fendan.persist.Fd_Bsheet;
-import com.mandi.fendan.persist.Fd_Company;
-import com.mandi.fendan.persist.Fd_Gbxstd;
-import com.mandi.fendan.persist.Fd_Gbxstdmx;
-import com.mandi.fendan.persist.Fd_XSTD;
-import com.mandi.fendan.persist.Fd_XSTDMX;
-import com.mandi.fendan.persist.Vehicle_XSTD;
+import com.mandi.fendan.mapper.*;
+import com.mandi.fendan.persist.*;
 import com.mandi.fendan.util.Contants;
+import com.mandi.fendan.util.ConvertTool;
+import com.mandi.fendan.util.ThreadPoolUtil;
 import com.mandi.fendan.util.persist.Serviceenum;
 import com.mandi.fendan.util.persist.WaitXSTDMX;
 import com.mandi.fendan.util.persist.Yktbsitem;
+import com.mandi.servlet.file.impl.FileLoadImpl;
 import com.mandi.webservice.service.IFdXSTDService;
+import org.apache.commons.lang3.StringUtils;
+import org.apache.log4j.Logger;
+import org.springframework.context.ApplicationContext;
+import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import javax.annotation.Resource;
+import java.util.*;
 
 @Service
 public class FdXSTDService implements IFdXSTDService{
@@ -88,6 +65,9 @@
 
 	private Logger log= Logger.getLogger(FileLoadImpl.class);
 
+	public static Boolean refreshMsLedLock = false;
+	public static Boolean refreshYrLedLock = false;
+	public static Boolean refreshKjLedLock = false;
 	@Override
 	@Transactional(rollbackFor=Exception.class)
 	public ObjectResult<Boolean> saveFd_xstd(String dataArr) throws Exception {
@@ -435,6 +415,7 @@
 			prr.setErrmsg("鍙傛暟锛氬崱鍙峰叧鑱旂殑杞︾墝鍙峰拰涓氬姟鍗曞叧鑱旂殑杞︾墝鍙蜂笉涓�鑷�");
 			return prr;
 		}
+
 		// yktywdh = fdb.getBsNo();
 
 		int wcnum=this.bsper.getweightDoc(vehicleId, fdb.getBsNo());
@@ -456,10 +437,10 @@
 				return prr;
 			}
 		} catch (Exception e) {
-			// TODO: handle exception
 		}
 
-
+		String currPch="";// 褰撳墠鎵规鍙�
+		List<String> pchList = new ArrayList<>();
 		//绗竴娆℃坊鍔犺鍗歌褰曞彂閫佽杞︿俊鎭�
 		int sfzc=this.fbper.getbsitembyNo(fdb.getBsNo());
 		if(sfzc<=0) {
@@ -473,7 +454,25 @@
 		}
 		// 鐜板満杩囧畬姣涢噸鍚庡嚭鐜版壂鐮佽杞︾殑锛屽繀椤婚噸鏂拌繃纾�
 		int grossNum=this.bsper.getgrosstDoc(vehicleId, fdb.getBsNo());
-
+		List tdmxPchList = new ArrayList();
+		for (JsonElement je : dataArr) {
+			JsonObject jo=je.getAsJsonObject();
+			String tdmx_pch = jo.get("tdmx_pch").getAsString();
+			tdmxPchList.add(tdmx_pch);
+		}
+		if("08".equals(fdb.getSdepartNo())) { // 鍙槸涔夌憺鍘傚尯鏈夋晥
+			// 妫�鏌ユ槸鍚﹀綋鍓嶅尯鍩熷凡缁忔帓闃�
+			Map paramMap = new HashMap();
+			paramMap.put("vehicleId", vehicleId);
+			paramMap.put("tdmxPchList", tdmxPchList);
+			String jsonStr = Jacksonmethod.tojson(paramMap, false);
+			JsonObject jsonObject = Wxhtmethod.postJsonStr(Contants.yr_canDoScanUrl, jsonStr);
+			if (jsonObject.get("code").getAsInt() != 0) {
+				prr.setCode(1);
+				prr.setErrmsg(jsonObject.get("errmsg").getAsString());
+				return prr;
+			}
+		}
 		for (JsonElement je : dataArr) {
 			JsonObject jo=je.getAsJsonObject();
 			String tdmx_pch = jo.get("tdmx_pch").getAsString();
@@ -582,6 +581,8 @@
 			remp.put("td_tdls",tdmx.getTdmx_tdls());
 			remp.put("tdmx_tdfl",tdmx.getTdmx_tdfl());
 			relist.add(remp);
+			currPch  = tdmx.getTdmx_pch();
+			pchList.add(tdmx.getTdmx_pch());
 		}
 
 		if(grossNum>0) {
@@ -607,7 +608,84 @@
 
 		 // 姝ゅ寮傛瑙﹀彂涓�涓嬫槑鏅熷彂杞�
 		if("06".equals(fdb.getSdepartNo())) {
-			ThreadPoolUtil.getInstance().execute(()->sendToMsLed());
+			final String pch = currPch;
+			final String finalVehicleId = vehicleId;
+			ThreadPoolUtil.getInstance().execute(()->{
+				Map paramMap = new HashMap();
+				paramMap.put("vehicleId", finalVehicleId);
+				paramMap.put("tdmxPchList", tdmxPchList);
+				String jsonStr = Jacksonmethod.tojson(paramMap, false);
+				JsonObject jsonObject = Wxhtmethod.postJsonStr(Contants.ms_DoScanUrl, jsonStr);
+				if (jsonObject.get("code").getAsInt() != 0) {
+					prr.setCode(1);
+					prr.setErrmsg(jsonObject.get("errmsg").getAsString());
+					// return prr;
+				}
+			});
+			// 寤惰繜1.5绉掓墽琛岋紝淇濊瘉鏁版嵁鎵ц瀹屼簡
+			ThreadPoolUtil.getInstance().execute(()->{
+				synchronized (FdXSTDService.refreshMsLedLock) {
+					if (FdXSTDService.refreshMsLedLock) { // 绯荤粺绻佸繖
+						log.info(finalVehicleId + "" + pch + "绯荤粺绻佸繖锛�");
+						return;
+					}
+				}
+				try {
+					synchronized (FdXSTDService.refreshMsLedLock) {
+						FdXSTDService.refreshMsLedLock = true;
+					}
+					sendToMsLed(pch);
+				} catch (Exception e) {
+					log.error("鍑虹幇寮傚父锛�"+ e.getMessage(),e);
+				} finally {
+					synchronized (FdXSTDService.refreshMsLedLock) {
+						FdXSTDService.refreshMsLedLock = false;
+					}
+				}
+			},1500);
+		}
+		if("08".equals(fdb.getSdepartNo())) {
+			final String cph = currPch;
+			ThreadPoolUtil.getInstance().execute(()->{
+				// 杩欎釜鍦版柟涓嶅啀璇锋眰
+				/*Map scanCodeParamMap = new HashMap();
+				scanCodeParamMap.put("pch",cph);
+				Wxhtmethod.post(Contants.yr_scanCodeNoticeUrl, scanCodeParamMap);*/
+				try {
+					synchronized (FdXSTDService.refreshYrLedLock) {
+						if (FdXSTDService.refreshYrLedLock) { // 绯荤粺绻佸繖
+							return  ;
+						}
+						FdXSTDService.refreshYrLedLock = true;
+					}
+					sendToYrLed(cph);
+				} catch (Exception e) {
+					log.error(e);
+				} finally {
+					synchronized (FdXSTDService.refreshYrLedLock) {
+						FdXSTDService.refreshYrLedLock = false;
+					}
+				}
+			});
+		} else if("04".equals(fdb.getSdepartNo())) { // 绉戞妧
+			final String cph = currPch;
+			ThreadPoolUtil.getInstance().execute(()->{
+				try {
+					synchronized (FdXSTDService.refreshKjLedLock) {
+						if (FdXSTDService.refreshKjLedLock) { // 绯荤粺绻佸繖
+							return  ;
+						}
+						FdXSTDService.refreshKjLedLock = true;
+					}
+					sendToKjLed(cph);
+				} catch (Exception e) {
+					log.error(e);
+				} finally {
+					synchronized (FdXSTDService.refreshKjLedLock) {
+						FdXSTDService.refreshKjLedLock = false;
+					}
+				}
+			});
 		}
 		prr.setCode(0);
 		prr.setErrmsg("瑁呰溅鎿嶄綔鎴愬姛锛�");
@@ -615,72 +693,282 @@
 		return prr;
 	}
 
-	public void sendToMsLed(){ // todo 鏄庡ぉ闇�瑕佹祴璇曚竴涓�
+	/**
+	 *  鎸埌涓�鍗¢��
+	 * @param currPch 褰撳墠鎵规鍙�
+	 */
+	public void sendToMsLed(String currPch){
 		//A鍖�  76-86 +  99-1
 		//B鍖�  14-33 +  99-2
 		//C鍖�  53-67 +  99-3
+		// 2024骞存敼
+		//A鍖�  73-88 +  99-1 +  40-45
+		//B鍖�  14-27 +  99-2 +  46-49
+		//C鍖�  50-65 +  99-3
+		//D鍖�  28-39 +	69-72	+ 89-98
+		log.info("LED-ABC褰撳墠鎵爜鎵规鍙凤細" + currPch);
 		List<Map> totalList =  tdmxper.getHwList("06"); // 鑾峰彇鏄庢櫉鎵�鏈夊湪鍔炰笟鍔″崟鐨勪俊鎭�
+		log.info("LED-ABC鑾峰彇淇℃伅鏉℃暟锛�" + totalList.size());
 		Map<String,List<Map>> ywbhListMap = new HashMap<>();
 		for (Map map : totalList) {
 			String ywdw = (String) map.get("tdmx_fdywbh");
+			if(ywdw == null) {
+				log.info("鍑虹幇涓氬姟鍗曞彿涓簄ull鐨勬儏鍐碉細" + Jacksonmethod.tojson(map,false));
+				continue;
+			}
 			if(ywbhListMap.get(ywdw) == null) {
 				ywbhListMap.put(ywdw, new ArrayList<>());
 			}
 			ywbhListMap.get(ywdw).add(map);
 		}
-		String str1 = "杞﹀彿-A鍖�-B鍖�-C鍖�" + "\r\n", str2="";
+		String str1 = " 杞﹀彿  A鍖�  B鍖�  C鍖�" + "\r\n", str2="";
 		//"(杞︾墝鍙�)\\-(A鍖哄凡瑁呰溅)/(A鍖烘�昏)\\-(B鍖哄凡瑁呰溅)/(B鍖烘�昏)\\-(C鍖哄凡瑁呰溅)/(C鍖烘�昏)\\r\\n";
-		String formatStr = "%s-%d/%d- %d/%d-%d/%d\r\n";
-		for (Map.Entry<String, List<Map>> entry : ywbhListMap.entrySet()) { // 閬嶅巻姣忎釜涓氬姟鍗曠殑
+		String formatStr = "%s %s/%s %s/%s %s/%s\r\n";
+		// 鍙湁1涓尯
+
+		Map speakParam = new HashMap(1);
+		for (Map.Entry<String, List<Map>> entry : ywbhListMap.entrySet()) {
+			// 閬嶅巻姣忎釜涓氬姟鍗曠殑
+			// 褰撳墠瑁呰溅A銆丅銆丆鍖�; D鍖哄彧鍙備笌璁板綍锛屼笉鍙備笌LED鏄剧ず鍜岃瑷�鎾姤
+			boolean currA = false,currB = false, currC = false, currD = false;
 			boolean hasZcwc = false; // 淇濊瘉宸茬粡瀹屾垚浜�
 			String ywhb = entry.getKey();
 			List<Map> vehicleIdTotalList = entry.getValue();
-			Map<String, Integer> totalAbcMap = new HashMap(3); // 鎬昏淇℃伅
+			// 鎬昏淇℃伅
+			Map<String, Integer> totalAbcMap = new HashMap(3);
 			totalAbcMap.put("A", 0);
 			totalAbcMap.put("B", 0);
 			totalAbcMap.put("C", 0);
-			Map<String, Integer> abcMap = new HashMap(3); // 宸茶淇℃伅
+			/* 宸茶淇℃伅 */
+			Map<String, Integer> abcMap = new HashMap(3);
 			abcMap.put("A", 0);
 			abcMap.put("B", 0);
 			abcMap.put("C", 0);
 			String cph = ""; // 杞︾墝鍙�
 			for (Map map : vehicleIdTotalList) {
 				String hw = (String) map.get("tdmx_hwmc");
-				if(!"".equals(cph))  cph = (String) map.get("tdmx_zccph");
+				String pch = (String) map.get("tdmx_pch");
+				if(StringUtils.isBlank(cph))  cph = (String) map.get("tdmx_fdcph");
 				Integer zcbz = (Integer) map.get("tdmx_zcbz");
 				String hh = hw.replaceAll("\\-.*","");
 				hh = hh.substring(hh.length()-2); // 鍙栨渶鍚庝袱浣�
 				int num = Integer.parseInt(hh);
-				if (num >= 76 && num <= 86 || hw.lastIndexOf("99-1") >= 0) { // A鍖�
-					totalAbcMap.put("A", 1);
+				if (num >= 73 && num <= 88 || hw.lastIndexOf("99-1") >= 0) { // A鍖�
+					totalAbcMap.put("A",totalAbcMap.get("A") + 1);
 					if (zcbz != null && zcbz == 1) { // 瑁呰溅瀹屾垚
 						abcMap.put("A", abcMap.get("A") + 1);
 						hasZcwc = true;
 					}
-				} else if (num >= 14 && num <= 33 || hw.lastIndexOf("99-2") >= 0) { // B鍖�
-					totalAbcMap.put("B", 1);
+					if(pch.equals(currPch)) {
+						currA = true; currB = false;currC =false;currD=false;
+					}
+				} else if (num >= 14 && num <= 27 || hw.lastIndexOf("99-2") >= 0) { // B鍖�
+					totalAbcMap.put("B", totalAbcMap.get("B") + 1);
 					if (zcbz != null && zcbz == 1) {
 						abcMap.put("B", abcMap.get("B") + 1);
 						hasZcwc = true;
 					}
-				} else if (num >= 53 && num <= 67 || hw.lastIndexOf("99-3") >= 0) { // C鍖�
-					totalAbcMap.put("C", 1);
+					if(pch.equals(currPch)) {
+						currA = false; currB = true;currC =false;currD=false;
+					}
+				} else if (num >= 50 && num <= 65 || hw.lastIndexOf("99-3") >= 0) { // C鍖�
+					totalAbcMap.put("C", totalAbcMap.get("C") + 1);
 					if (zcbz != null && zcbz == 1) {
 						abcMap.put("C", abcMap.get("C") + 1);
 						hasZcwc = true;
 					}
+					if(pch.equals(currPch)) {
+						currA = false; currB = false; currC =true; currD=false;
+					}
+				} else if(num>=28 && num<=39 ||	(num>=69 && num<=72) || (num>=89 && num<=98)) {
+					if(pch.equals(currPch)) {
+						currA = false; currB = false;currC =false;currD=true;
+					}
 				}
 			}
-			if (!hasZcwc) continue;
-			str2 += String.format(formatStr, cph, abcMap.get("A"), totalAbcMap.get("A"),
-					abcMap.get("B"), totalAbcMap.get("B"),
-					abcMap.get("C"), totalAbcMap.get("C"));
+			// if (!hasZcwc) continue; //娌℃湁瑁呰溅瀹屾垚鐨勪篃璺宠繃
+			/*if (!(currA || currB || currC) && abcMap.get("A") + abcMap.get("B") + abcMap.get("C") ==
+					totalAbcMap.get("A") + totalAbcMap.get("B") + totalAbcMap.get("C")) { // 闈炲綋鍓嶈溅鐗屽彿锛屽凡缁忚杞﹀畬鎴愪絾鏄湭鍑哄巶
+				continue;
+			}*/
+			if(totalAbcMap.get("B")==0 && totalAbcMap.get("C")==0 && totalAbcMap.get("A")==0) {
+				continue;
+			}
+			str2 += String.format(formatStr, cph, fillWithZero(abcMap.get("A")), fillWithZero(totalAbcMap.get("A")),
+					fillWithZero(abcMap.get("B")), fillWithZero(totalAbcMap.get("B")),
+					fillWithZero(abcMap.get("C")), fillWithZero(totalAbcMap.get("C")));
+			log.info(ywhb +  "鎶曞睆鍑嗗瀹屾垚锛屽紑濮嬪噯澶囪闊炽��");
+			// 寮�濮嬪噯澶囪闊�
+			int total = 0;
+			if(currA && abcMap.get("A") == totalAbcMap.get("A") && totalAbcMap.get("A")>0) { // 褰撳墠杞﹀湪A鍖鸿杞﹀畬鎴�
+				total = totalAbcMap.get("A");
+			}
+			if(currB && abcMap.get("B") == totalAbcMap.get("B") && totalAbcMap.get("B")>0) {// 褰撳墠杞﹀湪B鍖鸿杞﹀畬鎴�
+				total = totalAbcMap.get("B");
+			}
+			if(currC && abcMap.get("C") == totalAbcMap.get("C") && totalAbcMap.get("C")>0) {// 褰撳墠杞﹀湪C鍖鸿杞﹀畬鎴�
+				total = totalAbcMap.get("C");
+			}
+			try {
+				String speakTxt = startToSpeak(cph,total,abcMap,totalAbcMap);
+				if(StringUtils.isNotBlank(speakTxt)) {
+					log.info("SpeakTxt:"+ speakTxt);
+					speakParam.put("SpeakTxt", speakTxt);
+				}
+			}catch (Exception e){
+				log.error("鍑嗗璇煶鍑洪敊锛�" + e.getMessage(),e);
+			}
+
+			// 鍑嗗璇煶缁撴潫
 			// 鍗曡締杞︾殑鍗曚釜涓氬姟鍗曠殑淇℃伅缁撴潫
 		}
+		if(StringUtils.isBlank(str2)) {
+			str2 = "鏃犺溅杈�";
+		}
 		Map paramMap = new HashMap();
-		paramMap.put("str1",str1);
-		paramMap.put("str2",str2);
-		Wxhtmethod.post("192.168.112.21/api/xxx",paramMap);
+		paramMap.put("strTitle",str1);
+		paramMap.put("strContent",str2);
+		try {
+			log.info("LED-ABC webServiceAddrss:"+Contants.msLedServiceAddr+"st1::" +str1+";;;;;str2::"+str2);
+		    String re = Wxhtmethod.post(Contants.msLedServiceAddr + "/SendLED",paramMap);
+			log.info("LED-ABC result:"+re);
+			// 璇煶鍙挱涓�鏉�
+		    String re1 = Wxhtmethod.post(Contants.msLedServiceAddr + "/Speak",speakParam);
+		}catch (Exception e){}
+
+
+	}
+
+	/**
+	 * 鍑嗗璇煶 锛屾尓鍒颁竴鍗¢��
+	 * @param cph 杞︾墝鍙�
+	 * @param total 褰撳墠鍖烘�绘暟
+	 * @param abcMap A銆丅銆丆涓簁ey鐨勫尯宸茶鏁扮洰
+	 * @param totalAbcMap A銆丅銆丆涓簁ey鐨勫尯鎬绘暟
+	 * @return
+	 */
+	String startToSpeak(String cph, int total,Map<String,Integer> abcMap,Map<String,Integer> totalAbcMap) {
+		String speakTxt=null ;
+		if(total > 0) { // 鎾斁璇煶锛岃绂诲紑鍖哄煙
+			String speakTxtFormatStr1 = "杞﹀彿%s 锛岃璐�%d浠跺凡瀹屾垚锛岃鍙告満娓呯偣璐х墿鍚庡敖蹇┒绂昏璐у尯銆�";
+			// 鍙湁2涓尯
+			String speakTxtFormatStr2 = "杞﹀彿%s锛�%s鍖鸿璐�%d浠跺凡鍏ㄩ儴鎵弿瀹屾垚锛岃鍙告満娓呯偣璐х墿鍚庡幓%s鍖鸿璐с��";
+			// 鍙湁3涓尯
+			String speakTxtFormatStr3 = "杞﹀彿%s锛�%s鍖鸿璐�%d浠跺凡鍏ㄩ儴鎵弿瀹屾垚锛岃鍙告満娓呯偣璐х墿鍚庡幓%s鍖�%s鍖鸿璐с��";
+
+			if( (abcMap.get("A")>0  && totalAbcMap.get("B")==0 && totalAbcMap.get("C")==0) ||
+					(abcMap.get("B")>0  && totalAbcMap.get("A")==0 && totalAbcMap.get("C")==0)  ||
+					(abcMap.get("C")>0  && totalAbcMap.get("B")==0 && totalAbcMap.get("D")==0)
+			) { // 鍙湁涓�涓尯鍩熸湁璐х墿
+				speakTxt= String.format(speakTxtFormatStr1, cph, total);
+			}else  if(totalAbcMap.get("A")>0 && totalAbcMap.get("B")>0 &&
+					(totalAbcMap.get("C")==0 || totalAbcMap.get("C") == abcMap.get("C"))){ // AB閮芥湁璐� C鍖哄凡瀹屾垨鏃犺揣
+				if(totalAbcMap.get("C")>0 && abcMap.get("A")< totalAbcMap.get("A") && abcMap.get("B")< totalAbcMap.get("B")) { // C瑁呭畬AB鏈瀹�
+					speakTxt= String.format(speakTxtFormatStr3, cph,"C", total,"A","B");
+				} else if(abcMap.get("A")== totalAbcMap.get("A") && abcMap.get("B")< totalAbcMap.get("B")) { //A瀹孊鏈畬
+					speakTxt = String.format(speakTxtFormatStr2, cph, "A", total, "B");
+				}else if(abcMap.get("B")== totalAbcMap.get("B") && abcMap.get("A")< totalAbcMap.get("A")) {//B瀹孉鏈畬
+					speakTxt = String.format(speakTxtFormatStr2, cph, "B", total, "A");
+				}else { // 鍏ㄩ儴瑁呭畬
+					speakTxt= String.format(speakTxtFormatStr1, cph, total);
+				}
+			}else if(totalAbcMap.get("C")>0 && totalAbcMap.get("B")>0 &&
+					(totalAbcMap.get("A")==0 || totalAbcMap.get("A") == abcMap.get("A")) ){ //BC鏈夎揣 A鍖哄凡瀹屾垨鏃犺揣
+				if(totalAbcMap.get("A")>0 && abcMap.get("C")< totalAbcMap.get("C") && abcMap.get("B")< totalAbcMap.get("B")) {  // A瑁呭畬BC鏈瀹�
+					speakTxt= String.format(speakTxtFormatStr3, cph,"A", total,"B","C");
+				} else if(abcMap.get("C")== totalAbcMap.get("C") && abcMap.get("B")< totalAbcMap.get("B")) { // C瀹孊鏈瀹�
+					speakTxt = String.format(speakTxtFormatStr2, cph, "C", total, "B");
+				}else if(abcMap.get("B")== totalAbcMap.get("B") && abcMap.get("C")< totalAbcMap.get("C")) {// B瀹孋鏈瀹�
+					speakTxt = String.format(speakTxtFormatStr2, cph, "B", total, "C");
+				}else { // 鍏ㄩ儴瑁呭畬
+					speakTxt= String.format(speakTxtFormatStr1, cph, total);
+				}
+			}else  if (totalAbcMap.get("A")>0 && totalAbcMap.get("C")>0 &&
+					(totalAbcMap.get("B")==0 || totalAbcMap.get("B") == abcMap.get("B")) ) { //AC鏈夎揣
+				if(totalAbcMap.get("B")>0 && abcMap.get("A")< totalAbcMap.get("A") && abcMap.get("C")< totalAbcMap.get("C")) {
+					speakTxt= String.format(speakTxtFormatStr3, cph,"B", total,"A","C");
+				} else if(abcMap.get("A")== totalAbcMap.get("A") && abcMap.get("C")< totalAbcMap.get("C")) { // A瑁呭畬C鏈瀹�
+					speakTxt = String.format(speakTxtFormatStr2, cph, "A", total, "C");
+				}else if(abcMap.get("C")== totalAbcMap.get("C") && abcMap.get("A")< totalAbcMap.get("A")) {// C瑁呭畬A鏈瀹�
+					speakTxt = String.format(speakTxtFormatStr2, cph, "C", total, "A");
+				}else { // 鍏ㄩ儴瑁呭畬
+					speakTxt= String.format(speakTxtFormatStr1, cph, total);
+				}
+			}else if(totalAbcMap.get("A")>0 && totalAbcMap.get("B")>0 && totalAbcMap.get("C")>0) { // 3鍖洪兘鏈夎揣鐗╋紝涓斿彧鏈変竴涓彇瑁呭畬浜�
+				if(abcMap.get("A")>0 && abcMap.get("B")<totalAbcMap.get("B") && abcMap.get("C")<totalAbcMap.get("C")) {
+					speakTxt= String.format(speakTxtFormatStr3, cph,"A", total,"B","C");
+				} else if(abcMap.get("B")>0 && abcMap.get("C")==0 && abcMap.get("A")==0) {
+					speakTxt= String.format(speakTxtFormatStr3, cph,"B", total,"A","C");
+				} else if(abcMap.get("C")>0 && abcMap.get("A")==0 && abcMap.get("B")==0) {
+					speakTxt= String.format(speakTxtFormatStr3, cph,"C", total,"A","B");
+				} else { // 鍏ㄩ儴瑁呭畬
+					speakTxt= String.format(speakTxtFormatStr1, cph, total);
+				}
+			} else {
+				speakTxt= String.format(speakTxtFormatStr1, cph, total);
+			}
+		}
+		return speakTxt;
+	}
+
+	@Override
+	public void sendToYrLed(String currPch) {
+			// 鐘舵�� 涓�纾呭悗锛屽緟瑁咃紱PDA鎵爜 鍦ㄨ锛� 浜屾杩囩鍚庢秷澶�
+			// 瑁呰溅鍖� 涓や釜姹夊瓧鍔犱袱涓嫳鏂囨垨鏁板瓧
+			String strTitle="搴忓彿  杞﹀彿   瑁呰溅鍖�  鐘舵�乗r\n";
+			String strContent = "";
+			String contentFormatStr = "%s   %s  %s   %s\r\n";
+			List<Map> list = tdmxper.kjZcList("08");
+			int index = 1;
+			for (Map map : list) {
+				String numberplates = (String) map.get("numberplates"); // 杞︾墝鍙�
+				String zcWz = (String) map.get("zcWz"); // 瑁呰溅浣嶇疆
+				if(StringUtils.isNotBlank(zcWz)){
+					zcWz = zcWz.substring(0,4);
+				} else { // 绌烘槸6涓綅缃�
+					zcWz = "      ";
+				}
+				String zcStatus = (String) map.get("zcStatus"); // 瑁呰溅浣嶇疆 鍦ㄥ姙/寰呭姙
+				strContent += String.format(contentFormatStr, fillWithZero(index++), numberplates, zcWz, zcStatus);
+			}
+			Map paramMap = new HashMap();
+			paramMap.put("strTitle",strTitle);
+			paramMap.put("strContent",strContent);
+			Wxhtmethod.post(Contants.yr_zcLedUrl + "/SendLED",paramMap);
+			log.info("yr_zcLedUrl: " + Contants.yr_zcLedUrl + ";title:" + strTitle + ",content:" + strContent);
+	}
+	@Override
+	public void sendToKjLed(String currPch) {
+		// 鐘舵�� 涓�纾呭悗锛屽緟瑁咃紱PDA鎵爜 鍦ㄨ锛� 浜屾杩囩鍚庢秷澶�
+		// 瑁呰溅鍖� 涓や釜姹夊瓧鍔犱袱涓嫳鏂囨垨鏁板瓧
+		String strTitle="搴忓彿  杞﹀彿   瑁呰溅鍖�  鐘舵�乗r\n";
+		String strContent = "";
+		String contentFormatStr = "%s   %s  %s   %s\r\n";
+		List<Map> list = tdmxper.kjZcList("04");
+		int index = 1;
+		for (Map map : list) {
+			String numberplates = (String) map.get("numberplates"); // 杞︾墝鍙�
+			String zcWz = (String) map.get("zcWz"); // 瑁呰溅浣嶇疆
+			if(StringUtils.isNotBlank(zcWz)) {
+				zcWz = zcWz.substring(0,4);
+			} else { // 绌烘槸6涓綅缃�
+				zcWz = "      ";
+			}
+			String zcStatus = (String) map.get("zcStatus"); // 瑁呰溅浣嶇疆 鍦ㄥ姙/寰呭姙
+			strContent += String.format(contentFormatStr, fillWithZero(index++), numberplates, zcWz, zcStatus);
+		}
+		Map paramMap = new HashMap();
+		paramMap.put("strTitle",strTitle);
+		paramMap.put("strContent",strContent);
+		String re = Wxhtmethod.post(Contants.kj_zcLedUrl + "/SendLED",paramMap);
+		log.info("鍥炲锛�" + re +";kj_zcLedUrl: " + Contants.kj_zcLedUrl + ";title:" + strTitle + ",content:" + strContent);
+	}
+
+	String fillWithZero(int str){
+		String s;
+		if(str<10 && str>=0) s= "0" + str;
+		else s=String.valueOf(str);
+		return s;
 	}
 
 	@Override
@@ -733,7 +1021,6 @@
 				return orr;
 			}
 		} catch (Exception e) {
-			// TODO: handle exception
 		}
 //		Fd_Bsheet nr=this.fbper.getbyVehicleId(vehicleId, Serviceenum.鍦ㄥ姙);
 //		if(nr==null){
@@ -794,7 +1081,7 @@
 	}
 
 	@Override
-	public ObjectResult<Map<String, Object>> getcInfo(String cardID) {
+	public ObjectResult<Map<String, Object>> getcInfo(String cardID,boolean needRecord) {
 		ObjectResult<Map<String, Object>> orr=new ObjectResult<Map<String,Object>>();
 		Map<String, Object> rem=new HashMap<String, Object>();
 		Map<String, Object> mp=this.yktper.getcardinuse(cardID);
@@ -910,7 +1197,9 @@
 			}else {
 				mr.put("firstzxhtime", new Date());
 			}
-			this.bsper.updateTaskTime(mr);
+			if(needRecord) { // 涓簍rue 鍒欐洿鏂扮涓�娆℃壂鍗℃椂闂达紝鍚﹀垯涓嶈褰�
+				this.bsper.updateTaskTime(mr);
+			}
 		}else {
 			orr.setCode(1);
 			orr.setErrmsg("鏈壘鍒拌杞﹁褰�");

--
Gitblit v1.9.3