From 1fe34bd9cd779c67beece43b4016e2a0192157c9 Mon Sep 17 00:00:00 2001
From: whyclj <1525436766@qq.com>
Date: 星期二, 21 七月 2020 14:17:22 +0800
Subject: [PATCH] 改成改单个寄存器

---
 src/com/data/PowerArk_SocketCliet_Thread.java |  158 +++++++++++++++++++++++++++++++++-------------------
 1 files changed, 101 insertions(+), 57 deletions(-)

diff --git a/src/com/data/PowerArk_SocketCliet_Thread.java b/src/com/data/PowerArk_SocketCliet_Thread.java
index 72b1b91..bf80aad 100644
--- a/src/com/data/PowerArk_SocketCliet_Thread.java
+++ b/src/com/data/PowerArk_SocketCliet_Thread.java
@@ -20,8 +20,11 @@
 import com.sql.MysqlConnPool;
 
 public class PowerArk_SocketCliet_Thread implements Runnable{
-	public static final int CONTROL_ON = 1;
-	public static final int CONTROL_OFF = 0;
+	public static final int CONTROL_ON = 0xFF00;			//启动
+	public static final int CONTROL_OFF = 0x0000;			//停止
+	
+	public static final int CMD_Start = 1;					//启动
+	public static final int CMD_Stop = 2;					//停止
 	
 	private ByteBuffer bytebuffer_for_socket_RX = ByteBuffer.allocate(1500);
 	public static int PowerArk_Port = 502;
@@ -75,14 +78,14 @@
 						}
 					}*/
 					
-					if(run_count % 8 == 0) {
+					/*if(run_count % 8 == 0) {
 						//读取状态信息      0x8000-8013
 						basedata = new BaseData(Modbus_ComBase.READ_COIL_STATUS, Modbus_ComBase.ButtonOutPut_Start_Addr, 14);
 						if(SocketComm(basedata.createReadData(), socket)) {
 							//读取Q区状态成功 
 							PowerArk_ServerSocket_Thread_SQL.updateDynamicload_ButtonTable(conn_pool, button);
 						}
-					}
+					}*/
 					
 					/*if(run_count % 10 ==0 ) {
 						//读取各个按钮状态  0x40-x0160
@@ -106,187 +109,228 @@
 				/******************************************  写状态   **********************************************/
 				{
 					PowerArk_SocketClient_Thread_SQL.queryPowerArkControl(conn_pool, control);
-					if(control.FZ_b1 >= CONTROL_ON) {
+					if(control.FZ_b1 >= CMD_Start) {
 						//打开按钮1
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.Button_Start_Addr, 1);						
 						control.FZ_b1 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.FZ_b1)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(control.FZ_b1)), socket);
 					}
 					
-					if(control.FZ_b2 >= CONTROL_ON) {
+					if(control.FZ_b2 >= CMD_Start) {
 						//打开按钮2
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.Button_Start_Addr+1, 1);						
 						control.FZ_b2 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.FZ_b2)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(control.FZ_b2)), socket);
 					}
 					
-					if(control.FZ_b3 >= CONTROL_ON) {
+					if(control.FZ_b3 >= CMD_Start) {
 						//打开按钮3
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.Button_Start_Addr+2, 1);						
 						control.FZ_b3 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.FZ_b3)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(control.FZ_b3)), socket);
 					}
 					
-					if(control.FZ_b4 >= CONTROL_ON) {
+					if(control.FZ_b4 >= CMD_Start) {
 						//打开按钮4
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.Button_Start_Addr+3, 1);						
 						control.FZ_b4 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.FZ_b4)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(control.FZ_b4)), socket);
 					}
 					
-					if(control.FZ_b5 >= CONTROL_ON) {
+					if(control.FZ_b5 >= CMD_Start) {
 						//打开按钮5
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.Button_Start_Addr+4, 1);						
 						control.FZ_b5 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.FZ_b5)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(control.FZ_b5)), socket);
 					}
 					
-					if(control.FZ_b6 >= CONTROL_ON) {
+					if(control.FZ_b6 >= CMD_Start) {
 						//打开按钮6
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.Button_Start_Addr+5, 1);						
 						control.FZ_b6 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.FZ_b6)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(control.FZ_b6)), socket);
 					}
 					
-					if(control.FZ_b7 >= CONTROL_ON) {
+					if(control.FZ_b7 >= CMD_Start) {
 						//打开按钮7
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.Button_Start_Addr+6, 1);						
 						control.FZ_b7 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.FZ_b7)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(control.FZ_b7)), socket);
 					}
 					
-					if(control.FZ_b8 >= CONTROL_ON) {
+					if(control.FZ_b8 >= CMD_Start) {
 						//打开按钮8
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.Button_Start_Addr+7, 1);						
 						control.FZ_b8 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.FZ_b8)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(control.FZ_b8)), socket);
 					}
 					
-					if(control.FZ_b9 >= CONTROL_ON) {
+					if(control.FZ_b9 >= CMD_Start) {
 						//打开按钮9
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.Button_Start_Addr+8, 1);						
 						control.FZ_b9 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.FZ_b9)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(control.FZ_b9)), socket);
 					}
 					
-					if(control.FZ_b10 >= CONTROL_ON) {
+					if(control.FZ_b10 >= CMD_Start) {
 						//打开按钮10
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.Button_Start_Addr+9, 1);						
 						control.FZ_b10 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.FZ_b10)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(control.FZ_b10)), socket);
 					}
 					
-					if(control.FZ_b11 >= CONTROL_ON) {
+					if(control.FZ_b11 >= CMD_Start) {
 						//打开按钮11
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.Button_Start_Addr+10, 1);						
 						control.FZ_b11 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.FZ_b11)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(control.FZ_b11)), socket);
 					}
 					
-					if(control.start_auto >= CONTROL_ON) {
+					if(control.start_auto >= CMD_Start) {
 						//启动自动加载
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.StartAutoLoad_Start_Addr, 1);						
 						control.start_auto = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.start_auto)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(control.start_auto)), socket);
 					}
 					
-					if(control.stop_auto >= CONTROL_ON) {
+					if(control.stop_auto >= CMD_Start) {
 						//停止自动加载
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.StopAutoLoad_Start_Addr, 1);						
 						control.stop_auto = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.stop_auto)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(control.stop_auto)), socket);
 					}
 					
-					if(control.sudden_crease >= CONTROL_ON) {
+					if(control.sudden_crease >= CMD_Start) {
 						//突加突卸
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.SuddenCrease_Start_Addr, 1);						
 						control.sudden_crease = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.sudden_crease)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(control.sudden_crease)), socket);
 					}
 					
-					if(control.all_open >= CONTROL_ON) {
+					if(control.all_open >= CMD_Start) {
 						//全部分闸
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.AllOpenBreak_Start_Addr, 1);						
 						control.all_open = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.all_open)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(control.all_open)), socket);
 					}
 					
-					if(control.FZ_autostate1 >= CONTROL_ON) {
+					if(control.FZ_autostate1 >= CMD_Start) {
+						int code_value = CONTROL_OFF;
+						if(control.FZ_autostate1 == CMD_Start) {
+							code_value = CONTROL_ON;
+						}
 						//FZ自动状态1
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.AutoProcess1_Start_Addr, 1);						
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(code_value)), socket);
 						control.FZ_autostate1 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.FZ_autostate1)), socket);
 					}
 					
-					if(control.FZ_autostate2 >= CONTROL_ON) {
+					if(control.FZ_autostate2 >= CMD_Start) {
+						int code_value = CONTROL_OFF;
+						if(control.FZ_autostate2 == CMD_Start) {
+							code_value = CONTROL_ON;
+						}
 						//FZ自动状态2
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.AutoProcess2_Start_Addr, 1);						
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(code_value)), socket);
 						control.FZ_autostate2 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.FZ_autostate2)), socket);
 					}
 					
-					if(control.FZ_autostate3 >= CONTROL_ON) {
+					if(control.FZ_autostate3 >= CMD_Start) {
 						//FZ自动状态3
+						int code_value = CONTROL_OFF;
+						if(control.FZ_autostate3 == CMD_Start) {
+							code_value = CONTROL_ON;
+						}
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.AutoProcess3_Start_Addr, 1);						
 						control.FZ_autostate3 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.FZ_autostate3)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(code_value)), socket);
 					}
 					
-					if(control.FZ_autostate4 >= CONTROL_ON) {
+					if(control.FZ_autostate4 >= CMD_Start) {
 						//FZ自动状态4
+						int code_value = CONTROL_OFF;
+						if(control.FZ_autostate4 == CMD_Start) {
+							code_value = CONTROL_ON;
+						}
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.AutoProcess4_Start_Addr, 1);						
 						control.FZ_autostate4 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.FZ_autostate4)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(code_value)), socket);
 					}
 					
-					if(control.FZ_autostate5 >= CONTROL_ON) {
+					if(control.FZ_autostate5 >= CMD_Start) {
 						//FZ自动状态5
+						int code_value = CONTROL_OFF;
+						if(control.FZ_autostate5 == CMD_Start) {
+							code_value = CONTROL_ON;
+						}
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.AutoProcess5_Start_Addr, 1);						
 						control.FZ_autostate5 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.FZ_autostate5)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(code_value)), socket);
 					}
 					
-					if(control.local_control >= CONTROL_ON) {
+					if(control.local_control >= CMD_Start) {
 						//就地控制
+						int code_value = CONTROL_OFF;
+						if(control.local_control == CMD_Start) {
+							code_value = CONTROL_ON;
+						}
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.LocalControl_Start_Addr, 1);						
 						control.local_control = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.local_control)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(code_value)), socket);
 					}
 					
-					if(control.back_control >= CONTROL_ON) {
+					if(control.back_control >= CMD_Start) {
 						//后台控制
+						int code_value = CONTROL_OFF;
+						if(control.back_control == CMD_Start) {
+							code_value = CONTROL_ON;
+						}
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.BackControl_Start_Addr, 1);						
 						control.back_control = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.back_control)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(code_value)), socket);
 					}
 					
-					if(control.central_control >= CONTROL_ON) {
+					if(control.central_control >= CMD_Start) {
 						//中控控制
+						int code_value = CONTROL_OFF;
+						if(control.central_control == CMD_Start) {
+							code_value = CONTROL_ON;
+						}
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.CenterControl_Start_Addr, 1);						
 						control.central_control = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.central_control)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(code_value)), socket);
 					}
 					
-					if(control.inter_volume_M200 >= CONTROL_ON) {
+					if(control.inter_volume_M200 >= CMD_Start) {
 						//中控控制
+						int code_value = CONTROL_OFF;
+						if(control.inter_volume_M200 == CMD_Start) {
+							code_value = CONTROL_ON;
+						}
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.Middle_Start_Addr, 1);						
 						control.inter_volume_M200 = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.inter_volume_M200)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(code_value)), socket);
 					}
 					
-					if(control.fan_button >= CONTROL_ON) {
+					if(control.fan_button >= CMD_Start) {
 						//风机按钮
+						int code_value = CONTROL_OFF;
+						if(control.inter_volume_M200 == CMD_Start) {
+							code_value = CONTROL_ON;
+						}
 						basedata = new BaseData(Modbus_ComBase.WRITE_SINGLE_COIL, Modbus_ComBase.Fan_Button_Start_Addr, 1);						
 						control.fan_button = CONTROL_OFF;
-						SocketComm(basedata.createWiriteData(BaseData.createButtonByte(control.fan_button)), socket);
+						SocketComm(basedata.createSingleCollWiriteData(BaseData.createButtonByte(code_value)), socket);
 					}
 					
-					if(control.set_power >= CONTROL_ON) {
+					if(control.set_power >= CMD_Start) {
 						//设定功率
 						basedata = new BaseData(Modbus_ComBase.WRITE_MULTIPLE_REGISTER, Modbus_ComBase.SetPower_Start_Addr, 1);						
 						control.set_power = CONTROL_OFF;
 						SocketComm(basedata.createWiriteData(BaseData.createFloatByte(control.set_power)), socket);
 					}
+					//System.out.println(control);
 					PowerArk_ServerSocket_Thread_SQL.updateDynamicload_ControlTable(conn_pool, control);					
 				}
 				
@@ -325,7 +369,7 @@
 		        bytebuffer_for_socket_RX.clear();
 		        //--------------------- socket write -----------------------------------//
 		        //byte[] b = makeCommBuf(cmd, bf);
-		        System.err.println(ComFn.bytesToHexString(bytedata, bytedata.length));
+		        System.err.println("发送数据:"+ComFn.bytesToHexString(bytedata, bytedata.length));
 		        Date d1 = new Date();
 		      
 		        
@@ -361,7 +405,7 @@
 		        }
 		        byte[] buffer = new byte[bytebuffer_for_socket_RX.limit()];
 		        bytebuffer_for_socket_RX.get(buffer);
-		        System.err.println(ComFn.bytesToHexString(buffer, buffer.length));       
+		        System.err.println("接收数据"+ComFn.bytesToHexString(buffer, buffer.length));       
 		        if(true == getDataFromCommBuf(buffer)) {
 		        	connCount ++;
 		        	res_t = true;

--
Gitblit v1.9.1