【開發問題】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)即可。稍微有點坑。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章