前端之家收集整理的这篇文章主要介绍了
微信小程序实现蓝牙打印,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
@H_
403_0@最近刚好完成了一个打印
标签的项目,其中就涉及到了
小程序的蓝牙
功能。所以写下这篇粗略的
文章记录一下,同时也是给即将做相关项目的亲们提供一个参考,也希望有什么描述不恰当或者技术上不正确的地方大家可以指出,一起进步。
@H_
403_0@蓝牙打印只要按这九个步骤(前六个步骤连接蓝牙,后三个步骤打印数据)就可以搞定啦!步骤如下:
@H_
403_0@第一步:初始化蓝牙模块 wx.openBluetoothAdapter
wx.openBluetoothAdapter({
success (res) {
console.log(res)//res:{errMsg: "openBluetoothAdapter:ok"}
}
})
@H_
403_0@第二步:开始搜寻附近的蓝牙外围设备 wx.startBluetoothDevicesDiscovery
wx.startBluetoothDevicesDiscovery({
//services: ['FEE7'],只搜索主服务 UUID 为 FEE7 的设备,如果明确知道主服务UUID可以用此项做筛选
success (res) {
console.log(res)//res:{errCode: 0,errMsg: "startBluetoothDevicesDiscovery:ok",isDiscovering: true}
}
})
@H_
403_0@第三步:
获取已搜素到的蓝牙设备列表 wx.getBluetoothDevices
wx.getBluetoothDevices({
success: function (res) {
console.log(res)//res:{errMsg: "getBluetoothDevices:ok",devices: Array(3)}
}
})
@H_
403_0@第四步:监听寻找到新设备的事件 wx.onBluetoothDeviceFound(有时候会第三步会搜不到所以需要使用监听器去随时监听
搜索到的蓝牙设备并返回给你)
wx.onBluetoothDeviceFound(function(res) {
console.log(res)//res:{devices: Array(1)}
})
@H_
403_0@第五步:连接蓝牙设备 wx.createBLEConnection
wx.createBLEConnection({
deviceId,//上面选择蓝牙设备的deviceId,例:连接第一个设备devices[0].deviceId
success (res) {
console.log(res)//{errCode: 0,errMsg: "createBLEConnection:ok"}
}
})
@H_
403_0@第六步:停止搜寻附近的蓝牙外围设备 wx.stopBluetoothDevicesDiscovery(可以写在第五步成功回调之后,或者是
onUnload()函数里)
wx.stopBluetoothDevicesDiscovery({
success (res) {
console.log(res)
}
})
@H_
403_0@第七步:
获取蓝牙设备所有服务 wx.getBLEDeviceServices
wx.getBLEDeviceServices({
deviceId,//已连接的蓝牙设备ID
success (res) {
console.log(res)//{errMsg: "getBLEDeviceServices:ok",services: Array(5),errCode: 0}
}
})
//这边获取到了5个服务
@H_
403_0@第八步:
获取蓝牙设备中某一个服务的所有特征值 wx.getBLEDeviceCharacteristics
var characteristics="";
wx.getBLEDeviceCharacteristics({
deviceId,serviceId,//第七步的服务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;
}
}
//保存特征值
}
})
@H_
403_0@第九步:向蓝牙设备特征值中写入数据 wx.writeBLECharacteristicValue
wx.writeBLECharacteristicValue({
deviceId,characteristicId,//上面保存的特征值
value: buffer,// 这里的value是ArrayBuffer类型,中间层传过来的打印数据前端自己做转换,转换过程我这边就不描述了;
success (res) {
console.log('writeBLECharacteristicValue success',res.errMsg)
}
})
//特别提醒建议每次写入的buffer不超过20字节,超过会有写入错误的风险,所以一个打印的内容可能要拆成N个20字节的buffer去循环writeBLECharacteristicValue,这样就能打印成功啦。
@H_
403_0@
附:
@H_
403_0@
微信小程序官方文档
@H_
403_0@
示例代码(uniapp实现小程序蓝牙打印简易流程)
@H_
403_0@另注:无论是原生、WePY、mpvue或uniapp、
调用步骤都是一样的,不过
调用API的前缀需要改成对应的就OK了
@H_
403_0@以上就是本文的全部
内容,希望对大家的学习有所帮助,也希望大家多多
支持我们。