This is a Modbus TCP example for Android.If You need the examples for RTU/ASCII ,You can call me.
ModbusFactory factory = new ModbusFactory();
IpParameters params = new IpParameters();
//Setting Ip Address and port
params.setHost("192.168.0.101");
params.setPort(502);
params.setEncapsulated(false);
//Create ModbusMaster and set timeout and retry count
ModbusMaster master = factory.createTcpMaster(params, true);
// master.setRetries(4);
master.setTimeout(2000);
master.setRetries(0);
master.init();
ModbusReq.readCoil(mModbusMaster, new OnRequestBack<boolean[]>() {
@Override
public void onSuccess(boolean[] booleen) {
Log.d(TAG, "readCoil onSuccess " + Arrays.toString(booleen));
}
@Override
public void onFailed(String msg) {
Log.e(TAG, "readCoil onFailed " + msg);
}
}, 1, 1, 2);
ModbusReq.readDiscreteInput(mModbusMaster, new OnRequestBack<boolean[]>() {
@Override
public void onSuccess(boolean[] booleen) {
Log.d(TAG, "readDiscreteInput onSuccess " + Arrays.toString(booleen));
}
@Override
public void onFailed(String msg) {
Log.e(TAG, "readDiscreteInput onFailed " + msg);
}
},1,1,5);
ModbusReq.readHoldingRegisters(mModbusMaster, new OnRequestBack<short[]>() {
@Override
public void onSuccess(short[] data) {
Log.d(TAG, "readHoldingRegisters onSuccess " + Arrays.toString(data));
}
@Override
public void onFailed(String msg) {
Log.e(TAG, "readHoldingRegisters onFailed " + msg);
}
}, 1, 2, 8);
ModbusReq.readInputRegisters(mModbusMaster, new OnRequestBack<short[]>() {
@Override
public void onSuccess(short[] data) {
Log.d(TAG, "readInputRegisters onSuccess " + Arrays.toString(data));
}
@Override
public void onFailed(String msg) {
Log.e(TAG, "readInputRegisters onFailed " + msg);
}
}, 1, 2, 8);
ModbusReq.writeCoil(mModbusMaster, new OnRequestBack<String>() {
@Override
public void onSuccess(String s) {
Log.e(TAG, "writeCoil onSuccess " + s);
}
@Override
public void onFailed(String msg) {
Log.e(TAG, "writeCoil onFailed " + msg);
}
},1,1,true);
ModbusReq.writeRegister(mModbusMaster, new OnRequestBack<String>() {
@Override
public void onSuccess(String s) {
Log.e(TAG, "writeRegister onSuccess " + s);
}
@Override
public void onFailed(String msg) {
Log.e(TAG, "writeRegister onFailed " + msg);
}
},1,1,234);
ModbusReq.writeRegisters(mModbusMaster, new OnRequestBack<String>() {
@Override
public void onSuccess(String s) {
Log.e(TAG, "writeRegisters onSuccess " + s);
}
@Override
public void onFailed(String msg) {
Log.e(TAG, "writeRegisters onFailed " + msg);
}
},1,2,new short[]{211,52,34});
master.destroy();
You have any questions to send email to me.Thanks.
- e-mail : [email protected]
- gmail : [email protected]