From 7aa842ca0c3863da9024873cadd9fd64c72d26d2 Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@63.com> Date: 星期二, 13 十二月 2022 08:48:54 +0800 Subject: [PATCH] # --- src/main/java/com/zy/asrs/controller/SiteController.java | 73 +++++++++++++++++++++++++++++++----- 1 files changed, 63 insertions(+), 10 deletions(-) diff --git a/src/main/java/com/zy/asrs/controller/SiteController.java b/src/main/java/com/zy/asrs/controller/SiteController.java index 122b07c..78e8d0f 100644 --- a/src/main/java/com/zy/asrs/controller/SiteController.java +++ b/src/main/java/com/zy/asrs/controller/SiteController.java @@ -2,33 +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.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 { @@ -37,6 +47,12 @@ 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 = "鍏呯數妯″紡") @@ -66,12 +82,49 @@ @PostMapping("/io/mode/action/site") @ManagerAuth(memo = "鍏呯數鎺у埗") public R ioModeAction(@RequestParam("floor") Integer floor, @RequestParam("charge") Boolean charge){ - for (DevpSlave devp : slaveProperties.getDevp()) { - SiemensDevpThread devpThread = (SiemensDevpThread) SlaveConnection.get(SlaveType.Devp, devp.getId()); - boolean res = devpThread.charge(floor - 1, charge); - return res?R.ok():R.error(); + if (null != wrkChargeService.selectWorking(null, WrkChargeType.charge)) { + return R.error("鐩墠瀛樺湪灏忚溅鍏呯數浠诲姟锛岃绋嶅悗鍐嶈瘯"); } - return R.ok(); + 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") -- Gitblit v1.9.1