久久婷久久-久久婷婷丁香欧美-久久婷婷国产-久久婷婷国产麻豆91-久久婷婷激情-久久婷婷精品

歡迎光臨~深圳市山星盛電子科技有限公司-稱重產品官方展示網站
服務熱線 全國服務熱線:

0755-2979 1990

公司新聞

微信WEIXIN小程序中連接藍牙電子秤(電子稱品牌:Mount star山星盛),直接通過藍牙獲取當前稱重的重量數據,然后顯示在界面上

微信小程序低功率電子秤及稱重產品的程序開發,電子磅秤的非標定制使用方法和技術指導,云服務器代碼說明,APP/APK/小程序簡單功能開發訂做,直接WIFI及4G/5G移動數據直接上傳。

深圳市山星盛電子科技有限公司隨著物聯網的興起,催生了越來越多的軟件與設備的對接開發需求。隨著用戶從APP到微信公眾號再到微信小程序的遷移,小程序憑借開發簡單,應用方便的優勢成為了物聯網開發軟件的首選。

2018年初至今,越來越多的客戶咨詢我們進行軟件與設備對接的開發。客戶來源于各行各業,需求也不盡相同。下面我們將為客戶分析部分微信小程序與設備開發案例,希望給后續有開發需求的客戶帶來一定的幫助。


1、微信小程序與電子秤的對接

如今電子秤的應用越來越普及,用戶在稱重時可以快速讀取電子秤的數據,應用領域有礦業,牛奶,機械加工等。但是高頻地讀取和記錄數據容易形成造成時間的浪費,同時容易產生錯誤,因此不少用戶尋求更加高效的解決方案。解決方案之一就是微信小程序與電子秤的對接開發,開發者基于有數據接口的電子秤開發微信小程序的對接應用。不但能通過藍牙或網絡的方式獲取數據,還能通過微信小程序后臺輕松管理數據,一鍵發送數據,大大提高了電子秤作業的效率和數據正確率。

2、相關小程序代碼說明

微信小程序連接藍牙電子秤

前情:在微信小程序中連接藍牙電子計重桌秤(電子秤品牌:Mount star山星盛),直接通過藍牙獲取當前稱重的重量數據,然后顯示在界面上。

###??注意 * 此次,只涉及讀取數據,沒有寫入數據,具體 API 查看小程序官方文檔 * 確保手機藍牙已經打開,并且可以搜索到該電子秤的藍牙設備,android 可以搜到,ios 搜不到 --- 但是沒有關系,小程序里 getBluetoothDevices 可以成功就可以了 * 微信小程序中搜索到的藍牙設備很多,deviceId 在 android 上顯示為藍牙設備主服務的 mac 地址,在 ios 上顯示為藍牙設備主服務的 uuid * 最終得到的結果是 ArrayBuffer 型數據,需要先轉為16進制字符串,再轉為10進制數據 --- 小程序官方文檔上這樣提示,實際并不可行

(1)初始化

初始化藍牙模塊 --- wx.openBluetoothAdapter

// 定義數據data: {    devices: [],    // 搜索到的藍牙設備 deviceId 數組
    deviceId: '',    // 目標藍牙設備 deviceId
    services: []    //  設備服務列表 serviceId 數組
    serviceId: '',    characteristics: []   // 特征值列表
    characteristicId: ''  // 選擇某一個特征值 
    value: ''   // 16 進制數據值}// 藍牙 API 調用步驟openBluetoothAdapter() {
    wx.openBluetoothAdapter({   // (1)
        success: res => {            console.log('openBluetoothAdapter初始化藍牙模塊成功:', res)             this.startBluetoothDevicesDiscovery()  // (2) 開始搜索
        },        fail: err => {            console.log('openBluetoothAdapter初始化藍牙模塊失敗:', err)            if (err.errCode === 10001) {  // 當前藍牙適配器不可用
                wx.onBluetoothAdapterStateChange( res => {                    if (res.available) {                        this.startBluetoothDevicesDiscovery()
                    }
              })
           }            /* 
            wx.onBluetoothAdapterStateChange({
                success: res => {
                  console.log('onBlueToothAdapterStateChange success 監聽藍牙適配器變化: ', res);
                  this.startBluetoothDevicesDiscovery();
                },
                fail: err => {
                     console.log('onBlueToothAdapterStateChange fail: ', err)
                 }
            })
            */
        }
    })
}


###(2)搜索藍牙設備 ####搜尋附近的藍牙外圍設備 --- wx.startBluetoothDevicesDiscovery * 入參 services 作用要搜索的藍牙設備主 service 的 uuid 列表,某些藍牙設備會廣播自己的主 service 的 uuid,如果設置此參數,則只搜索廣播包括對應 uuid 的主服務的藍牙設備,可以通過該參數過濾掉周邊不需要處理的其他藍牙設備 * 入參 allowDuplicatesKey 作用是否允許重復上報同一設備,如果允許重復上報,則 wx.onBlueToothDeviceFound 方法會多次上報同一設備,但是 RSSI 值會有不同,默認為 false eg: services: ['FEE7'] 主服務的 UUID 是 FEE7,傳入這個參數,只搜索主服務 UUID 為 FEE7 的設備,該設備是微信硬件平臺的藍牙智能燈

?? 此操作比較耗費系統資源,需要在搜索并連接到設備后調用 wx.stopBluetoothDevicesDiscovery 方法停止搜索

startBluetoothDevicesDiscovery() {
    wx.startBluetoothDevicesDiscovery({        success: res => {            console.log('startBluetoothDevicesDiscovery開始搜索外圍設備成功:', res)            this.getBluetoothDevices()  // (3) 獲取藍牙列表
         },        fail: err => {            console.log('startBluetoothDevicesDiscovery搜索外圍設備失敗:', err)
        }
    })
}


###(3)獲取藍牙設備 ####獲取在藍牙模塊生效期間所有已發現的藍牙設備,包括已經連接成功的藍牙設備 --- wx.getBluetoothDevices ``` getBluetoothDevices() { wx.getBluetoothDevices({ success: res => { console.log('getBluetoothDevices獲取藍牙設備成功:', res) this.setData({ devices: res. devices || [] // uuid 對應的的已連接設備列表 }) this.createBLEConnection(); // (4) 與目標設備建立連接 }, fail: err => { console.log('getBluetoothDevices獲取藍牙設備失敗:', err) } }) } ``` ####這里還可以用 wx.onBluetoothDeviceFound(),但是相較于 wx.getBluetoothDevices(),這個只會監聽尋找新設備,因而在一次編譯中,不方便同一個藍牙設備的復用 ``` // 監聽尋找新設備 onBluetoothDeviceFound() { let that = this; wx.onBluetoothDeviceFound(res => { console.log('onBluetoothDeviceFound success 監聽尋找新設備: ', res); (res.devices || []).forEach(item => { if(item.name == 'KunHong') { that.setData({ deviceId: item.deviceId || '' }) that.createBLEConnection(that.data.deviceId); } }) }) }, ```
###(4)建立連接 ####與目標藍牙設備建立連接,需要是低功耗藍牙設備 --- wx.createBLEConnection ?? 如果微信小程序此前搜索過某個藍牙設備,并成功建立連接,可直接傳入之前搜索獲取的 deviceId 直接嘗試連接該設備,不用重新搜索 ``` createBLEConnection() { // 如果是第一次建立連接,可以通過名稱匹配,獲取相應設備的 deviceId let devices = this.data.devices; devices.forEach(item => { if(item.name == 'kunHong') { this.setData({ deviceId: item.deviceId }) } }) // 建立連接 wx.createBLEConnection({ deviceId: this.data.deviceId, success: res => { console.log('createBLEConnection與目標藍牙連接成功:', res) this.getBLEDeviceServices() // (5)獲取服務 }, fail: err => { console.log('createBLEConnection與目標藍牙連接失敗:', err) } }) } ```
###(5)獲取藍牙設備服務 ####獲取藍牙設備所有主服務的 uuid --- wx.getBLEDeviceServices * 入參 deviceId 為 wx.getBluetoothDevices 中獲取的目標藍牙設備的 deviceId

??開發過程中,主服務 serviceId 和 主服務的特征值 characteristics 都是選取的實際操作過程中,得到的類似于該目標藍牙設備的 id,但是小程序官方文檔的 demo,遍歷了所有的列表(serviceId 和 characteristics),需要區分一下

getBLEDeviceServices() {
    wx.getBLEDeviceServices({        deviceId: this.data.deviceId,        success: res => {            console.log('getBLEDeviceServices獲取藍牙設備服務', res)            // getBluetoothDevices 獲取的有 deviceId 和 advertisServiceUUIDs,可以在這里獲取的服務列表中選擇一個一樣的作為后續 API 請求的服務id,這個 id 需要滿足是否可讀
            this.setData({                 services: res.services,                 serviceId: res.services[0].uuid    // 假設是第一個
            })            this.getBLEDeviceCharacteristics()    // (6) 獲取特征值

            // 官方 demo
            for(var i = 0; i < res.services.length; i++) {                // 該服務是否為主服務
                if(res.services[i].isPrimary) {                    this.getBLEDeviceCharacteristics(res.services[i].uuid)
                }
            }
        },        fail: err => {            console.log('getBLEDeviceServices獲取藍牙設備服務失敗:', err)
        }
    })
}


###(6)獲取特征值 ####獲取藍牙設備某個服務中所有特征值 --- wx.getBLEDeviceCharacteristics * 入參 deviceId 為 wx.getBluetoothDevices 中獲取的目標藍牙設備的 deviceId * 入參 serviceId 為藍牙服務 uuid ,通過 wx.getBLEDeviceServices 獲取 ``` getBLEDeviceCharacteristics(serviceId) { wx.getBLEDeviceCharacteristics({ deviceId: this.data.deviceId, serviceId: this.data.serviceId, success: res => { console.log('getBLEDeviceCharacteristics獲取藍牙服務特征值成功:', res) this.setData({ characteristics: res. characteristics, characteristics: res. characteristics[0].uuid }) (res.characteristics || []).forEach(item => { if(item.properties.read) { wx.readBLECharacteristicValue({ deviceId: this.data.deviceId, serviceId: serviceid, characteristicId: res.characteristicId[i].uuid }) } if(item.properties.notify || item.properties.indicate) { // 開啟通知 wx.notifyBLECharacteristicValueChange({ state: true, deviceId, serviceId, characteristicId: item.uuid, success(res) { console.log('notifyBLECharacteristicValueChange success state: ', res.errMsg) that.setData({ notifyFlag: true }) } }) } }) }, fail: err => { console.log('getBLEDeviceCharacteristics獲取藍牙服務特征值失敗:', err) } }) this.onBLECharacteristicValueChange() // (8)監聽特征值變化 } ```
###(7)啟用 notify 功能 ####啟用低功耗藍牙特征值變化時的 notify 功能,訂閱特征值 ??必須設備的特征值支持 notify 或者 indicate 才可以成功啟用 ``` notifyBLECharacteristicValueChange() { wx.notifyBLECharacteristicValueChange({ deviceId: this.data.deviceId, serviceId: this.data.serviceId, characteristicId: this.data. characteristicId, state: true // 是否啟用 notify (四個字段全部必填) }) } ```
###(8)監聽特征值變化 ####監聽低功耗藍牙設備特征值的變化事件 --- wx.onBLECharacteristicValueChange ??必須先啟用 notifyBLECharacteristicValueChange 接口才能接收到設備推送的 notification(通知) ``` // 先監聽一下,保證第一時間獲取數據 onBLECharacteristicValueChange() { wx.onBLECharacteristicValueChange( characteristic => { console.log('onBLECharacteristicValueChange從目標藍牙設備監聽到的數據值:', characteristic) this.setData({ value: this.ab2hex(characteristic.value) // (10) 轉為 16 進制 })

    //     獲取最終結果 監聽值是否發生變化,變化時獲取最新值 避免一直監聽,數據改變量較大
    let result = (this.ab2Str(characteristic.value) || '').split(' ').reverse()[1];    if(this.data.weight == result) {       return;
    } else {        this.setData({
          weight: result,
        })
      }
})

}

<br>###(9)讀取數據####讀取低功耗藍牙設備的特征值的二進制數據值 --- wx.readBLECharacteristicValue??必須目標藍牙設備的特征值支持 read 才可以成功調用,并且單獨使用 readBLECharacteristicValue 并不能獲取到真正的特征值,只能返回獲取特征值的狀態,即是否成功獲取到值,真正的值需要使用 wx.onBLECharacteristicValueChange() 執行回調才可以在 wx.onBLECharacteristicValueChange() 這個 API 中獲得讀取到的特征值

readBLECharacteristicValue() {
wx.readBLECharacteristicValue({
deviceId: this.data.deviceId,
serviceId: this.data.serviceId,
characteristicId: this.data.charecteristicId,
success: res => {
console.log('readBLECharacteristicValue讀取特征值成功:', res)
},
fail: err => {
console.log('readBLECharacteristicValue讀取特征值失敗:', err)
}
})
}

<br>###(10)轉為 16 進制####官方文檔中介紹了 ArrayBuffer 轉為 16 進制的方法

// ArrayBuffer轉16進制字符串示例
ab2hex(buffer) {
let hexArr = Array.prototype.map.call(
new Uint8Array(buffer),
function(bit) {
return ('00' + bit.toString(16)).slice(-2)
}
)
return hexArr.join('');
}

<br>###(11)值轉換####官方文檔介紹的方法似乎有點不適用哎,試下這個

ab2Str(arrayBuffer){
let unit8Arr = new Uint8Array(arrayBuffer);
let encodedString = String.fromCharCode.apply(null, unit8Arr);
return encodedString;
}


微信小程序藍牙模塊

藍牙部分知識

  • 關于Service:

每個設備包含有多個Service,每個Service對應一個uuid

  • 關于Characteristic

每個Service包含多個Characteristic,每個Characteristic對應一個uuid

  • 如何得到數據

我們想要的數據是包含在每一個Characteristic

 

微信小程序目前提供的藍牙API:

1.操作藍牙適配器的4個API  

復制代碼

wx.openBluetoothAdapter //初始化藍牙適配器wx.closeBluetoothAdapter //關閉藍牙模塊wx.getBluetoothAdapterState //獲取本機藍牙適配器狀態wx.onBluetoothAdapterStateChange //監聽藍牙適配器狀態變化事件

復制代碼

 

2.連接前使用的共有4個,分別是

wx.startBluetoothDevicesDiscovery //開始搜尋附近的藍牙外圍設備wx.stopBluetoothDevicesDiscovery //停止搜尋附近的藍牙外圍設備wx.getBluetoothDevices //獲取所有已發現的藍牙設備wx.onBluetoothDeviceFound //監聽尋找到新設備的事件

3.連接和斷開時使用的共有2個,分別是

wx.createBLEConnection //連接低功耗藍牙設備wx.closeBLEConnection //斷開與低功耗藍牙設備的連接

4.連接成功后使用的共有8個,分別是

復制代碼

wx.getConnectedBluetoothDevices //根據 uuid 獲取處于已連接狀態的設備wx.getBLEDeviceServices //獲取藍牙設備所有 service(服務)wx.getBLEDeviceCharacteristics //獲取藍牙設備所有 characteristic(特征值)wx.readBLECharacteristicValue //讀取低功耗藍牙設備的特征值的二進制數據值wx.writeBLECharacteristicValue //向低功耗藍牙設備特征值中寫入二進制數據wx.notifyBLECharacteristicValueChange //啟用低功耗藍牙設備特征值變化時的 notify 功能wx.onBLECharacteristicValueChange //監聽低功耗藍牙設備的特征值變化wx.onBLEConnectionStateChange //監聽低功耗藍牙連接的錯誤事件


詳細參數請見小程序開發文檔

開發指南

小程序提供了一個簡單、高效的應用開發框架和豐富的組件及API,幫助開發者在微信中開發具有原生 APP 體驗的服務。

本章分主題的介紹了小程序的開發語言、框架、能力、調試等內容,幫助開發者快速全面的了解小程序開發的方方面面。

想要更具體了解關于框架、組件、API的詳細內容,請參考對應的參考文檔:


小程序電子秤,微信電子秤,微信小程序稱重,WEIXIN電子秤,MOUNT STAR電子秤,小程序藍牙電子秤,數據通訊電子秤,電子磅秤低功率藍牙,Bluetooth scale

用手機掃描二維碼關閉
二維碼
主站蜘蛛池模板: 国产综合另类色情亚洲中出 | 亚洲AV成人无码一区二区在线 | 国产精品色欲AV久久水 | 成人国产精品秘 在线看明星合成 | 国产2区 | 国产三级视频观看 | 国产高清视频在线观看 | 亚洲AV无码一区二区三区大学生 | 91午夜在线 | 亚洲一区二区无码视频 | 无码精品人妻一二三区免费粉红 | 极品白嫩少妇无套内谢 | 伴郎狠狠挺进我下面 | 久久福利| 天天综合网,7799精品视频天天看 | 免费 无码 国产在线观看观喷水 | 日韩婬乱片A片AAA | 国产美女裸体网站 | 国产A级成人婬片1976 | 人妻洗澡被强公日日澡 | 无码免费婬AV片在线观看 | 久久久无码精品秘 人口 | 在线3级片| 黄色三级片网址 | 欧亚成人A片一区二区 | 欧洲精品码一区二区三区免费看 | 午夜久久精品 | 日韩免费中文字幕A片 | 91蜜桃麻豆媒体成人影院 | 国产黄色免费网站 | 久久精品久久久久 | 99人妻碰碰碰久久久久禁片 | 午夜福利视频 | 午夜日韩 | 高潮喷水无码 | 91精品国产麻豆国产自产影视 | 51精品秘 无码一区二区山手 | 精品成人无码久久久久 | 免费av一区 | HEYZO少妇AV无码1024 | 黄色网址在线播放 |