| | |
| | | case 9: |
| | | write9((StaProtocol)task.getData()); |
| | | break; |
| | | case 10: |
| | | write10((StaProtocol)task.getData()); |
| | | break; |
| | | default: |
| | | break; |
| | | } |
| | |
| | | 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"; |
| | | resultV1 = "DB100.1804"; |
| | | break; |
| | | case 624: |
| | | resultV1 = "1810"; |
| | | resultV2 = "1810"; |
| | | resultV1 = "DB100.1810"; |
| | | break; |
| | | case 625: |
| | | resultV1 = "1816"; |
| | | resultV2 = "1816"; |
| | | resultV1 = "DB100.1816"; |
| | | break; |
| | | case 626: |
| | | resultV1 = "1822"; |
| | | resultV2 = "1822"; |
| | | resultV1 = "DB100.1822"; |
| | | break; |
| | | default: |
| | | return; |
| | | } |
| | | result1 = siemensS7Net.Write(rgv4?resultV1+".4":resultV1+".3", rgv4?rgv5:rgv4); |
| | | if (rgv4){ |
| | | result1 = siemensS7Net.Write(resultV1+".3", rgv4); |
| | | } else { |
| | | result1 = siemensS7Net.Write(resultV1+".4", rgv5); |
| | | } |
| | | //硫化罐任务写入后,回读一次,看是否成功 |
| | | try { |
| | | Thread.sleep(200); |
| | |
| | | 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); |
| | | if (rgv4){ |
| | | result1 = siemensS7Net.Write(resultV1+".3", rgv4); |
| | | } else { |
| | | result1 = siemensS7Net.Write(resultV1+".4", rgv5); |
| | | } |
| | | 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){ |
| | | if (status[rgv4? 3:4]){ |
| | | break; |
| | | } else { |
| | | log.error("写入RGV数据失败,重新下发任务 写入直接失败 ===>> [id:{}],{},[写入次数:{}]", slave.getId(), JSON.toJSON(staProtocol),writeCount); |
| | | result1 = siemensS7Net.Write(rgv4?resultV1+".4":resultV1+".3", rgv4?rgv5:rgv4); |
| | | if (rgv4){ |
| | | result1 = siemensS7Net.Write(resultV1+".3", rgv4); |
| | | } else { |
| | | result1 = siemensS7Net.Write(resultV1+".4", rgv5); |
| | | } |
| | | 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; |
| | | if (rgv4){ |
| | | result1 = siemensS7Net.Write(resultV1+".3", rgv4); |
| | | } 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; |
| | | result1 = siemensS7Net.Write(resultV1+".4", rgv5); |
| | | } |
| | | } 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; |