| | |
| | | staProtocol.setRGV1(status[0]); // 自动 |
| | | staProtocol.setRGV2(status[1]); // 有物 |
| | | staProtocol.setRGV3(status[2]); // 可入 |
| | | staProtocol.setRGV4(status[3]);// 可出 |
| | | staProtocol.setRGV5(status[4]); // 空板信号 |
| | | staProtocol.setRGV4(status[3]);// |
| | | staProtocol.setRGV5(status[4]); // |
| | | staProtocol.setRGV6(status[5]); // 满托盘 |
| | | } |
| | | } |
| | |
| | | /** |
| | | * 写入 ID+目标站 =====> 单站点写入 |
| | | */ |
| | | private void write10(StaProtocol staProtocol) throws InterruptedException { |
| | | if (null == staProtocol) { |
| | | return; |
| | | } |
| | | boolean rgv4 = staProtocol.isRGV4(); |
| | | boolean rgv5 = staProtocol.isRGV5(); |
| | | OperateResult result1 = null; |
| | | OperateResult result2 = null; |
| | | String resultV1 = ""; |
| | | String resultV2 = ""; |
| | | switch (staProtocol.getSiteId()){ |
| | | case 623: |
| | | resultV1 = "1804"; |
| | | resultV2 = "1804"; |
| | | break; |
| | | case 624: |
| | | resultV1 = "1810"; |
| | | resultV2 = "1810"; |
| | | break; |
| | | case 625: |
| | | resultV1 = "1816"; |
| | | resultV2 = "1816"; |
| | | break; |
| | | case 626: |
| | | resultV1 = "1822"; |
| | | resultV2 = "1822"; |
| | | break; |
| | | default: |
| | | return; |
| | | } |
| | | result1 = siemensS7Net.Write(rgv4?resultV1+".4":resultV1+".3", rgv4?rgv5:rgv4); |
| | | //硫化罐任务写入后,回读一次,看是否成功 |
| | | try { |
| | | Thread.sleep(200); |
| | | } catch (InterruptedException e) { |
| | | e.printStackTrace(); |
| | | } |
| | | |
| | | int writeCount = 1; |
| | | do { |
| | | try{ |
| | | if(!result1.IsSuccess){ |
| | | log.error("写入RGV数据失败,重新下发任务 写入直接失败 ===>> [id:{}],{},[写入次数:{}]", slave.getId(), JSON.toJSON(staProtocol),writeCount); |
| | | result1 = siemensS7Net.Write(rgv4?resultV1+".4":resultV1+".3", rgv4?rgv5:rgv4); |
| | | Thread.sleep(100); |
| | | writeCount++; |
| | | continue; |
| | | } |
| | | OperateResultExOne<byte[]> resultRead1 = siemensS7Net.Read(resultV1, (short) 2); |
| | | if (resultRead1.IsSuccess) { |
| | | boolean[] status = siemensS7Net.getByteTransform().TransBool(resultRead1.Content, 0, 1); |
| | | boolean status1 = status[rgv4? 4:3]; |
| | | if (status1 == rgv4?rgv5:rgv4){ |
| | | break; |
| | | } else { |
| | | log.error("写入RGV数据失败,重新下发任务 写入直接失败 ===>> [id:{}],{},[写入次数:{}]", slave.getId(), JSON.toJSON(staProtocol),writeCount); |
| | | result1 = siemensS7Net.Write(rgv4?resultV1+".4":resultV1+".3", rgv4?rgv5:rgv4); |
| | | Thread.sleep(100); |
| | | writeCount++; |
| | | continue; |
| | | } |
| | | } else { |
| | | log.error("写入RGV数据失败,重新下发任务 写入直接失败 ===>> [id:{}],{},[写入次数:{}]", slave.getId(), JSON.toJSON(staProtocol),writeCount); |
| | | result1 = siemensS7Net.Write(rgv4?resultV1+".4":resultV1+".3", rgv4?rgv5:rgv4); |
| | | Thread.sleep(100); |
| | | writeCount++; |
| | | continue; |
| | | } |
| | | }catch (Exception e){ |
| | | log.error("写入RGV数据后回读出错,异常:"+e); |
| | | } |
| | | writeCount++; |
| | | } while (writeCount<6); |
| | | |
| | | result2 = siemensS7Net.Write(rgv4?resultV2+".3":resultV2+".4", rgv4?rgv4:rgv5); |
| | | writeCount = 1; |
| | | do { |
| | | try{ |
| | | if(!result2.IsSuccess){ |
| | | log.error("写入RGV数据失败,重新下发任务 写入直接失败 ===>> [id:{}],{},[写入次数:{}]", slave.getId(), JSON.toJSON(staProtocol),writeCount); |
| | | result2 = siemensS7Net.Write(rgv4?resultV2+".3":resultV2+".4", rgv4?rgv4:rgv5); |
| | | Thread.sleep(100); |
| | | writeCount++; |
| | | continue; |
| | | } |
| | | OperateResultExOne<byte[]> resultRead2 = siemensS7Net.Read(resultV2, (short) 1); |
| | | if (resultRead2.IsSuccess) { |
| | | boolean[] status = siemensS7Net.getByteTransform().TransBool(resultRead2.Content, 0, 1); |
| | | boolean status1 = status[rgv4? 3:4]; |
| | | if (status1 == rgv4?rgv4:rgv5){ |
| | | break; |
| | | } else { |
| | | log.error("写入RGV数据失败,重新下发任务 写入直接失败 ===>> [id:{}],{},[写入次数:{}]", slave.getId(), JSON.toJSON(staProtocol),writeCount); |
| | | result2 = siemensS7Net.Write(rgv4?resultV2+".3":resultV2+".4", rgv4?rgv4:rgv5); |
| | | Thread.sleep(100); |
| | | writeCount++; |
| | | continue; |
| | | } |
| | | } else { |
| | | log.error("写入RGV数据失败,重新下发任务 写入直接失败 ===>> [id:{}],{},[写入次数:{}]", slave.getId(), JSON.toJSON(staProtocol),writeCount); |
| | | result2 = siemensS7Net.Write(rgv4?resultV2+".3":resultV2+".4", rgv4?rgv4:rgv5); |
| | | Thread.sleep(100); |
| | | writeCount++; |
| | | continue; |
| | | } |
| | | }catch (Exception e){ |
| | | log.error("写入RGV数据后回读出错,异常:"+e); |
| | | } |
| | | writeCount++; |
| | | } while (writeCount<6); |
| | | } |
| | | private void write9(StaProtocol staProtocol) throws InterruptedException { |
| | | if (null == staProtocol) { |
| | | return; |
| | | } |
| | | short resultS1 = staProtocol.getEndRow(); |
| | | OperateResult result1 = null; |
| | | OperateResult result2 = null; |
| | | String resultV1 = ""; |
| | | String resultV2 = ""; |
| | | switch (staProtocol.getSiteId()){ |
| | | case 623: |
| | | resultV1 = "1800"; |
| | | resultV2 = "1812"; |
| | | break; |
| | | case 624: |
| | | resultV1 = "1806"; |
| | | resultV2 = "1818"; |
| | | break; |
| | | case 625: |
| | | resultV1 = "1812"; |
| | | resultV2 = "1800"; |
| | | break; |
| | | case 626: |
| | | resultV1 = "1818"; |
| | | resultV2 = "1806"; |
| | | break; |
| | | default: |
| | | return; |
| | | } |
| | | result1 = siemensS7Net.Write(resultV1, resultS1); |
| | | result2 = siemensS7Net.Write(resultV2, resultS1); |
| | | //硫化罐任务写入后,回读一次,看是否成功 |
| | | try { |
| | | Thread.sleep(200); |
| | |
| | | OperateResultExOne<byte[]> resultRead1 = siemensS7Net.Read(resultV1, (short) 2); |
| | | if (resultRead1.IsSuccess) { |
| | | short transInt16 = siemensS7Net.getByteTransform().TransInt16(resultRead1.Content, 0); |
| | | if (transInt16 == resultS1 || transInt16 == (short) 2 || transInt16 == (short) 3){ |
| | | if (transInt16 == resultS1){ |
| | | break; |
| | | } else { |
| | | log.error("写入RGV数据失败,重新下发任务 写入直接失败 ===>> [id:{}],{},[写入次数:{}]", slave.getId(), JSON.toJSON(staProtocol),writeCount); |
| | |
| | | writeCount++; |
| | | } while (writeCount<6); |
| | | |
| | | writeCount = 1; |
| | | do { |
| | | try{ |
| | | if(!result2.IsSuccess){ |
| | | log.error("写入RGV数据失败,重新下发任务 写入直接失败 ===>> [id:{}],{},[写入次数:{}]", slave.getId(), JSON.toJSON(staProtocol),writeCount); |
| | | result2 = siemensS7Net.Write(resultV2, resultS1); |
| | | Thread.sleep(100); |
| | | writeCount++; |
| | | continue; |
| | | } |
| | | OperateResultExOne<byte[]> resultRead2 = siemensS7Net.Read(resultV2, (short) 2); |
| | | if (resultRead2.IsSuccess) { |
| | | short transInt16 = siemensS7Net.getByteTransform().TransInt16(resultRead2.Content, 0); |
| | | if (transInt16 == resultS1){ |
| | | break; |
| | | } else { |
| | | log.error("写入RGV数据失败,重新下发任务 写入直接失败 ===>> [id:{}],{},[写入次数:{}]", slave.getId(), JSON.toJSON(staProtocol),writeCount); |
| | | result2 = siemensS7Net.Write(resultV2, resultS1); |
| | | Thread.sleep(100); |
| | | writeCount++; |
| | | continue; |
| | | } |
| | | } else { |
| | | log.error("写入RGV数据失败,重新下发任务 写入直接失败 ===>> [id:{}],{},[写入次数:{}]", slave.getId(), JSON.toJSON(staProtocol),writeCount); |
| | | result2 = siemensS7Net.Write(resultV2, resultS1); |
| | | Thread.sleep(100); |
| | | writeCount++; |
| | | continue; |
| | | } |
| | | }catch (Exception e){ |
| | | log.error("写入RGV数据后回读出错,异常:"+e); |
| | | } |
| | | writeCount++; |
| | | } while (writeCount<6); |
| | | |
| | | if (!result1.IsSuccess) { |
| | | staProtocol = station.get(staProtocol.getSiteId()); |
| | | OutputQueue.DEVP.offer(MessageFormat.format("【{0}】写入输送线站点数据失败。输送线plc编号={1},站点数据={2}", slave.getId(), JSON.toJSON(staProtocol))); |