Fix ANR, optimize write delay
This commit is contained in:
parent
e9964604a1
commit
3ffb78a7e8
2 changed files with 7 additions and 5 deletions
|
@ -72,7 +72,7 @@ class BLEComm @Inject internal constructor(
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
|
|
||||||
private const val WRITE_DELAY_MILLIS: Long = 100
|
private const val WRITE_DELAY_MILLIS: Long = 10
|
||||||
private const val SERVICE_UUID = "669A9001-0008-968F-E311-6050405558B3"
|
private const val SERVICE_UUID = "669A9001-0008-968F-E311-6050405558B3"
|
||||||
private const val READ_UUID = "669a9120-0008-968f-e311-6050405558b3"
|
private const val READ_UUID = "669a9120-0008-968f-e311-6050405558b3"
|
||||||
private const val WRITE_UUID = "669a9101-0008-968f-e311-6050405558b3"
|
private const val WRITE_UUID = "669a9101-0008-968f-e311-6050405558b3"
|
||||||
|
@ -455,11 +455,13 @@ class BLEComm @Inject internal constructor(
|
||||||
} else {
|
} else {
|
||||||
characteristic.value = data
|
characteristic.value = data
|
||||||
characteristic.writeType = BluetoothGattCharacteristic.WRITE_TYPE_DEFAULT
|
characteristic.writeType = BluetoothGattCharacteristic.WRITE_TYPE_DEFAULT
|
||||||
aapsLogger.debug(LTag.PUMPBTCOMM, "writeCharacteristic:" + Arrays.toString(data))
|
aapsLogger.debug(LTag.PUMPBTCOMM, "writeCharacteristic: ${Arrays.toString(data)}")
|
||||||
mBluetoothGatt?.writeCharacteristic(characteristic)
|
val success = mBluetoothGatt?.writeCharacteristic(characteristic)
|
||||||
|
if (success != true) {
|
||||||
|
mCallback?.onSendMessageError("Failed to write characteristic")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}, WRITE_DELAY_MILLIS)
|
}, WRITE_DELAY_MILLIS)
|
||||||
SystemClock.sleep(WRITE_DELAY_MILLIS)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private val uartWriteBTGattChar: BluetoothGattCharacteristic
|
private val uartWriteBTGattChar: BluetoothGattCharacteristic
|
||||||
|
|
|
@ -92,7 +92,7 @@ class MedtrumService : DaggerService(), BLECommCallback {
|
||||||
private var currentState: State = IdleState()
|
private var currentState: State = IdleState()
|
||||||
private var mPacket: MedtrumPacket? = null
|
private var mPacket: MedtrumPacket? = null
|
||||||
|
|
||||||
private val scope = CoroutineScope(SupervisorJob() + Dispatchers.Main.immediate)
|
private val scope = CoroutineScope(Dispatchers.Default)
|
||||||
|
|
||||||
val isConnected: Boolean
|
val isConnected: Boolean
|
||||||
get() = medtrumPump.connectionState == ConnectionState.CONNECTED
|
get() = medtrumPump.connectionState == ConnectionState.CONNECTED
|
||||||
|
|
Loading…
Add table
Reference in a new issue