【开发问题】usb-serial-for-android

程序重启后无法再次读取USB设备

  • 插入USB设备,程序运行,一切正常。关闭程序再次打开,设备与端口皆可获取,直到Port.open(connection)出错
  • 使用的是RK3188 5.1系统
  • 传感器为体温传感器,使用此开源CH34转USB
/MainActivity: connection: android.hardware.usb.UsbDeviceConnection@3b3b49f1
/UsbDeviceConnectionJNI: close
/MainActivity: 打开端口失败

java.io.IOException: Expected 0xff bytes, but get 0x9f [init #6]
    at com.hoho.android.usbserial.driver.Ch34xSerialDriver$Ch340SerialPort.checkState(Ch34xSerialDriver.java:158)
    at com.hoho.android.usbserial.driver.Ch34xSerialDriver$Ch340SerialPort.initialize(Ch34xSerialDriver.java:184)
    at com.hoho.android.usbserial.driver.Ch34xSerialDriver$Ch340SerialPort.openInt(Ch34xSerialDriver.java:113)
    at com.hoho.android.usbserial.driver.CommonUsbSerialPort.open(CommonUsbSerialPort.java:116)
    at com.example.tempermodular.TemperMoudle$1.onReceive(TemperMoudle.java:103)
    at android.app.LoadedApk$ReceiverDispatcher$Args.run(LoadedApk.java:866)
    at android.os.Handler.handleCallback(Handler.java:739)
    at android.os.Handler.dispatchMessage(Handler.java:95)
    at android.os.Looper.loop(Looper.java:135)
    at android.app.ActivityThread.main(ActivityThread.java:5258)
    at java.lang.reflect.Method.invoke(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:372)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:940)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:735)
  • 下载了GITHUB上代码运行后,也是一样的问题。

解答

  • 由于我的传感器接收数据时用到了setRTS(true),这会导致此类问题,所以只需要在关闭Port之前首先setRTS(false)即可。稍微有点坑。

猜你喜欢

转载自blog.csdn.net/qq_36881363/article/details/104861952