欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信小程序?qū)崿F(xiàn)藍(lán)牙打印

 更新時(shí)間:2019年09月23日 09:46:36   作者:泠青云  
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)藍(lán)牙打印,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

最近剛好完成了一個(gè)打印標(biāo)簽的項(xiàng)目,其中就涉及到了小程序的藍(lán)牙功能。所以寫下這篇粗略的文章記錄一下,同時(shí)也是給即將做相關(guān)項(xiàng)目的親們提供一個(gè)參考,也希望有什么描述不恰當(dāng)或者技術(shù)上不正確的地方大家可以指出,一起進(jìn)步。

藍(lán)牙打印只要按這九個(gè)步驟(前六個(gè)步驟連接藍(lán)牙,后三個(gè)步驟打印數(shù)據(jù))就可以搞定啦!步驟如下:

第一步:初始化藍(lán)牙模塊 wx.openBluetoothAdapter

wx.openBluetoothAdapter({
 success (res) {
 console.log(res)//res:{errMsg: "openBluetoothAdapter:ok"}
 }
})

第二步:開始搜尋附近的藍(lán)牙外圍設(shè)備 wx.startBluetoothDevicesDiscovery

wx.startBluetoothDevicesDiscovery({
 //services: ['FEE7'],只搜索主服務(wù) UUID 為 FEE7 的設(shè)備,如果明確知道主服務(wù)UUID可以用此項(xiàng)做篩選
 success (res) {
 console.log(res)//res:{errCode: 0, errMsg: "startBluetoothDevicesDiscovery:ok", isDiscovering: true}
 }
})

第三步:獲取已搜素到的藍(lán)牙設(shè)備列表 wx.getBluetoothDevices

wx.getBluetoothDevices({
 success: function (res) {
 console.log(res)//res:{errMsg: "getBluetoothDevices:ok", devices: Array(3)}
 }
})

第四步:監(jiān)聽尋找到新設(shè)備的事件 wx.onBluetoothDeviceFound(有時(shí)候會第三步會搜不到所以需要使用監(jiān)聽器去隨時(shí)監(jiān)聽搜索到的藍(lán)牙設(shè)備并返回給你)

wx.onBluetoothDeviceFound(function(res) {
 console.log(res)//res:{devices: Array(1)}
})

第五步:連接藍(lán)牙設(shè)備 wx.createBLEConnection

wx.createBLEConnection({
 deviceId,//上面選擇藍(lán)牙設(shè)備的deviceId,例:連接第一個(gè)設(shè)備devices[0].deviceId
 success (res) {
 console.log(res)//{errCode: 0, errMsg: "createBLEConnection:ok"}
 }
})

第六步:停止搜尋附近的藍(lán)牙外圍設(shè)備 wx.stopBluetoothDevicesDiscovery(可以寫在第五步成功回調(diào)之后,或者是

onUnload()函數(shù)里)
wx.stopBluetoothDevicesDiscovery({
 success (res) {
 console.log(res)
 }
})

第七步:獲取藍(lán)牙設(shè)備所有服務(wù) wx.getBLEDeviceServices

wx.getBLEDeviceServices({
 deviceId,//已連接的藍(lán)牙設(shè)備ID
 success (res) {
 console.log(res)//{errMsg: "getBLEDeviceServices:ok", services: Array(5), errCode: 0}
 }
})
//這邊獲取到了5個(gè)服務(wù)

第八步:獲取藍(lán)牙設(shè)備中某一個(gè)服務(wù)的所有特征值 wx.getBLEDeviceCharacteristics

var characteristics="";
wx.getBLEDeviceCharacteristics({
 deviceId,
 serviceId,//第七步的服務(wù)ID,
 success (res) {
 //res:{errMsg: "getBLEDeviceCharacteristics:ok", characteristics: Array(4), errCode: 0}
 //characteristics[0].properties: {read: true, write: false, notify: false, indicate: false}
 //特征值有好幾種類型,我們這邊打印需要的是item.properties.write為true的特征值
 for (var i = 0; i < res.characteristics.length; i++) {
 var item = res.characteristics[i];
 if (item.properties.write) {
 characteristics = item.uuid;
 }
 }
 //保存特征值
 }
})

第九步:向藍(lán)牙設(shè)備特征值中寫入數(shù)據(jù) wx.writeBLECharacteristicValue

wx.writeBLECharacteristicValue({
 deviceId,
 serviceId,
 characteristicId,//上面保存的特征值
 value: buffer, // 這里的value是ArrayBuffer類型,中間層傳過來的打印數(shù)據(jù)前端自己做轉(zhuǎn)換,轉(zhuǎn)換過程我這邊就不描述了;
 success (res) {
 console.log('writeBLECharacteristicValue success', res.errMsg)
 }
})
//特別提醒建議每次寫入的buffer不超過20字節(jié),超過會有寫入錯(cuò)誤的風(fēng)險(xiǎn),所以一個(gè)打印的內(nèi)容可能要拆成N個(gè)20字節(jié)的buffer去循環(huán)writeBLECharacteristicValue,這樣就能打印成功啦。

附:

微信小程序官方文檔

示例代碼(uniapp實(shí)現(xiàn)小程序藍(lán)牙打印簡易流程)

另注:無論是原生、WePY、mpvue或uniapp、調(diào)用步驟都是一樣的,不過調(diào)用API的前綴需要改成對應(yīng)的就OK了

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • js如何獲取對象在數(shù)組中的index

    js如何獲取對象在數(shù)組中的index

    這篇文章主要介紹了js如何獲取對象在數(shù)組中的index,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • webpack v4 從dev到prd的方法

    webpack v4 從dev到prd的方法

    這篇文章主要介紹了webpack v4 從dev到prd的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-04-04
  • JS自動生成動態(tài)HTML驗(yàn)證碼頁面

    JS自動生成動態(tài)HTML驗(yàn)證碼頁面

    這篇文章主要介紹了JS自動生成動態(tài)HTML驗(yàn)證碼頁面,輸入錯(cuò)誤自動清空輸入框的功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • JavaScript瀏覽器的跨域問題解決方案

    JavaScript瀏覽器的跨域問題解決方案

    出于瀏覽器的同源策略限制。同源策略是一種約定,它是瀏覽器最核心也最基本的安全功能,如果缺少了同源策略,則瀏覽器的正常功能可能都會受到影響。知識點(diǎn):跨域只會出現(xiàn)在瀏覽器上,小程序和APP開發(fā)不會有跨域問題
    2022-11-11
  • 深入淺析JavaScript函數(shù)前面的加號和嘆號

    深入淺析JavaScript函數(shù)前面的加號和嘆號

    這篇文章主要介紹了深入淺析JavaScript函數(shù)前面的加號和嘆號的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-07-07
  • js實(shí)現(xiàn)1,2,3,5數(shù)字按照概率生成

    js實(shí)現(xiàn)1,2,3,5數(shù)字按照概率生成

    這篇文章主要介紹了js實(shí)現(xiàn)1,2,3,5數(shù)字按照概率生成,需要的朋友可以參考下
    2017-09-09
  • 原生js實(shí)現(xiàn)自定義滾動條

    原生js實(shí)現(xiàn)自定義滾動條

    這篇文章主要為大家詳細(xì)介紹了原生js實(shí)現(xiàn)自定義滾動條,可點(diǎn)擊、拖動到達(dá),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • js實(shí)現(xiàn)表格字段排序

    js實(shí)現(xiàn)表格字段排序

    本篇文章只要是對js表格字段排序的實(shí)例代碼進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-02-02
  • 使用layui 渲染table數(shù)據(jù)表格的實(shí)例代碼

    使用layui 渲染table數(shù)據(jù)表格的實(shí)例代碼

    今天小編就為大家分享一篇使用layui 渲染table數(shù)據(jù)表格的實(shí)例代碼,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • JS for循環(huán)中i++ 和 ++i的區(qū)別介紹

    JS for循環(huán)中i++ 和 ++i的區(qū)別介紹

    這篇文章主要介紹了JS for循環(huán)中i++ 和 ++i的區(qū)別介紹的相關(guān)資料,需要的朋友可以參考下
    2016-07-07

最新評論