From eeb10b50e297061092c61935e4cc1cc9c01ed302 Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@163.com> Date: 星期二, 06 十二月 2022 15:42:34 +0800 Subject: [PATCH] # --- src/main/java/com/zy/asrs/controller/SiteController.java | 107 ++++++++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 101 insertions(+), 6 deletions(-) diff --git a/src/main/java/com/zy/asrs/controller/SiteController.java b/src/main/java/com/zy/asrs/controller/SiteController.java index 30500f8..78e8d0f 100644 --- a/src/main/java/com/zy/asrs/controller/SiteController.java +++ b/src/main/java/com/zy/asrs/controller/SiteController.java @@ -2,32 +2,43 @@ import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.core.annotations.ManagerAuth; +import com.core.common.Cools; import com.core.common.R; import com.zy.asrs.domain.vo.PlcErrorTableVo; import com.zy.asrs.domain.vo.SiteTableVo; import com.zy.asrs.entity.BasDevp; +import com.zy.asrs.entity.BasSte; +import com.zy.asrs.entity.WrkCharge; import com.zy.asrs.service.BasDevpService; +import com.zy.asrs.service.BasSteService; +import com.zy.asrs.service.WrkChargeService; +import com.zy.common.model.enums.WrkChargeType; +import com.zy.common.service.CommonService; +import com.zy.core.DevpThread; import com.zy.core.cache.MessageQueue; import com.zy.core.cache.OutputQueue; import com.zy.core.cache.SlaveConnection; import com.zy.core.enums.SlaveType; +import com.zy.core.enums.SteChargeType; +import com.zy.core.enums.SteStatusType; import com.zy.core.model.DevpSlave; import com.zy.core.model.Task; import com.zy.core.model.protocol.StaProtocol; +import com.zy.core.model.protocol.SteProtocol; import com.zy.core.properties.SlaveProperties; -import com.zy.core.thread.DevpThread; +import com.zy.core.thread.SiemensDevpThread; +import com.zy.core.thread.SteThread; +import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; -import java.util.ArrayList; -import java.util.HashMap; -import java.util.List; -import java.util.Map; +import java.util.*; /** * 杈撻�佽澶囨帴鍙� * Created by vincent on 2020-06-01 */ +@Slf4j @RestController @RequestMapping("/site") public class SiteController { @@ -36,6 +47,85 @@ private SlaveProperties slaveProperties; @Autowired private BasDevpService basDevpService; + @Autowired + private WrkChargeService wrkChargeService; + @Autowired + private BasSteService basSteService; + @Autowired + private CommonService commonService; + + @GetMapping("/io/mode/info/site") + @ManagerAuth(memo = "鍏呯數妯″紡") + public R ioMode(){ + List<Map<String, Object>> res = new ArrayList<>(); + for (DevpSlave devp : slaveProperties.getDevp()) { + SiemensDevpThread devpThread = (SiemensDevpThread) SlaveConnection.get(SlaveType.Devp, devp.getId()); + Map<String, Object> map1 = new HashMap<>(); + map1.put("floor", 1); + map1.put("modeVal", devpThread.charge0); + map1.put("modeDesc", devpThread.charge0?"鍏呯數涓�":"鍏抽棴"); + res.add(map1); + Map<String, Object> map2 = new HashMap<>(); + map2.put("floor", 2); + map2.put("modeVal", devpThread.charge1); + map2.put("modeDesc", devpThread.charge1?"鍏呯數涓�":"鍏抽棴"); + res.add(map2); + Map<String, Object> map3 = new HashMap<>(); + map3.put("floor", 3); + map3.put("modeVal", devpThread.charge2); + map3.put("modeDesc", devpThread.charge2?"鍏呯數涓�":"鍏抽棴"); + res.add(map3); + } + return R.ok().add(res); + } + + @PostMapping("/io/mode/action/site") + @ManagerAuth(memo = "鍏呯數鎺у埗") + public R ioModeAction(@RequestParam("floor") Integer floor, @RequestParam("charge") Boolean charge){ + if (null != wrkChargeService.selectWorking(null, WrkChargeType.charge)) { + return R.error("鐩墠瀛樺湪灏忚溅鍏呯數浠诲姟锛岃绋嶅悗鍐嶈瘯"); + } + if (null != wrkChargeService.selectWorking(null, WrkChargeType.reset)) { + return R.error("鐩墠瀛樺湪灏忚溅澶嶄綅浠诲姟锛岃绋嶅悗鍐嶈瘯"); + } + if (charge) { + return R.ok(); + } + + SteChargeType steCharge = SteChargeType.get(floor); + assert steCharge != null; + Integer steNo = basSteService.hasCarOfLocNo(steCharge.locNo); + if (Cools.isEmpty(steNo)) { + return R.error(steNo + "鍙峰皬杞︿笉鍦�" + floor + "鍙峰厖鐢垫々锛岃妫�鏌ュ皬杞﹀畾浣�"); + } + SteThread steThread = (SteThread) SlaveConnection.get(SlaveType.Ste, steNo); + SteProtocol steProtocol = steThread.getSteProtocol(); + BasSte basSte = basSteService.selectById(steNo); + if (steProtocol.getMode() == 0) { + return R.error(steNo + "鍙峰皬杞︾绾匡紝鏃犳硶鎿嶄綔"); + } + if (!steProtocol.getStatusType().equals(SteStatusType.IDLE)) { + return R.error(steNo + "鍙峰皬杞︿笉鏄┖闂诧紝鏃犳硶鎿嶄綔"); + } + WrkCharge wrkCharge = wrkChargeService.selectWorking(steNo, WrkChargeType.reset); + if (wrkCharge == null) { + // 寮�濮嬬┛姊溅澶嶄綅浠诲姟 + wrkCharge = new WrkCharge(); + wrkCharge.setSteNo(steNo); + wrkCharge.setWrkNo(commonService.getChargeWorkNo(6)); + wrkCharge.setWrkSts(41L); // 41.灏忚溅鍑嗗澶嶄綅 + wrkCharge.setCrnNo(2); // 鍥哄畾2鍙峰爢鍨涙満 + wrkCharge.setIoPri((double) 10); + wrkCharge.setSourceLocNo(steCharge.locNo); + wrkCharge.setLocNo(basSte.getIdleLoc()); + wrkCharge.setMemo("reset"); + wrkCharge.setAppeTime(new Date()); + if (!wrkChargeService.insert(wrkCharge)) { + log.error("淇濆瓨{}鍙风┛姊溅澶嶄綅浠诲姟澶辫触!!!", steNo); + } + } + return R.ok(steNo + "鍙峰皬杞﹀噯澶囩寮�" + floor + "鍙峰厖鐢垫々"); + } @PostMapping("/table/site") @ManagerAuth(memo = "绔欑偣淇℃伅琛�") @@ -148,19 +238,24 @@ @ManagerAuth(memo = "淇敼绔欑偣鏁版嵁") public R siteDetlUpdate(@RequestParam Integer siteId, @RequestParam Short workNo, - @RequestParam Short staNo){ + @RequestParam Short staNo, + @RequestParam String pakMk){ for (DevpSlave devp : slaveProperties.getDevp()) { DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Devp, devp.getId()); Map<Integer, StaProtocol> station = devpThread.getStation(); for (Map.Entry<Integer, StaProtocol> entry : station.entrySet()) { if (siteId.equals(entry.getKey())) { StaProtocol staProtocol = entry.getValue(); + staProtocol = staProtocol.clone(); if (workNo != null) { staProtocol.setWorkNo(workNo); } if (staNo != null) { staProtocol.setStaNo(staNo); } + if (pakMk != null) { + staProtocol.setPakMk(pakMk.equals("Y")); + } boolean result = MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol)); if (result) { return R.ok(); -- Gitblit v1.9.1