MachineController.java 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. package com.iamberry.rst.controllers.pts;
  2. import com.iamberry.rst.core.pts.*;
  3. import com.iamberry.rst.core.tools.QRCJson;
  4. import com.iamberry.rst.core.tools.WeixinUtil;
  5. import com.iamberry.rst.faces.pts.*;
  6. import com.iamberry.wechat.tools.NameUtils;
  7. import com.iamberry.wechat.tools.ResponseJson;
  8. import com.iamberry.wechat.tools.ResultInfo;
  9. import net.sf.json.JSONArray;
  10. import net.sf.json.JSONObject;
  11. import org.springframework.beans.factory.annotation.Autowired;
  12. import org.springframework.stereotype.Controller;
  13. import org.springframework.web.bind.annotation.RequestBody;
  14. import org.springframework.web.bind.annotation.RequestMapping;
  15. import org.springframework.web.bind.annotation.ResponseBody;
  16. import javax.servlet.http.HttpServletRequest;
  17. import java.util.Date;
  18. import java.util.Iterator;
  19. import java.util.List;
  20. /**
  21. * Created by LJK on 2017/8/29.
  22. */
  23. @Controller
  24. @RequestMapping("/mcahine")
  25. public class MachineController {
  26. @Autowired
  27. private ProduceService produceService;
  28. @Autowired
  29. private MachineService machineService;
  30. @Autowired
  31. private DeviceService deviceService;
  32. @Autowired
  33. private PtsEmployeeService ptsEmployeeService;
  34. @Autowired
  35. private MachineLogsService machineLogsService;
  36. @ResponseBody
  37. @RequestMapping("/uploadProcessOptions")
  38. public ResponseJson uploadProcessOptions(HttpServletRequest request,@RequestBody JSONObject query){
  39. ResponseJson rj = new ResponseJson();
  40. if(query == null){
  41. rj.setResultMsg("200");
  42. rj.setResultMsg("ERROR");
  43. return rj;
  44. }
  45. Integer employeeId = query.getInt("employeeId");//员工id
  46. String produceNo = query.getString("produceId");//产品编号
  47. //生成条形码,二维码
  48. String berQrcode = String.valueOf(employeeId+new Date().getTime());
  49. String json = String.format(NameUtils.QR_LIMIT_STR_SCENE, ResultInfo.barCodePrefix+berQrcode);
  50. QRCJson qrc = WeixinUtil.createQrcode(json);
  51. PtsMachine ptsMachine = new PtsMachine();
  52. if (!(qrc == null || qrc.getUrl() == null || qrc.getUrl().isEmpty())) {
  53. ptsMachine.setMachineQrcode(qrc.getUrl());//二维码
  54. ptsMachine.setMachineBarcode(berQrcode);//条形码
  55. ptsMachine.setMachineStatus(1);//机器状态
  56. ptsMachine.setMachineProducedTime(new Date());//生产时间
  57. ptsMachine.setMachineIsPrint(1);//是否打印1:未打印2:已打印
  58. ptsMachine.setMachineCompoundImg("合成的图片url");
  59. ptsMachine.setMachineProcessState(1);//生成流程状态1.正常2.异常
  60. ptsMachine.setMachineCreateTime(new Date());//创建时间
  61. machineService.addMachine(ptsMachine);
  62. }
  63. boolean isAbnormality = true;//状态是否异常
  64. JSONArray nodes = query.getJSONArray("nodes");//选项集合(包含一个或多个工序选项,详情见示例)
  65. PtsMachineLogs ptsMachineLogs = new PtsMachineLogs();
  66. for(int i = 0;i< nodes.size();i++){
  67. JSONObject jsonObject = nodes.getJSONObject(i);
  68. String processNo = jsonObject.getString("processId"); //工序编号
  69. String nodeNo = jsonObject.getString("nodeId"); //工序选项编号
  70. Long logsProcessTime = jsonObject.getLong("logsProcessTime"); //工序执行时间 (时间戳)
  71. Date logsProcessDate = new Date(logsProcessTime);
  72. Produce produce = produceService.getProduce(produceNo);//根据产品编号获取产品信息
  73. ProduceProcess produceProcess = produceService.getProduceProcess(produce.getProduceId(),processNo.charAt(0));
  74. ProcessNode processNode = produceService.getprocessNode(produceProcess.getProcessId(),nodeNo.charAt(0));
  75. PtsDevice ptsDevice = deviceService.getDevice(produceProcess.getDriveId());
  76. PtsEmployee ptsEmployee =ptsEmployeeService.getPtsEmployeeById(employeeId);
  77. ptsMachineLogs.setDeviceId(produceProcess.getDriveId());
  78. ptsMachineLogs.setEmployeeId(employeeId);
  79. ptsMachineLogs.setProduceId(produce.getProduceId());
  80. ptsMachineLogs.setProcessId(produceProcess.getProcessId());
  81. ptsMachineLogs.setMachineId(ptsMachine.getMachineId());
  82. ptsMachineLogs.setEmployeeName(ptsEmployee.getEmployeeName());
  83. ptsMachineLogs.setProduceName(produce.getProduceName());
  84. ptsMachineLogs.setProcessName(produceProcess.getProcessName());
  85. ptsMachineLogs.setDeviceName(ptsDevice.getDeviceName());
  86. if(i == 0){//如果当前循环的是第一条数据则排序必须是1,否则为异常
  87. if(produceProcess.getProcessSort() == 1){
  88. if(processNode.getNodeStatus() == 0){//工序选项状态为异常则机器表状态也是异常
  89. isAbnormality = false;
  90. }
  91. ptsMachineLogs.setLogsProcessStatus(processNode.getNodeStatus());
  92. }else{
  93. ptsMachineLogs.setLogsProcessStatus(0);
  94. isAbnormality = false;
  95. }
  96. }else{//默认为正常
  97. ptsMachineLogs.setLogsProcessStatus(processNode.getNodeStatus());
  98. }
  99. ptsMachineLogs.setLogsProcessPrompt(processNode.getNodeStatus() == 0?"异常操作": null);
  100. ptsMachineLogs.setLogsProcessTime(logsProcessDate);
  101. ptsMachineLogs.setLogsCreateTime(new Date());
  102. //根据上一条工序选项信息判断当前工序是否正常,如果当前为修理工序则忽略,如果上一条为修理工序则查询上上一条
  103. if(i > 0){
  104. //修理工序不用查询上一条工序,但是修理工序前一条工序要设置为次品
  105. /*if(produceProcess.getProcessType() == 1){*/
  106. int num = 0;
  107. ProduceProcess produceProcess2 = null;//当前工序的上一条非修理工序
  108. JSONObject jsonObject2;//上一级工序信息
  109. String processNo2 = null;//上一级工序编号
  110. //先判断当前的上一次是否是修理工序,如果不是则不用执行下面的循环,否则需要循环判断
  111. jsonObject2 = nodes.getJSONObject(i-1);
  112. if(jsonObject2 != null){
  113. processNo2 = jsonObject2.getString("processId");
  114. produceProcess2 = produceService.getProduceProcess(produce.getProduceId(),processNo2.charAt(0));
  115. //判断当前工序是否是修理工序,如果是,则修改上一条为次品
  116. if(produceProcess.getProcessType() == 2){
  117. ptsMachineLogs.setLogsErrorType(2);//异常类型 1:流程异常 2:次品异常
  118. machineLogsService.updateMachineLogs(ptsMachineLogs);
  119. isAbnormality = false;
  120. ptsMachineLogs.setLogsId(null);
  121. ptsMachineLogs.setLogsErrorType(null);
  122. }else{
  123. //判断是否是修理工序 1:生产工序 2:修理工序
  124. if(produceProcess2.getProcessType() == 1){
  125. if(produceProcess.getProcessSort() - produceProcess2.getProcessSort() != 1){
  126. ptsMachineLogs.setLogsProcessStatus(0);
  127. ptsMachineLogs.setLogsErrorType(1);//异常类型 1:流程异常 2:次品异常
  128. isAbnormality = false;
  129. }
  130. }else{
  131. for(int j = i-1;j<= i-1;j--){
  132. if(num == i){
  133. break;//只能循环 i 次,超出则跳出当前循环
  134. }
  135. jsonObject2 = nodes.getJSONObject(j);
  136. if(jsonObject2 != null){
  137. processNo2 = jsonObject2.getString("processId");
  138. produceProcess2 = produceService.getProduceProcess(produce.getProduceId(),processNo2.charAt(0));
  139. if(produceProcess2.getProcessType() == 1){//判断是否是修理工序 1:生产工序 2:修理工序
  140. if(produceProcess.getProcessSort() > produceProcess2.getProcessSort()){
  141. ptsMachineLogs.setLogsProcessStatus(0);
  142. ptsMachineLogs.setLogsErrorType(1);//异常类型 1:流程异常 2:次品异常
  143. isAbnormality = false;
  144. }
  145. break;
  146. }
  147. }
  148. num++;
  149. }
  150. }
  151. }
  152. }
  153. /*}*/
  154. }
  155. //执行添加日志操作
  156. machineLogsService.addMachineLogs(ptsMachineLogs);
  157. ptsMachineLogs.setLogsErrorType(null);//还原为默认值
  158. }
  159. //修改机器信息
  160. if(!isAbnormality){
  161. PtsMachine ptsMachine2 = new PtsMachine();
  162. ptsMachine2.setMachineId(ptsMachine.getMachineId());
  163. ptsMachine2.setMachineProcessState(2);//2表示机器生产过程中出现异常
  164. ptsMachine2.setMachineUpdateTime(new Date());
  165. machineService.updateMachine(ptsMachine2);
  166. }
  167. //截取条形码尾号(4位)
  168. rj.addResponseKeyValue("barcodeTail",berQrcode.substring(berQrcode.length()-4, berQrcode.length()));
  169. return rj;
  170. }
  171. }