一些麻煩事兒
藍牙設備比較多會把手機卡死,公司能掃描到200+個設備,直接把iphone5S的微信卡死了。
每次硬件操作之間一定加延遲,建議100ms,例如“打開藍牙”與“開始掃描”間,“連接成功”與“獲取服務”等等之類。不使用延遲可能會出現莫名其妙的錯誤,多見于Android端。
注意JS的異步、并發特性,特別在輪詢service下的characteristic。小程序還不支持async,await(代碼補全中有這兩個關鍵字,但是編譯不過)。
藍牙的數據讀寫、advertisData的類型是ArrayBuffer,(引用小程序的注意:vConsole 無法打印出 ArrayBuffer 類型數據)。鞋童們請先把二進制數組、十六進制字符串弄明白吧,代碼中有轉換的方法(復制自github)。
初始化藍牙適配器(wx.openBluetoothAdapter(OBJECT))、獲取本機藍牙適配器狀態(wx.getBluetoothAdapterState(OBJECT)),這兩個函數那個先調用不好說,自己玩吧,見下說明。
一些BUG
1、藍牙在掃描過程中,獲取本機藍牙適配器狀態(wx.getBluetoothAdapterState(OBJECT))。(Android獨有,華為榮耀8、VIVO 7plus,6.5.13)
available\Boolean\藍牙適配器是否可用,值為true。
discovering\Boolean\是否正在搜索設備,值為false。
https://github.com/FFiot/WX_Bluetooth/issues/1
2、藍牙在掃描過程中,再次啟動掃描wx.startBluetoothDevicesDiscovery(OBJECT):fail,errCode=10008。(Android獨有,華為榮耀8、VIVO 7plus,6.5.13)BUG:藍牙掃描中查詢藍牙狀態 · Issue #1 · FFiot/WX_Bluetoothgithub.com藍牙在掃描過程中,再次啟動掃描wx.startBluetoothDevicesDiscovery(OBJECT):fail,errCode=10008。(Android獨有,華為榮耀8、VIVO 7plus,6.5.13)
https://github.com/FFiot/WX_Bluetooth/issues/2
errorCode與errMsg混在一起。(IOS獨有,IPHONE5s,微信6.5.15)
https://github.com/FFiot/WX_Bluetooth/issues/3
3、藍牙在掃描service下character時,如果有多個service,只能正常獲取第一個service下的character,其余service獲取的chara與第一個service相同。(IOS獨有,IPHONE5s,微信6.5.15)
移動設備藍牙開啟\關閉用兩種狀態,觸發wx.onBluetoothAdapterStateChange回調
1、wx.getBluetoothAdapterState(OBJECT)
關閉狀態返回:drrCode:10000,errMsg:"getBluetoothAdapterState:fail"。此時開啟藍牙: wx.onBluetoothAdapterStateChange(CALLBACK)無回調。
開啟狀態返回:drrCode:10000,errMsg:"getBluetoothAdapterState:fail"。此時關閉藍牙: wx.onBluetoothAdapterStateChange(CALLBACK)無回調。
2、wx.getBluetoothAdapterState(OBJECT)
關閉狀態返回:drrCode:10001,errMsg:"openBluetoothAdapter:fail"。此時開啟藍牙:wx.onBluetoothAdapterStateChange(CALLBACK)有回調。
開啟狀態返回:errMsg:"openBluetoothAdapter:ok"。此時開啟藍牙:wx.onBluetoothAdapterStateChange(CALLBACK)有回調。
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com