This commit is contained in:
misty 2018-06-20 00:16:57 +02:00
parent 2c016376e4
commit eaf73d067e
4 changed files with 143 additions and 21 deletions

View File

@ -7,17 +7,18 @@ import com.ghgande.j2mod.modbus.net.TCPMasterConnection;
import java.net.InetAddress; import java.net.InetAddress;
import java.net.UnknownHostException; import java.net.UnknownHostException;
import java.util.HashMap;
public class GlobalState extends Application { public class GlobalState extends Application {
// coil
private String ipAddress = "192.168.157.16"; private String ipAddress = "192.168.157.16";
private int port = 503; private int port = 503;
private HashMap<Integer, Integer> mapMappingValue = new HashMap<Integer, Integer>();
// //
public enum InputConfig { public enum InputConfig {
Q_COIL(8192, 8), Q_COIL(8192, 8),
VM_COIL2 (1, 8), VM_COIL2 (1, 8),
VM_COIL3 (65, 8), VM_COIL3 (64, 8),
AI_IR(0, 2), AI_IR(0, 2),
I_DI(0, 12); I_DI(0, 12);
@ -40,6 +41,11 @@ public class GlobalState extends Application {
} }
} }
public HashMap<Integer, Integer> getMapMappingValue() {
initMappingValue();
return mapMappingValue;
}
// getter/setter // getter/setter
public String getIpAddress() { public String getIpAddress() {
return ipAddress; return ipAddress;
@ -56,4 +62,16 @@ public class GlobalState extends Application {
public void setPort(int port) { public void setPort(int port) {
this.port = port; this.port = port;
} }
private void initMappingValue () {
mapMappingValue.clear();
mapMappingValue.put(InputConfig.VM_COIL3.getStartReference(), InputConfig.Q_COIL.getStartReference()); // 64/8192
mapMappingValue.put(InputConfig.VM_COIL3.getStartReference() + 6, InputConfig.Q_COIL.getStartReference() + 1); // 70/8193
mapMappingValue.put(InputConfig.VM_COIL3.getStartReference() + 1, InputConfig.Q_COIL.getStartReference() + 4); // 65/8196
mapMappingValue.put(InputConfig.VM_COIL3.getStartReference() + 7, InputConfig.Q_COIL.getStartReference() + 5); // 71/8197
mapMappingValue.put(InputConfig.VM_COIL3.getStartReference() + 4, InputConfig.Q_COIL.getStartReference() + 6); // 68/8198
mapMappingValue.put(InputConfig.VM_COIL3.getStartReference() + 5, InputConfig.Q_COIL.getStartReference() + 7); // 69/8199
mapMappingValue.put(InputConfig.VM_COIL3.getStartReference() + 2, InputConfig.Q_COIL.getStartReference() + 2); // 66/8194
mapMappingValue.put(InputConfig.VM_COIL3.getStartReference() + 3, InputConfig.Q_COIL.getStartReference() + 3); // 67/8195
}
} }

View File

@ -5,36 +5,62 @@ import android.content.Context;
import android.content.Intent; import android.content.Intent;
import android.content.IntentFilter; import android.content.IntentFilter;
import android.os.Handler; import android.os.Handler;
import android.support.annotation.Nullable;
import android.support.v4.content.LocalBroadcastManager; import android.support.v4.content.LocalBroadcastManager;
import android.support.v7.app.AppCompatActivity; import android.support.v7.app.AppCompatActivity;
import android.os.Bundle; import android.os.Bundle;
import android.view.MotionEvent;
import android.view.View; import android.view.View;
import android.widget.Button;
import android.widget.CompoundButton; import android.widget.CompoundButton;
import android.widget.ImageView; import android.widget.ImageView;
import android.widget.ToggleButton; import android.widget.ToggleButton;
import java.util.HashMap;
import java.util.Map;
public class ManualDriveActivity extends AppCompatActivity { public class ManualDriveActivity extends AppCompatActivity {
private GlobalState state; private GlobalState state;
private Handler coilHandler; private Handler coilHandler;
private HashMap<Integer, Boolean> mapCoilCheckStatus = new HashMap <> ();
private boolean manualMode = false;
private void initMap () {
mapCoilCheckStatus.put(65, false);
mapCoilCheckStatus.put(71, false);
mapCoilCheckStatus.put(66, false);
mapCoilCheckStatus.put(72, false);
mapCoilCheckStatus.put(69, false);
mapCoilCheckStatus.put(70, false);
mapCoilCheckStatus.put(67, false);
mapCoilCheckStatus.put(68, false);
}
@Override @Override
protected void onCreate(Bundle savedInstanceState) { protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
LocalBroadcastManager.getInstance(this).registerReceiver(coilWriterMessageReceiver, new IntentFilter("readVmCoil2"));
LocalBroadcastManager.getInstance(this).registerReceiver(coilWriterMessageReceiver, new IntentFilter("checkCoilValue"));
state = (GlobalState) getApplicationContext(); state = (GlobalState) getApplicationContext();
initMap(); // initialise the value of the coil toggle state
coilHandler = new Handler();
// coilHandler.post(refreshCoil);
setContentView(R.layout.activity_manual_drive); setContentView(R.layout.activity_manual_drive);
ToggleButton button = (ToggleButton) findViewById(R.id.manual_override_button); ToggleButton h1ControlButton = (ToggleButton) findViewById(R.id.h1_control_button);
button.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() { ToggleButton h2ControlButton = (ToggleButton) findViewById(R.id.h2_control_button);
Button pu1ControlButton = (Button) findViewById(R.id.pu1_control_button);
Button pu2ControlButton = (Button) findViewById(R.id.pu2_control_button);
Button sp1ControlButton = (Button) findViewById(R.id.sp1_control_button);
Button b1ControlButton = (Button) findViewById(R.id.b1_control_button);
ToggleButton m1ControlButton = (ToggleButton) findViewById(R.id.m1_control_button);
ToggleButton m2ControlButton = (ToggleButton) findViewById(R.id.m2_control_button);
LocalBroadcastManager.getInstance(this).registerReceiver(coilWriterMessageReceiver, new IntentFilter("readVmCoil2"));
// LocalBroadcastManager.getInstance(this).registerReceiver(coilWriterMessageReceiver, new IntentFilter("checkCoilValue"));
// manual drive button
ToggleButton manualDriveOverrideButton = (ToggleButton) findViewById(R.id.manual_override_button);
manualDriveOverrideButton.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override @Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
if (isChecked) { if (isChecked) {
@ -46,6 +72,7 @@ public class ManualDriveActivity extends AppCompatActivity {
serviceIntent.putExtra("extra.ref", GlobalState.InputConfig.VM_COIL2.getStartReference()); serviceIntent.putExtra("extra.ref", GlobalState.InputConfig.VM_COIL2.getStartReference());
serviceIntent.putExtra("extra.bit", true); serviceIntent.putExtra("extra.bit", true);
serviceIntent.putExtra("extra.intent.name", "readVmCoil2"); serviceIntent.putExtra("extra.intent.name", "readVmCoil2");
serviceIntent.putExtra("extra.is.basic.coil", false);
getApplicationContext().startService(serviceIntent); getApplicationContext().startService(serviceIntent);
} else { } else {
// writing the value false // writing the value false
@ -56,10 +83,51 @@ public class ManualDriveActivity extends AppCompatActivity {
serviceIntent.putExtra("extra.ref", GlobalState.InputConfig.VM_COIL2.getStartReference()); serviceIntent.putExtra("extra.ref", GlobalState.InputConfig.VM_COIL2.getStartReference());
serviceIntent.putExtra("extra.bit", false); serviceIntent.putExtra("extra.bit", false);
serviceIntent.putExtra("extra.intent.name", "readVmCoil2"); serviceIntent.putExtra("extra.intent.name", "readVmCoil2");
serviceIntent.putExtra("extra.is.basic.coil", false);
getApplicationContext().startService(serviceIntent); getApplicationContext().startService(serviceIntent);
} }
} }
}); });
//TODO refactoring starting from here !!
// button h1
h1ControlButton.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
if (isChecked) {
// writing the value true
Intent serviceIntent = new Intent(getApplicationContext(), MyIntentService.class);
serviceIntent.setAction("write.coil");
serviceIntent.putExtra("extra.ip.address", state.getIpAddress());
serviceIntent.putExtra("extra.ip.port", state.getPort());
serviceIntent.putExtra("extra.ref", 64);
serviceIntent.putExtra("extra.bit", true);
serviceIntent.putExtra("extra.intent.name", "writeBit65");
serviceIntent.putExtra("extra.is.basic.coil", true);
getApplicationContext().startService(serviceIntent);
mapCoilCheckStatus.put(64, true);
} else {
// writing the value false
Intent serviceIntent = new Intent(getApplicationContext(), MyIntentService.class);
serviceIntent.setAction("write.coil");
serviceIntent.putExtra("extra.ip.address", state.getIpAddress());
serviceIntent.putExtra("extra.ip.port", state.getPort());
serviceIntent.putExtra("extra.ref", 64);
serviceIntent.putExtra("extra.bit", false);
serviceIntent.putExtra("extra.intent.name", "writeBit65");
serviceIntent.putExtra("extra.is.basic.coil", true);
getApplicationContext().startService(serviceIntent);
mapCoilCheckStatus.put(64, false);
}
}
});
}
@Override
protected void onStart () {
super.onStart();
coilHandler = new Handler();
coilHandler.post(refreshCoil);
} }
private BroadcastReceiver coilWriterMessageReceiver = new BroadcastReceiver() { private BroadcastReceiver coilWriterMessageReceiver = new BroadcastReceiver() {
@ -71,13 +139,41 @@ public class ManualDriveActivity extends AppCompatActivity {
ImageView lightOn = (ImageView) findViewById(R.id.manual_override_status_light_on); ImageView lightOn = (ImageView) findViewById(R.id.manual_override_status_light_on);
ImageView lightOff = (ImageView) findViewById(R.id.manual_override_status_light_on); ImageView lightOff = (ImageView) findViewById(R.id.manual_override_status_light_on);
System.out.print("value "+supposedToBeValue);
if (supposedToBeValue) { if (supposedToBeValue) {
manualMode = true;
lightOn.setVisibility(View.VISIBLE); lightOn.setVisibility(View.VISIBLE);
lightOff.setVisibility(View.INVISIBLE); lightOff.setVisibility(View.INVISIBLE);
} else { } else {
manualMode = false;
lightOn.setVisibility(View.INVISIBLE); lightOn.setVisibility(View.INVISIBLE);
lightOff.setVisibility(View.VISIBLE); lightOff.setVisibility(View.VISIBLE);
} }
} }
}; };
Runnable refreshCoil = new Runnable() {
@Override
public void run() {
System.out.println("pass "+manualMode);
if (manualMode) {
for (Map.Entry<Integer, Boolean> entry : mapCoilCheckStatus.entrySet()) {
System.out.println("entry : " + entry.getKey() + " value :" + entry.getValue());
if (entry.getValue() == true) { // if the thing is toggle
Intent serviceIntent = new Intent(getApplicationContext(), MyIntentService.class);
serviceIntent.setAction("read.coil");
serviceIntent.putExtra("extra.ip.address", state.getIpAddress());
serviceIntent.putExtra("extra.ip.port", state.getPort());
serviceIntent.putExtra("extra.ref", state.getMapMappingValue().get(entry.getKey()));
serviceIntent.putExtra("extra.count", 1);
serviceIntent.putExtra("extra.intent.name", "readOnlyCoil");
getApplicationContext().startService(serviceIntent);
}
}
}
coilHandler.postDelayed(this, 2000);
}
};
} }

View File

@ -127,28 +127,36 @@ public class MyIntentService extends IntentService {
} }
} }
public void writeCoilAction (String ipAddress, int port, int ref, boolean value, String intentReceiveName) { public void writeCoilAction (String ipAddress, int port, int ref, boolean value, String intentReceiveName, boolean withCheck) {
try { try {
master = new ModbusTCPMaster(ipAddress, port); master = new ModbusTCPMaster(ipAddress, port);
master.connect(); master.connect();
// writing the value // writing the value
boolean expectedValue = master.writeCoil(ref, value); boolean writtenValue = master.writeCoil(ref, value);
System.out.println("I wrote "+expectedValue+" to coil "+ref); if (withCheck) {
System.out.println("I wrote " + writtenValue + " to coil " + ref);
Thread.sleep(CAP_WAIT_TIME); Thread.sleep(CAP_WAIT_TIME);
boolean currentValue = master.readCoils(8192, 1).getBit(0); GlobalState state = (GlobalState) getApplicationContext();
sendNewBitValueToActivity (currentValue, intentReceiveName);
int coilToRead = state.getMapMappingValue().get(ref);
System.out.println("Checking the value of coil "+coilToRead);
boolean currentValue = master.readCoils(coilToRead, 1).getBit(0);
sendNewBitValueToActivity(currentValue, intentReceiveName);
} else {
System.out.println("I switched the manual mode to " + writtenValue);
sendNewBitValueToActivity(writtenValue, intentReceiveName);
}
Thread.sleep(CAP_WAIT_TIME); Thread.sleep(CAP_WAIT_TIME);
master.disconnect(); master.disconnect();
} catch (Exception e) { } catch (Exception e) {
System.out.println("Exception in reading coil " + e); System.out.println("Exception in writing coil " + e);
} }
} }
private void sendNewBitValueToActivity (boolean newValue, String intentReceive) { private void sendNewBitValueToActivity (boolean newValue, String intentReceive) {
Intent intent = new Intent(intentReceive); Intent intent = new Intent(intentReceive);
System.out.println("here "+newValue);
intent.putExtra("coil", newValue); intent.putExtra("coil", newValue);
sendLocationBroadcast(intent); sendLocationBroadcast(intent);
} }
@ -166,7 +174,7 @@ public class MyIntentService extends IntentService {
// for write // for write
final Boolean value = intent.getBooleanExtra(EXTRA_BIT_TO_SET, false); final Boolean value = intent.getBooleanExtra(EXTRA_BIT_TO_SET, false);
final Boolean expectedValue = intent.getBooleanExtra("extra.coil.status", false); final Boolean withCheck = intent.getBooleanExtra("extra.is.basic.coil", false);
switch(action) { switch(action) {
case ACTION_READ_DISCRETE_INPUT: case ACTION_READ_DISCRETE_INPUT:
@ -179,7 +187,7 @@ public class MyIntentService extends IntentService {
readInputRegisterAction (ipAddress, port,ref, count, intentName); readInputRegisterAction (ipAddress, port,ref, count, intentName);
break; break;
case ACTION_WRITE_COIL: case ACTION_WRITE_COIL:
writeCoilAction(ipAddress, port, ref, value, intentName); writeCoilAction(ipAddress, port, ref, value, intentName, withCheck);
break; break;
} }
} }

Binary file not shown.