|  |  |  | 
|---|
|  |  |  | import com.core.exception.CoolException; | 
|---|
|  |  |  | import com.fasterxml.jackson.databind.ObjectMapper; | 
|---|
|  |  |  | import com.zy.asrs.entity.BasShuttle; | 
|---|
|  |  |  | import com.zy.asrs.entity.DeviceConfig; | 
|---|
|  |  |  | import com.zy.asrs.entity.DeviceDataLog; | 
|---|
|  |  |  | import com.zy.asrs.entity.LocMast; | 
|---|
|  |  |  | import com.zy.asrs.service.BasShuttleService; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.zy.common.utils.NavigatePositionConvert; | 
|---|
|  |  |  | import com.zy.common.utils.RedisUtil; | 
|---|
|  |  |  | import com.zy.core.News; | 
|---|
|  |  |  | import com.zy.core.model.DeviceCommandMsgModel; | 
|---|
|  |  |  | import com.zy.core.utils.DeviceMsgUtils; | 
|---|
|  |  |  | import com.zy.core.action.ShuttleAction; | 
|---|
|  |  |  | import com.zy.core.cache.OutputQueue; | 
|---|
|  |  |  | import com.zy.core.enums.*; | 
|---|
|  |  |  | import com.zy.core.model.CommandResponse; | 
|---|
|  |  |  | import com.zy.core.model.ShuttleSlave; | 
|---|
|  |  |  | import com.zy.core.model.DeviceMsgModel; | 
|---|
|  |  |  | import com.zy.core.model.command.NyShuttleHttpCommand; | 
|---|
|  |  |  | import com.zy.core.model.command.ShuttleCommand; | 
|---|
|  |  |  | import com.zy.core.model.command.ShuttleRedisCommand; | 
|---|
|  |  |  | 
|---|
|  |  |  | import lombok.Data; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.io.BufferedReader; | 
|---|
|  |  |  | import java.io.IOException; | 
|---|
|  |  |  | import java.io.InputStreamReader; | 
|---|
|  |  |  | import java.io.OutputStreamWriter; | 
|---|
|  |  |  | import java.net.Socket; | 
|---|
|  |  |  | import java.text.MessageFormat; | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | @SuppressWarnings("all") | 
|---|
|  |  |  | public class NyShuttleThread implements ShuttleThread { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private ShuttleSlave slave; | 
|---|
|  |  |  | private DeviceConfig deviceConfig; | 
|---|
|  |  |  | private RedisUtil redisUtil; | 
|---|
|  |  |  | private ShuttleProtocol shuttleProtocol; | 
|---|
|  |  |  | private Socket socket; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private static final boolean DEBUG = false;//调试模式 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private List<JSONObject> socketResults = new ArrayList<>(); | 
|---|
|  |  |  | private List<JSONObject> socketReadResults = new ArrayList<>(); | 
|---|
|  |  |  | private List<DeviceMsgModel> socketResults = new ArrayList<>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //原始设备数据 | 
|---|
|  |  |  | private Object originDeviceData; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public NyShuttleThread(ShuttleSlave slave, RedisUtil redisUtil) { | 
|---|
|  |  |  | this.slave = slave; | 
|---|
|  |  |  | public NyShuttleThread(DeviceConfig deviceConfig, RedisUtil redisUtil) { | 
|---|
|  |  |  | this.deviceConfig = deviceConfig; | 
|---|
|  |  |  | this.redisUtil = redisUtil; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void run() { | 
|---|
|  |  |  | News.info("{}号四向车线程启动", slave.getId()); | 
|---|
|  |  |  | this.connect(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //监听消息并存储 | 
|---|
|  |  |  | Thread innerThread = new Thread(() -> { | 
|---|
|  |  |  | while (true) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | listenSocketMessage(); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | innerThread.start(); | 
|---|
|  |  |  | News.info("{}号四向车线程启动", deviceConfig.getDeviceNo()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //设备读取 | 
|---|
|  |  |  | Thread readThread = new Thread(() -> { | 
|---|
|  |  |  | while (true) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | read(); | 
|---|
|  |  |  | Thread.sleep(50); | 
|---|
|  |  |  | listenMessageFromRedis(); | 
|---|
|  |  |  | listenInit();//监听初始化事件 | 
|---|
|  |  |  | readStatus(); | 
|---|
|  |  |  | Thread.sleep(100); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ShuttleAction shuttleAction = null; | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | shuttleAction = SpringUtils.getBean(ShuttleAction.class); | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (shuttleAction == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //演示模式 | 
|---|
|  |  |  | shuttleAction.demo(deviceConfig.getDeviceNo()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //                    //小车空闲且有跑库程序 | 
|---|
|  |  |  | //                    shuttleAction.moveLoc(deviceConfig.getDeviceNo()); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | log.error("ShuttleThread Fail", e); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | Thread executeThread = new Thread(() -> { | 
|---|
|  |  |  | while (true) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | ShuttleAction shuttleAction = SpringUtils.getBean(ShuttleAction.class); | 
|---|
|  |  |  | ShuttleAction shuttleAction = null; | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | shuttleAction = SpringUtils.getBean(ShuttleAction.class); | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (shuttleAction == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Object object = redisUtil.get(RedisKeyType.SHUTTLE_FLAG.key + slave.getId()); | 
|---|
|  |  |  | Object object = redisUtil.get(RedisKeyType.SHUTTLE_FLAG.key + deviceConfig.getDeviceNo()); | 
|---|
|  |  |  | if (object == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | Integer taskNo = Integer.valueOf(String.valueOf(object)); | 
|---|
|  |  |  | if (taskNo != 0) { | 
|---|
|  |  |  | //存在任务需要执行 | 
|---|
|  |  |  | boolean result = shuttleAction.executeWork(slave.getId(), taskNo); | 
|---|
|  |  |  | boolean result = shuttleAction.executeWork(deviceConfig.getDeviceNo(), taskNo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //                    //小车空闲且有跑库程序 | 
|---|
|  |  |  | //                    shuttleAction.moveLoc(slave.getId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //演示模式 | 
|---|
|  |  |  | shuttleAction.demo(slave.getId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Thread.sleep(200); | 
|---|
|  |  |  | Thread.sleep(100); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | executeThread.start(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //其他任务 | 
|---|
|  |  |  | Thread otherThread = new Thread(() -> { | 
|---|
|  |  |  | while (true) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | listenInit();//监听初始化事件 | 
|---|
|  |  |  | saveLog();//保存数据 | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | otherThread.start(); | 
|---|
|  |  |  | //        //其他任务 | 
|---|
|  |  |  | //        Thread otherThread = new Thread(() -> { | 
|---|
|  |  |  | //            while (true) { | 
|---|
|  |  |  | //                try { | 
|---|
|  |  |  | //                    saveLog();//保存数据 | 
|---|
|  |  |  | //                } catch (Exception e) { | 
|---|
|  |  |  | //                    e.printStackTrace(); | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //        }); | 
|---|
|  |  |  | //        otherThread.start(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private void saveLog() { | 
|---|
|  |  |  | 
|---|
|  |  |  | deviceDataLog.setOriginData(JSON.toJSONString(this.originDeviceData)); | 
|---|
|  |  |  | deviceDataLog.setWcsData(JSON.toJSONString(shuttleProtocol)); | 
|---|
|  |  |  | deviceDataLog.setType(String.valueOf(SlaveType.Shuttle)); | 
|---|
|  |  |  | deviceDataLog.setDeviceNo(slave.getId()); | 
|---|
|  |  |  | deviceDataLog.setDeviceNo(deviceConfig.getDeviceNo()); | 
|---|
|  |  |  | deviceDataLog.setCreateTime(new Date()); | 
|---|
|  |  |  | deviceDataLogService.insert(deviceDataLog); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //更新采集时间 | 
|---|
|  |  |  | shuttleProtocol.setDeviceDataLog(System.currentTimeMillis()); | 
|---|
|  |  |  | OutputQueue.SHUTTLE.offer(MessageFormat.format("【{0}】[id:{1}] <<<<< 实时数据更新成功",DateUtils.convert(new Date()), slave.getId())); | 
|---|
|  |  |  | OutputQueue.SHUTTLE.offer(MessageFormat.format("【{0}】[id:{1}] <<<<< 实时数据更新成功",DateUtils.convert(new Date()), deviceConfig.getDeviceNo())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private void listenSocketMessage() { | 
|---|
|  |  |  | private void listenMessageFromRedis() { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | if (this.socket == null) { | 
|---|
|  |  |  | DeviceMsgUtils deviceMsgUtils = null; | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | deviceMsgUtils = SpringUtils.getBean(DeviceMsgUtils.class); | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (deviceMsgUtils == null) { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | DeviceMsgModel deviceMsg = deviceMsgUtils.getDeviceMsg(SlaveType.Shuttle, deviceConfig.getDeviceNo()); | 
|---|
|  |  |  | if(deviceMsg == null){ | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取输入流 | 
|---|
|  |  |  | BufferedReader reader = new BufferedReader(new InputStreamReader(this.socket.getInputStream())); | 
|---|
|  |  |  | // 读取服务器的响应 | 
|---|
|  |  |  | StringBuffer sb = new StringBuffer(); | 
|---|
|  |  |  | char[] chars = new char[2048];//缓冲区 | 
|---|
|  |  |  | while (true) { | 
|---|
|  |  |  | reader.read(chars); | 
|---|
|  |  |  | String trim = new String(chars); | 
|---|
|  |  |  | sb.append(trim); | 
|---|
|  |  |  | if (trim.lastIndexOf("\r\n") != -1) { | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | JSONObject data = JSON.parseObject(JSON.toJSONString(deviceMsg.getDeviceMsg())); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONObject result = JSON.parseObject(sb.toString());//得到响应结果集 | 
|---|
|  |  |  | if (!socketResults.isEmpty() && socketResults.size() >= 5) { | 
|---|
|  |  |  | socketResults.remove(0);//清理头节点 | 
|---|
|  |  |  | if (deviceMsg.getDeviceMsgType().equals("status")) { | 
|---|
|  |  |  | data.put("originDeviceData", deviceMsg.getDeviceOriginMsg()); | 
|---|
|  |  |  | socketReadResults.add(data); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | socketResults.add(deviceMsg);//添加数据 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | socketResults.add(result);//添加数据 | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | //            e.printStackTrace(); | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public JSONObject getRequestBody(String type, String taskId) { | 
|---|
|  |  |  | public JSONObject getRequestBody(String resultKey) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | // 获取服务器响应 | 
|---|
|  |  |  | JSONObject result = null; | 
|---|
|  |  |  | if (type.equals("readState")) { | 
|---|
|  |  |  | type = "state"; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | int idx = -1; | 
|---|
|  |  |  | for (int i = 0; i < socketResults.size(); i++) { | 
|---|
|  |  |  | JSONObject socketResult = socketResults.get(i); | 
|---|
|  |  |  | if (!socketResult.get("msgType").equals("responseMsg")) {//不是响应内容 | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONObject resultResponse = JSON.parseObject(socketResult.get("response").toString()); | 
|---|
|  |  |  | JSONObject resultBody = JSON.parseObject(resultResponse.get("body").toString()); | 
|---|
|  |  |  | String responseType = resultBody.get("responseType").toString(); | 
|---|
|  |  |  | String responseTaskId = resultBody.get("taskId").toString(); | 
|---|
|  |  |  | if (DEBUG) { | 
|---|
|  |  |  | result = socketResult; | 
|---|
|  |  |  | DeviceMsgModel deviceMsgModel = socketResults.get(i); | 
|---|
|  |  |  | if(deviceMsgModel.getResultKey().equals(resultKey)){ | 
|---|
|  |  |  | idx = i; | 
|---|
|  |  |  | result = JSON.parseObject(JSON.toJSONString(deviceMsgModel.getDeviceMsg())); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!responseType.equals(type)) { | 
|---|
|  |  |  | continue;//响应类型与请求类型不一致,不在调试模式下 | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (taskId != null && !responseTaskId.equals(taskId)) { | 
|---|
|  |  |  | continue;//响应ID与请求ID不一致,不在调试模式下 | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | result = socketResult; | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (result == null) { | 
|---|
|  |  |  | return null;//无响应结果 | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | socketResults.remove(idx); | 
|---|
|  |  |  | return filterBodyData(result);//返回Body结果集 | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private void read() { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | if (this.socket == null || this.socket.isClosed()) { | 
|---|
|  |  |  | //链接断开重新链接 | 
|---|
|  |  |  | this.connect(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | readStatus(); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | OutputQueue.SHUTTLE.offer(MessageFormat.format("【{0}】读取四向穿梭车状态信息失败 ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | if (null == shuttleProtocol) { | 
|---|
|  |  |  | shuttleProtocol = new ShuttleProtocol(); | 
|---|
|  |  |  | shuttleProtocol.setShuttleNo(slave.getId()); | 
|---|
|  |  |  | shuttleProtocol.setShuttleNo(deviceConfig.getDeviceNo()); | 
|---|
|  |  |  | shuttleProtocol.setProtocolStatus(ShuttleProtocolStatusType.IDLE); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | InnerSuhttleExtend extend = new InnerSuhttleExtend(); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //----------读取四向穿梭车状态----------- | 
|---|
|  |  |  | NyShuttleHttpCommand readStatusCommand = getReadStatusCommand(slave.getId()); | 
|---|
|  |  |  | JSONObject data = requestCommand(readStatusCommand); | 
|---|
|  |  |  | if (data == null) { | 
|---|
|  |  |  | DeviceMsgUtils deviceMsgUtils = null; | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | deviceMsgUtils = SpringUtils.getBean(DeviceMsgUtils.class); | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(deviceMsgUtils == null){ | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | NyShuttleHttpCommand readStatusCommand = getReadStatusCommand(deviceConfig.getDeviceNo()); | 
|---|
|  |  |  | //指令超过2条,不再下发任务状态请求 | 
|---|
|  |  |  | TreeSet<String> deviceCommandMsgListKey = deviceMsgUtils.getDeviceCommandMsgListKey(SlaveType.Shuttle, deviceConfig.getDeviceNo()); | 
|---|
|  |  |  | if (deviceCommandMsgListKey.size() < 2) { | 
|---|
|  |  |  | requestCommand(readStatusCommand);//请求状态 | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (this.socketReadResults.isEmpty()) { | 
|---|
|  |  |  | if (System.currentTimeMillis() - shuttleProtocol.getLastOnlineTime() > 1000 * 60) { | 
|---|
|  |  |  | //最后一次上线时间超过60s,认定离线 | 
|---|
|  |  |  | shuttleProtocol.setProtocolStatus(ShuttleProtocolStatusType.OFFLINE); | 
|---|
|  |  |  | this.shuttleProtocol.setProtocolStatus(ShuttleProtocolStatusType.OFFLINE); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | OutputQueue.SHUTTLE.offer(MessageFormat.format("【{0}】四向穿梭车Socket状态信息失败 ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort())); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //----------读取四向穿梭车状态----------- | 
|---|
|  |  |  | //小车设备状态 | 
|---|
|  |  |  | shuttleProtocol.setDeviceStatus(data.getInteger("free")); | 
|---|
|  |  |  | //小车模式 | 
|---|
|  |  |  | shuttleProtocol.setMode(data.getInteger("workingMode")); | 
|---|
|  |  |  | //当前二维码 | 
|---|
|  |  |  | shuttleProtocol.setCurrentCode(data.getString("point")); | 
|---|
|  |  |  | //电池电量 | 
|---|
|  |  |  | shuttleProtocol.setBatteryPower(data.getString("powerPercent")); | 
|---|
|  |  |  | //电池电压 | 
|---|
|  |  |  | shuttleProtocol.setBatteryVoltage(data.getInteger("voltage")); | 
|---|
|  |  |  | //故障 | 
|---|
|  |  |  | shuttleProtocol.setErrorCode(data.getJSONArray("errCode").getString(0)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //是否顶升 | 
|---|
|  |  |  | shuttleProtocol.setHasLift(data.getInteger("liftPosition") == 2 ? true : false); | 
|---|
|  |  |  | //是否有托盘 | 
|---|
|  |  |  | shuttleProtocol.setHasPallet(data.getInteger("loadState") == 1 ? true : false); | 
|---|
|  |  |  | //行驶方向 | 
|---|
|  |  |  | shuttleProtocol.setRunDirection(data.getString("runDir") == null ? "none" : data.getString("runDir")); | 
|---|
|  |  |  | //是否为充电状态 | 
|---|
|  |  |  | shuttleProtocol.setHasCharge(data.getInteger("chargState") == 1 ? true : false); | 
|---|
|  |  |  | //运行速度 | 
|---|
|  |  |  | shuttleProtocol.setSpeed(data.getInteger("speed")); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //*********读取扩展字段********** | 
|---|
|  |  |  | InnerSuhttleExtend extend = (InnerSuhttleExtend) shuttleProtocol.getExtend(); | 
|---|
|  |  |  | //管制状态 | 
|---|
|  |  |  | extend.setSuspendState(data.getInteger("suspendState")); | 
|---|
|  |  |  | //最高电芯电压(mV) | 
|---|
|  |  |  | extend.setMaxCellVoltage(data.getInteger("maxCellVoltage")); | 
|---|
|  |  |  | //最低电芯电压(mV) | 
|---|
|  |  |  | extend.setMinCellVoltage(data.getInteger("minCellVoltage")); | 
|---|
|  |  |  | //电池电压 | 
|---|
|  |  |  | extend.setVoltage(data.getInteger("voltage")); | 
|---|
|  |  |  | //充放电循环次数 | 
|---|
|  |  |  | extend.setChargeCycleTimes(data.getInteger("chargeCycleTimes")); | 
|---|
|  |  |  | //剩余电量 | 
|---|
|  |  |  | extend.setSurplusQuantity(data.getInteger("surplusQuantity")); | 
|---|
|  |  |  | //总电量 | 
|---|
|  |  |  | extend.setCountQuantity(data.getInteger("countQuantity")); | 
|---|
|  |  |  | shuttleProtocol.setExtend(extend);//扩展字段 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //最近一次在线时间 | 
|---|
|  |  |  | shuttleProtocol.setLastOnlineTime(System.currentTimeMillis()); | 
|---|
|  |  |  | ///读取四向穿梭车状态-end | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //小车处于运行中,将标记置为true | 
|---|
|  |  |  | if (shuttleProtocol.getDeviceStatus() == 0) { | 
|---|
|  |  |  | shuttleProtocol.setPakMk(true); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (shuttleProtocol.getProtocolStatusType() == null && shuttleProtocol.getDeviceStatus().intValue() == 0) { | 
|---|
|  |  |  | //小车空闲状态、小车任务状态为未知,认定曾离线过,需要复位成空闲 | 
|---|
|  |  |  | shuttleProtocol.setProtocolStatusType(ShuttleProtocolStatusType.IDLE); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.originDeviceData = data; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | OutputQueue.SHUTTLE.offer(MessageFormat.format("【{0}】[id:{1}] <<<<< 实时数据更新成功",DateUtils.convert(new Date()), slave.getId())); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONObject data = this.socketReadResults.get(0); | 
|---|
|  |  |  | this.socketReadResults.remove(0); | 
|---|
|  |  |  | //----------读取四向穿梭车状态----------- | 
|---|
|  |  |  | //小车设备状态 | 
|---|
|  |  |  | shuttleProtocol.setDeviceStatus(data.getInteger("deviceStatus")); | 
|---|
|  |  |  | //小车模式 | 
|---|
|  |  |  | shuttleProtocol.setMode(data.getInteger("mode")); | 
|---|
|  |  |  | //当前二维码 | 
|---|
|  |  |  | shuttleProtocol.setCurrentCode(data.getString("currentCode")); | 
|---|
|  |  |  | //电池电量 | 
|---|
|  |  |  | shuttleProtocol.setBatteryPower(data.getString("batteryPower")); | 
|---|
|  |  |  | //电池电压 | 
|---|
|  |  |  | shuttleProtocol.setBatteryVoltage(data.getInteger("batteryVoltage")); | 
|---|
|  |  |  | //故障 | 
|---|
|  |  |  | shuttleProtocol.setErrorCode(data.getString("errorCode")); | 
|---|
|  |  |  | //是否顶升 | 
|---|
|  |  |  | shuttleProtocol.setHasLift(data.getBoolean("hasLift")); | 
|---|
|  |  |  | //是否有托盘 | 
|---|
|  |  |  | shuttleProtocol.setHasPallet(data.getBoolean("hasPallet")); | 
|---|
|  |  |  | //行驶方向 | 
|---|
|  |  |  | shuttleProtocol.setRunDirection(data.getString("runDirection")); | 
|---|
|  |  |  | //是否为充电状态 | 
|---|
|  |  |  | shuttleProtocol.setHasCharge(data.getBoolean("hasCharge")); | 
|---|
|  |  |  | //运行速度 | 
|---|
|  |  |  | shuttleProtocol.setSpeed(data.getInteger("speed")); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //*********读取扩展字段********** | 
|---|
|  |  |  | JSONObject extendData = data.getJSONObject("extend"); | 
|---|
|  |  |  | InnerSuhttleExtend extend = (InnerSuhttleExtend) shuttleProtocol.getExtend(); | 
|---|
|  |  |  | //管制状态 | 
|---|
|  |  |  | extend.setSuspendState(extendData.getInteger("suspendState")); | 
|---|
|  |  |  | //最高电芯电压(mV) | 
|---|
|  |  |  | extend.setMaxCellVoltage(extendData.getInteger("maxCellVoltage")); | 
|---|
|  |  |  | //最低电芯电压(mV) | 
|---|
|  |  |  | extend.setMinCellVoltage(extendData.getInteger("minCellVoltage")); | 
|---|
|  |  |  | //电池电压 | 
|---|
|  |  |  | extend.setVoltage(extendData.getInteger("voltage")); | 
|---|
|  |  |  | //充放电循环次数 | 
|---|
|  |  |  | extend.setChargeCycleTimes(extendData.getInteger("chargeCycleTimes")); | 
|---|
|  |  |  | //剩余电量 | 
|---|
|  |  |  | extend.setSurplusQuantity(extendData.getInteger("surplusQuantity")); | 
|---|
|  |  |  | //总电量 | 
|---|
|  |  |  | extend.setCountQuantity(extendData.getInteger("countQuantity")); | 
|---|
|  |  |  | shuttleProtocol.setExtend(extend);//扩展字段 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //最近一次在线时间 | 
|---|
|  |  |  | shuttleProtocol.setLastOnlineTime(System.currentTimeMillis()); | 
|---|
|  |  |  | //读取四向穿梭车状态-end | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //小车处于运行中,将标记置为true | 
|---|
|  |  |  | if (shuttleProtocol.getDeviceStatus() == 0) { | 
|---|
|  |  |  | shuttleProtocol.setPakMk(true); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (shuttleProtocol.getProtocolStatusType() == null && shuttleProtocol.getDeviceStatus().intValue() == 1) { | 
|---|
|  |  |  | //小车空闲状态、小车任务状态为未知,认定曾离线过,需要复位成空闲 | 
|---|
|  |  |  | this.shuttleProtocol.setProtocolStatus(ShuttleProtocolStatusType.IDLE); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (shuttleProtocol.getProtocolStatusType().equals(ShuttleProtocolStatusType.OFFLINE) && shuttleProtocol.getDeviceStatus().intValue() == 1) { | 
|---|
|  |  |  | this.shuttleProtocol.setProtocolStatus(ShuttleProtocolStatusType.IDLE); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.originDeviceData = data.getString("originDeviceData"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | OutputQueue.SHUTTLE.offer(MessageFormat.format("【{0}】[id:{1}] <<<<< 实时数据更新成功",DateUtils.convert(new Date()), deviceConfig.getDeviceNo())); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | OutputQueue.SHUTTLE.offer(MessageFormat.format("【{0}】四向穿梭车Socket状态信息失败 ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort())); | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | this.socket.close(); | 
|---|
|  |  |  | this.socket = null; | 
|---|
|  |  |  | Thread.sleep(1000); | 
|---|
|  |  |  | this.connect(); | 
|---|
|  |  |  | } catch (IOException | InterruptedException exception) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | OutputQueue.SHUTTLE.offer(MessageFormat.format("【{0}】四向穿梭车Socket状态信息失败 ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), deviceConfig.getDeviceNo(), deviceConfig.getIp(), deviceConfig.getPort())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | // 获取服务器响应 | 
|---|
|  |  |  | JSONObject result = null; | 
|---|
|  |  |  | int removeIdx = -1; | 
|---|
|  |  |  | JSONObject socketResult = null; | 
|---|
|  |  |  | for (int i = 0; i < socketResults.size(); i++) { | 
|---|
|  |  |  | JSONObject socketResult = socketResults.get(i); | 
|---|
|  |  |  | if (socketResult == null) { | 
|---|
|  |  |  | DeviceMsgModel deviceMsgModel = socketResults.get(i); | 
|---|
|  |  |  | if (!deviceMsgModel.getDeviceMsgType().equals("shuttleInit")) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!socketResult.get("msgType").equals("requestMsg")) {//不是请求内容 | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONObject resultResponse = JSON.parseObject(socketResult.get("request").toString()); | 
|---|
|  |  |  | JSONObject resultHeader = JSON.parseObject(resultResponse.get("header").toString()); | 
|---|
|  |  |  | JSONObject resultBody = JSON.parseObject(resultResponse.get("body").toString()); | 
|---|
|  |  |  | String requestType = resultBody.getString("requestType"); | 
|---|
|  |  |  | Integer requestId = resultHeader.getInteger("requestId"); | 
|---|
|  |  |  | if (requestType.equals("init")) { | 
|---|
|  |  |  | Integer code = resultBody.getInteger("code"); | 
|---|
|  |  |  | //小车复位请求 | 
|---|
|  |  |  | ShuttleCommand initCommand = getInitCommand(requestId, code); | 
|---|
|  |  |  | //发出请求 | 
|---|
|  |  |  | NyShuttleHttpCommand httpCommand = JSON.parseObject(initCommand.getBody(), NyShuttleHttpCommand.class); | 
|---|
|  |  |  | JSONObject requestResult = requestCommand(httpCommand); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | removeIdx = i;//此数据已经处理,从结果集中剔除 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | log.info(MessageFormat.format("【{0}】四向车复位上报 ===>> [code:{1}] [ip:{2}] [port:{3}]", slave.getId(), code, slave.getIp(), slave.getPort())); | 
|---|
|  |  |  | OutputQueue.SHUTTLE.offer(MessageFormat.format("【{0}】四向车复位上报 ===>> [code:{1}] [ip:{2}] [port:{3}]", slave.getId(), code, slave.getIp(), slave.getPort())); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | removeIdx = i; | 
|---|
|  |  |  | socketResult = JSON.parseObject(JSON.toJSONString(deviceMsgModel.getDeviceMsg())); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (removeIdx != -1) { | 
|---|
|  |  |  | if (socketResult == null) { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONObject resultResponse = JSON.parseObject(socketResult.get("request").toString()); | 
|---|
|  |  |  | JSONObject resultHeader = JSON.parseObject(resultResponse.get("header").toString()); | 
|---|
|  |  |  | JSONObject resultBody = JSON.parseObject(resultResponse.get("body").toString()); | 
|---|
|  |  |  | String requestType = resultBody.getString("requestType"); | 
|---|
|  |  |  | Integer requestId = resultHeader.getInteger("requestId"); | 
|---|
|  |  |  | if (requestType.equals("init")) { | 
|---|
|  |  |  | socketResults.remove(removeIdx); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Integer code = resultBody.getInteger("code"); | 
|---|
|  |  |  | //小车复位请求 | 
|---|
|  |  |  | ShuttleCommand initCommand = getInitCommand(requestId, code); | 
|---|
|  |  |  | //发出请求 | 
|---|
|  |  |  | NyShuttleHttpCommand httpCommand = JSON.parseObject(initCommand.getBody(), NyShuttleHttpCommand.class); | 
|---|
|  |  |  | requestCommand(httpCommand); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | log.info(MessageFormat.format("【{0}】四向车复位上报 ===>> [code:{1}] [ip:{2}] [port:{3}]", deviceConfig.getDeviceNo(), code, deviceConfig.getIp(), deviceConfig.getPort())); | 
|---|
|  |  |  | OutputQueue.SHUTTLE.offer(MessageFormat.format("【{0}】四向车复位上报 ===>> [code:{1}] [ip:{2}] [port:{3}]", deviceConfig.getDeviceNo(), code, deviceConfig.getIp(), deviceConfig.getPort())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | //            e.printStackTrace(); | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | return response; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //    @Override | 
|---|
|  |  |  | //    public CommandResponse move(ShuttleCommand command) { | 
|---|
|  |  |  | //        CommandResponse response = new CommandResponse(false); | 
|---|
|  |  |  | //        try { | 
|---|
|  |  |  | //            //发出请求 | 
|---|
|  |  |  | //            NyShuttleHttpCommand httpCommand = JSON.parseObject(command.getBody(), NyShuttleHttpCommand.class); | 
|---|
|  |  |  | //            Map<String, Object> body = httpCommand.getRequest().getBody(); | 
|---|
|  |  |  | //            Object pathObj = body.get("path"); | 
|---|
|  |  |  | //            int taskId = Integer.parseInt(body.get("taskId").toString()); | 
|---|
|  |  |  | //            List<JSONObject> path = JSON.parseArray(JSON.toJSONString(pathObj), JSONObject.class); | 
|---|
|  |  |  | //            ArrayList<NyShuttleHttpCommand> commandList = new ArrayList<>(); | 
|---|
|  |  |  | //            while (!path.isEmpty()) { | 
|---|
|  |  |  | //                ArrayList<Map<String, Object>> list = new ArrayList<>(); | 
|---|
|  |  |  | //                if (path.size() > 10) { | 
|---|
|  |  |  | //                    List<JSONObject> subList = path.subList(0, 10); | 
|---|
|  |  |  | //                    list.addAll(subList); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                    List<JSONObject> tmp = new ArrayList<>(); | 
|---|
|  |  |  | //                    for (int i = 10; i < path.size(); i++) { | 
|---|
|  |  |  | //                        tmp.add(path.get(i)); | 
|---|
|  |  |  | //                    } | 
|---|
|  |  |  | //                    path = tmp; | 
|---|
|  |  |  | //                }else  { | 
|---|
|  |  |  | //                    list.addAll(path); | 
|---|
|  |  |  | //                    path.clear(); | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                NyShuttleHttpCommand httpCommandCopy = JSON.parseObject(JSON.toJSONString(httpCommand), NyShuttleHttpCommand.class); | 
|---|
|  |  |  | //                JSONObject bodyCopy = JSON.parseObject(JSON.toJSONString(body)); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                NyShuttleHttpCommand.NyRequest request = httpCommandCopy.getRequest(); | 
|---|
|  |  |  | //                bodyCopy.put("path", list); | 
|---|
|  |  |  | //                bodyCopy.put("taskId", taskId++); | 
|---|
|  |  |  | //                request.setBody(bodyCopy); | 
|---|
|  |  |  | //                httpCommandCopy.setRequest(request); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                commandList.add(httpCommandCopy);//add copy | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //            for (NyShuttleHttpCommand requestCommand : commandList) { | 
|---|
|  |  |  | //                while (true) { | 
|---|
|  |  |  | //                    JSONObject result = requestCommand(requestCommand); | 
|---|
|  |  |  | //                    if (result == null) { | 
|---|
|  |  |  | ////                        return response;//请求失败 | 
|---|
|  |  |  | //                        continue;//请求失败尝试重新请求 | 
|---|
|  |  |  | //                    } | 
|---|
|  |  |  | //                    this.shuttleProtocol.setSendTime(System.currentTimeMillis());//指令下发时间 | 
|---|
|  |  |  | //                    response.setMessage(JSON.toJSONString(result)); | 
|---|
|  |  |  | //                    response.setResult(true); | 
|---|
|  |  |  | //                    break; | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //            return response; | 
|---|
|  |  |  | //        } catch (Exception e) { | 
|---|
|  |  |  | //            e.printStackTrace(); | 
|---|
|  |  |  | //            response.setMessage(e.getMessage()); | 
|---|
|  |  |  | //            return response; | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public CommandResponse move(ShuttleCommand command) { | 
|---|
|  |  |  | CommandResponse response = new CommandResponse(false); | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | //发出请求 | 
|---|
|  |  |  | NyShuttleHttpCommand httpCommand = JSON.parseObject(command.getBody(), NyShuttleHttpCommand.class); | 
|---|
|  |  |  | Map<String, Object> body = httpCommand.getRequest().getBody(); | 
|---|
|  |  |  | Object pathObj = body.get("path"); | 
|---|
|  |  |  | int taskId = Integer.parseInt(body.get("taskId").toString()); | 
|---|
|  |  |  | List<JSONObject> path = JSON.parseArray(JSON.toJSONString(pathObj), JSONObject.class); | 
|---|
|  |  |  | ArrayList<NyShuttleHttpCommand> commandList = new ArrayList<>(); | 
|---|
|  |  |  | while (!path.isEmpty()) { | 
|---|
|  |  |  | ArrayList<Map<String, Object>> list = new ArrayList<>(); | 
|---|
|  |  |  | if (path.size() > 10) { | 
|---|
|  |  |  | List<JSONObject> subList = path.subList(0, 10); | 
|---|
|  |  |  | list.addAll(subList); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<JSONObject> tmp = new ArrayList<>(); | 
|---|
|  |  |  | for (int i = 10; i < path.size(); i++) { | 
|---|
|  |  |  | tmp.add(path.get(i)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | path = tmp; | 
|---|
|  |  |  | }else  { | 
|---|
|  |  |  | list.addAll(path); | 
|---|
|  |  |  | path.clear(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | NyShuttleHttpCommand httpCommandCopy = JSON.parseObject(JSON.toJSONString(httpCommand), NyShuttleHttpCommand.class); | 
|---|
|  |  |  | JSONObject bodyCopy = JSON.parseObject(JSON.toJSONString(body)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | NyShuttleHttpCommand.NyRequest request = httpCommandCopy.getRequest(); | 
|---|
|  |  |  | bodyCopy.put("path", list); | 
|---|
|  |  |  | bodyCopy.put("taskId", taskId++); | 
|---|
|  |  |  | request.setBody(bodyCopy); | 
|---|
|  |  |  | httpCommandCopy.setRequest(request); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | commandList.add(httpCommandCopy);//add copy | 
|---|
|  |  |  | String resultKey = requestCommand(httpCommand); | 
|---|
|  |  |  | //查询请求结果 | 
|---|
|  |  |  | JSONObject result = queryCommandStatus(resultKey); | 
|---|
|  |  |  | if (result == null) { | 
|---|
|  |  |  | return response;//请求失败 | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (NyShuttleHttpCommand requestCommand : commandList) { | 
|---|
|  |  |  | while (true) { | 
|---|
|  |  |  | int i = 0; | 
|---|
|  |  |  | i++; | 
|---|
|  |  |  | JSONObject result = requestCommand(requestCommand); | 
|---|
|  |  |  | if (result == null) { | 
|---|
|  |  |  | //                        return response;//请求失败 | 
|---|
|  |  |  | News.info("Socket命令下发失败,任务数据={},次数={}", JSON.toJSON(requestCommand), i); | 
|---|
|  |  |  | continue;//请求失败尝试重新请求 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.shuttleProtocol.setSendTime(System.currentTimeMillis());//指令下发时间 | 
|---|
|  |  |  | response.setMessage(JSON.toJSONString(result)); | 
|---|
|  |  |  | response.setResult(true); | 
|---|
|  |  |  | News.info("Socket命令下发成功,任务数据={},次数={},响应数据={}", JSON.toJSON(requestCommand), i, JSON.toJSONString(result)); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.shuttleProtocol.setSendTime(System.currentTimeMillis());//指令下发时间 | 
|---|
|  |  |  | response.setMessage(JSON.toJSONString(result)); | 
|---|
|  |  |  | response.setResult(true); | 
|---|
|  |  |  | return response; | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | //发出请求 | 
|---|
|  |  |  | NyShuttleHttpCommand httpCommand = JSON.parseObject(command.getBody(), NyShuttleHttpCommand.class); | 
|---|
|  |  |  | JSONObject result = requestCommand(httpCommand); | 
|---|
|  |  |  | String resultKey = requestCommand(httpCommand); | 
|---|
|  |  |  | //查询请求结果 | 
|---|
|  |  |  | JSONObject result = queryCommandStatus(resultKey); | 
|---|
|  |  |  | if (result == null) { | 
|---|
|  |  |  | return response;//请求失败 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | //发出请求 | 
|---|
|  |  |  | NyShuttleHttpCommand httpCommand = JSON.parseObject(command.getBody(), NyShuttleHttpCommand.class); | 
|---|
|  |  |  | JSONObject result = requestCommand(httpCommand); | 
|---|
|  |  |  | String resultKey = requestCommand(httpCommand); | 
|---|
|  |  |  | //查询请求结果 | 
|---|
|  |  |  | JSONObject result = queryCommandStatus(resultKey); | 
|---|
|  |  |  | if (result == null) { | 
|---|
|  |  |  | return response;//请求失败 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | //发出请求 | 
|---|
|  |  |  | NyShuttleHttpCommand httpCommand = JSON.parseObject(command.getBody(), NyShuttleHttpCommand.class); | 
|---|
|  |  |  | JSONObject result = requestCommand(httpCommand); | 
|---|
|  |  |  | String resultKey = requestCommand(httpCommand); | 
|---|
|  |  |  | //查询请求结果 | 
|---|
|  |  |  | JSONObject result = queryCommandStatus(resultKey); | 
|---|
|  |  |  | if (result == null) { | 
|---|
|  |  |  | return response;//请求失败 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | if (shuttleService == null) { | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | BasShuttle basShuttle = shuttleService.selectOne(new EntityWrapper<BasShuttle>().eq("shuttle_no", slave.getId())); | 
|---|
|  |  |  | BasShuttle basShuttle = shuttleService.selectOne(new EntityWrapper<BasShuttle>().eq("shuttle_no", deviceConfig.getDeviceNo())); | 
|---|
|  |  |  | if (basShuttle == null) { | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //***************判断是否满充校准*************** | 
|---|
|  |  |  | Config shuttleMaxPowerVerifyConfig = configService.selectOne(new EntityWrapper<Config>() | 
|---|
|  |  |  | .eq("code", "shuttleMaxPowerVerify") | 
|---|
|  |  |  | .eq("status", 1)); | 
|---|
|  |  |  | if (shuttleMaxPowerVerifyConfig != null) { | 
|---|
|  |  |  | if (shuttleMaxPowerVerifyConfig.getValue().equals("true")) { | 
|---|
|  |  |  | if (this.shuttleProtocol.getBatteryVoltage() < 5630) { | 
|---|
|  |  |  | return false;//电压不够继续充电 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //***************判断是否满充校准*************** | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (this.shuttleProtocol.getHasCharge() == null) { | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | if (Integer.valueOf(this.shuttleProtocol.getBatteryPower()) >= maxPower) { | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public boolean isFault() { | 
|---|
|  |  |  | if (this.shuttleProtocol.getErrorCode() == null | 
|---|
|  |  |  | || this.shuttleProtocol.getMode() == null | 
|---|
|  |  |  | || this.shuttleProtocol.getExtend() == null | 
|---|
|  |  |  | ) { | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (this.shuttleProtocol.getMode() == 0) { | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!this.shuttleProtocol.getErrorCode().equals("0")) { | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | InnerSuhttleExtend extend = (InnerSuhttleExtend) this.shuttleProtocol.getExtend(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (extend.getSuspendState() == 1) { | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public JSONObject parseStatusToMsg(ShuttleProtocol shuttleProtocol) { | 
|---|
|  |  |  | JSONObject result = new JSONObject(); | 
|---|
|  |  |  | result.put("msgType", "responseMsg"); | 
|---|
|  |  |  | result.put("robotId", 5002); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONObject header = new JSONObject(); | 
|---|
|  |  |  | header.put("responseId", 5005631); | 
|---|
|  |  |  | header.put("version", "RGV-APP-F427-N24036-1112"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONObject body = new JSONObject(); | 
|---|
|  |  |  | body.put("responseType", "state"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public ShuttleCommand getMoveCommand(Integer taskNo, String startCodeNum, String distCodeNum, Integer allDistance, Integer runDirection, Integer runSpeed, List<NavigateNode> nodes) { | 
|---|
|  |  |  | NavigateMapData navigateMapData = SpringUtils.getBean(NavigateMapData.class); | 
|---|
|  |  |  | NyShuttleHttpCommand httpStandard = getHttpStandard(slave.getId(), taskNo); | 
|---|
|  |  |  | NyShuttleHttpCommand httpStandard = getHttpStandard(deviceConfig.getDeviceNo(), taskNo); | 
|---|
|  |  |  | NyShuttleHttpCommand.NyRequest request = httpStandard.getRequest(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ArrayList<HashMap<String, Object>> path = new ArrayList<>(); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ShuttleCommand command = new ShuttleCommand(); | 
|---|
|  |  |  | command.setShuttleNo(slave.getId()); | 
|---|
|  |  |  | command.setShuttleNo(deviceConfig.getDeviceNo()); | 
|---|
|  |  |  | command.setBody(JSON.toJSONString(httpStandard)); | 
|---|
|  |  |  | command.setMode(ShuttleCommandModeType.MOVE.id); | 
|---|
|  |  |  | command.setTargetLocNo(locMast.getLocNo()); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public ShuttleCommand getLiftCommand(Integer taskNo, Boolean lift) { | 
|---|
|  |  |  | NyShuttleHttpCommand httpStandard = getHttpStandard(slave.getId(), taskNo); | 
|---|
|  |  |  | NyShuttleHttpCommand httpStandard = getHttpStandard(deviceConfig.getDeviceNo(), taskNo); | 
|---|
|  |  |  | NyShuttleHttpCommand.NyRequest request = httpStandard.getRequest(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Integer taskId = getTaskId();//TaskID需要随机 | 
|---|
|  |  |  | 
|---|
|  |  |  | httpStandard.setRequest(request); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ShuttleCommand command = new ShuttleCommand(); | 
|---|
|  |  |  | command.setShuttleNo(slave.getId()); | 
|---|
|  |  |  | command.setShuttleNo(deviceConfig.getDeviceNo()); | 
|---|
|  |  |  | command.setBody(JSON.toJSONString(httpStandard)); | 
|---|
|  |  |  | command.setMode(lift ? ShuttleCommandModeType.PALLET_LIFT.id : ShuttleCommandModeType.PALLET_DOWN.id); | 
|---|
|  |  |  | command.setTaskNo(taskId); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public ShuttleCommand getChargeCommand(Integer taskNo, Boolean charge) { | 
|---|
|  |  |  | NyShuttleHttpCommand httpStandard = getHttpStandard(slave.getId(), taskNo); | 
|---|
|  |  |  | NyShuttleHttpCommand httpStandard = getHttpStandard(deviceConfig.getDeviceNo(), taskNo); | 
|---|
|  |  |  | NyShuttleHttpCommand.NyRequest request = httpStandard.getRequest(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Integer taskId = getTaskId();//TaskID需要随机 | 
|---|
|  |  |  | 
|---|
|  |  |  | httpStandard.setRequest(request); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ShuttleCommand command = new ShuttleCommand(); | 
|---|
|  |  |  | command.setShuttleNo(slave.getId()); | 
|---|
|  |  |  | command.setShuttleNo(deviceConfig.getDeviceNo()); | 
|---|
|  |  |  | command.setBody(JSON.toJSONString(httpStandard)); | 
|---|
|  |  |  | command.setMode(charge ? ShuttleCommandModeType.CHARGE_OPEN.id : ShuttleCommandModeType.CHARGE_CLOSE.id); | 
|---|
|  |  |  | command.setTaskNo(taskId); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public ShuttleCommand getUpdateLocationCommand(Integer taskNo, String locNo) { | 
|---|
|  |  |  | NyShuttleHttpCommand httpStandard = getHttpStandard(slave.getId(), taskNo); | 
|---|
|  |  |  | NyShuttleHttpCommand httpStandard = getHttpStandard(deviceConfig.getDeviceNo(), taskNo); | 
|---|
|  |  |  | NyShuttleHttpCommand.NyRequest request = httpStandard.getRequest(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | HashMap<String, Object> body = new HashMap<>(); | 
|---|
|  |  |  | 
|---|
|  |  |  | httpStandard.setRequest(request); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ShuttleCommand command = new ShuttleCommand(); | 
|---|
|  |  |  | command.setShuttleNo(slave.getId()); | 
|---|
|  |  |  | command.setShuttleNo(deviceConfig.getDeviceNo()); | 
|---|
|  |  |  | command.setBody(JSON.toJSONString(httpStandard)); | 
|---|
|  |  |  | command.setMode(ShuttleCommandModeType.UPDATE_LOCATION.id); | 
|---|
|  |  |  | command.setTaskNo(taskNo); | 
|---|
|  |  |  | 
|---|
|  |  |  | public ShuttleCommand getInitCommand(Integer taskNo, Integer code) { | 
|---|
|  |  |  | LocMastService locMastService = SpringUtils.getBean(LocMastService.class); | 
|---|
|  |  |  | NavigateMapData navigateMapData = SpringUtils.getBean(NavigateMapData.class); | 
|---|
|  |  |  | NyShuttleHttpCommand httpStandard = getHttpStandard(slave.getId(), taskNo); | 
|---|
|  |  |  | NyShuttleHttpCommand httpStandard = getHttpStandard(deviceConfig.getDeviceNo(), taskNo); | 
|---|
|  |  |  | NyShuttleHttpCommand.NyRequest request = httpStandard.getRequest(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //code -> {Integer@13781} 1101101 | 
|---|
|  |  |  | 
|---|
|  |  |  | httpStandard.setRequest(request); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ShuttleCommand command = new ShuttleCommand(); | 
|---|
|  |  |  | command.setShuttleNo(slave.getId()); | 
|---|
|  |  |  | command.setShuttleNo(deviceConfig.getDeviceNo()); | 
|---|
|  |  |  | command.setBody(JSON.toJSONString(httpStandard)); | 
|---|
|  |  |  | command.setMode(ShuttleCommandModeType.RESET.id); | 
|---|
|  |  |  | command.setTaskNo(taskNo); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public boolean connect() { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | Socket socket = new Socket(slave.getIp(), slave.getPort()); | 
|---|
|  |  |  | socket.setSoTimeout(10000); | 
|---|
|  |  |  | socket.setKeepAlive(true); | 
|---|
|  |  |  | this.socket = socket; | 
|---|
|  |  |  | log.info(MessageFormat.format("【{0}】四向穿梭车Socket链接成功 ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort())); | 
|---|
|  |  |  | } catch (IOException e) { | 
|---|
|  |  |  | OutputQueue.SHUTTLE.offer(MessageFormat.format("【{0}】四向穿梭车Socket链接失败 ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort())); | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //发出请求 | 
|---|
|  |  |  | private JSONObject requestCommand(NyShuttleHttpCommand httpCommand) throws IOException { | 
|---|
|  |  |  | if (this.socket == null) { | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //压缩数据包 | 
|---|
|  |  |  | JSONObject data = JSON.parseObject(JSON.toJSONString(httpCommand)); | 
|---|
|  |  |  | data.remove("nodes"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取输出流 | 
|---|
|  |  |  | OutputStreamWriter writer = new OutputStreamWriter(this.socket.getOutputStream()); | 
|---|
|  |  |  | writer.write(JSON.toJSONString(data) + "\r\n"); | 
|---|
|  |  |  | writer.flush(); | 
|---|
|  |  |  | //            System.out.println("Sent message to server: " + JSON.toJSONString(httpCommand)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String requestType = null; | 
|---|
|  |  |  | String taskId = null; | 
|---|
|  |  |  | private String requestCommand(NyShuttleHttpCommand httpCommand) throws IOException { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | requestType = httpCommand.getRequest().getBody().get("requestType").toString(); | 
|---|
|  |  |  | taskId = httpCommand.getRequest().getBody().get("taskId").toString(); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | //            return null; | 
|---|
|  |  |  | //taskId可能取空,不报错,正常情况 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | DeviceMsgUtils deviceMsgUtils = SpringUtils.getBean(DeviceMsgUtils.class); | 
|---|
|  |  |  | if (deviceMsgUtils == null) { | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //压缩数据包 | 
|---|
|  |  |  | JSONObject data = JSON.parseObject(JSON.toJSONString(httpCommand)); | 
|---|
|  |  |  | data.remove("nodes"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | DeviceCommandMsgModel commandMsgModel = new DeviceCommandMsgModel(); | 
|---|
|  |  |  | commandMsgModel.setDeviceId(deviceConfig.getDeviceNo()); | 
|---|
|  |  |  | commandMsgModel.setDeviceType(String.valueOf(SlaveType.Shuttle)); | 
|---|
|  |  |  | commandMsgModel.setCommand(data); | 
|---|
|  |  |  | String key = deviceMsgUtils.sendDeviceCommand(SlaveType.Shuttle, deviceConfig.getDeviceNo(), commandMsgModel); | 
|---|
|  |  |  | return key; | 
|---|
|  |  |  | }catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private JSONObject queryCommandStatus(String resultKey) { | 
|---|
|  |  |  | // 获取服务器响应 | 
|---|
|  |  |  | // 尝试100次 | 
|---|
|  |  |  | // 尝试50次 | 
|---|
|  |  |  | JSONObject result = null; | 
|---|
|  |  |  | for (int i = 0; i < 100; i++) { | 
|---|
|  |  |  | result = getRequestBody(requestType, taskId); | 
|---|
|  |  |  | for (int i = 0; i < 50; i++) { | 
|---|
|  |  |  | result = getRequestBody(resultKey); | 
|---|
|  |  |  | if (result == null) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | Thread.sleep(100); | 
|---|
|  |  |  | Thread.sleep(500); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return result;//返回Body结果集 | 
|---|
|  |  |  | return result; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private JSONObject filterBodyData(JSONObject data) { | 
|---|