时间:2021-05-18
本文实例为大家分享了微信小程序使用蓝牙小插件,供大家参考,具体内容如下
bluetooth.js
function BLE(options) { this.options = options || { locator: {} };}function ab2hex(buffer) { const hexArr = Array.prototype.map.call( new Uint8Array(buffer), function (bit) { return ('00' + bit.toString(16)).slice(-2) } ) return hexArr.join('-')};BLE.prototype = { open: function (callback) {//打开适配器 成功 调用callback(); wx.openBluetoothAdapter({ success(res) { if (typeof callback != "undefined") { callback(); } }, fail(res) { console.log(res) } }) }, scan: function (callback) {//扫描设备 成功 调用callback(ls); wx.startBluetoothDevicesDiscovery({ success(res) { wx.getBluetoothDevices({ success(res) { console.log(res); var ls = []; for (var i = 0; i < res.devices.length; i++) { console.log(res.devices[i].name); ls[i] = { deviceId: res.devices[i].deviceId, name: res.devices[i].name }; } if (typeof callback!= "undefined"){ callback(ls); } } }) }, fail(res) { console.log(res) return 0; } }) }, link: function (deviceId, callback) {//连接设备 成功 调用callback(); wx.createBLEConnection({ // 这里的 deviceId 需要已经通过 createBLEConnection 与对应设备建立链接 deviceId: deviceId, success(res) { console.log(res); wx.getBLEDeviceServices({ // 这里的 deviceId 需要已经通过 createBLEConnection 与对应设备建立链接 deviceId: deviceId, success(res) { console.log(res); wx.getBLEDeviceCharacteristics({ // 这里的 deviceId 需要已经通过 createBLEConnection 与对应设备建立链接 deviceId: deviceId, // 这里的 serviceId 需要在 getBLEDeviceServices 接口中获取 serviceId: ' ', success(res) { console.log(res) if (typeof callback != "undefined") { callback(); } } }) } }) }, fail(res) { console.log(res) } }) }, write: function (deviceId, value, callback) {//写入数据 成功 调用callback(); const buffer = new ArrayBuffer(value.length); const dataView = new DataView(buffer); for (var i = 0; i < value.length; i++) { dataView.setUint8(i, value[i].charCodeAt()); } console.log(buffer); console.log(buffer); wx.getBLEDeviceServices({ // 这里的 deviceId 需要已经通过 createBLEConnection 与对应设备建立链接 deviceId: deviceId, success(res) { console.log(res); wx.getBLEDeviceCharacteristics({ // 这里的 deviceId 需要已经通过 createBLEConnection 与对应设备建立链接 deviceId: deviceId, // 这里的 serviceId 需要在 getBLEDeviceServices 接口中获取 serviceId: '4FAFC201-1FB5-459E-8FCC-C5C9C331914B', success(res) { wx.writeBLECharacteristicValue({ deviceId: deviceId, serviceId: '4FAFC201-1FB5-459E-8FCC-C5C9C331914B', characteristicId: 'BEB5483E-36E1-4688-B7F5-EA07361B26B8', value: buffer, success: function (res) { console.log(res); if (typeof callback != "undefined") { callback(); } }, fail: function (res) { console.log(res); } }) } }) } }) }, read: function (deviceId, callback) {//读取数据 成功 调用callback(xmlString); wx.onBLECharacteristicValueChange(function (characteristic) { var board = ab2hex(characteristic.value); var bigData = board.split('-'); var result = []; for (var i = 0; i < bigData.length; i++) { result.push(String.fromCharCode('0X' + bigData[i])); } var xmlString = result.join(''); if (typeof callback != "undefined") { callback(xmlString); } }); wx.readBLECharacteristicValue({ // 这里的 deviceId 需要已经通过 createBLEConnection 与对应设备建立链接 deviceId: deviceId, // 这里的 serviceId 需要在 getBLEDeviceServices 接口中获取 serviceId: '4FAFC201-1FB5-459E-8FCC-C5C9C331914B', // 这里的 characteristicId 需要在 getBLEDeviceCharacteristics 接口中获取 characteristicId: 'BEB5483E-36E1-4688-B7F5-EA07361B26B8', success(res) { // console.log('readBLECharacteristicValue:', res.errCode); console.log(res); }, fail(res) { console.log(res); } }) }, close: function (deviceId, callback) {//关闭蓝牙 成功 调用callback(); wx.closeBLEConnection({ deviceId: deviceId, success(res) { console.log(res); if (typeof callback != "undefined") { callback(); } } }) // wx.closeBluetoothAdapter({ // success(res) { // console.log(res); // if (typeof callback != "undefined"){ // callback(); // } // } // }) }}exports.BLE = BLE;index.js
const Ble = require('../../lib/bluetooch/bluetooch');var ble = new Ble.BLE();以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
企业微信小程序的开发通过企业微信小程序模拟器插件来实现,方便用户在微信开发者工具中进行企业微信小程序开发、调试和代码上传。一、开发须知开发者在使用企业微信小程序
微信公众平台很早之前就上线了小程序插件的功能,开发者可以直接在在小程序的内部提供插件为用户进行服务。那么,还是有很多开发者不知道微信小程序如何使用插件,下面小编
腾讯旗下社交媒体平台微信今天宣布,将为小程序开放插件功能,开发者可以像开发小程序一样开发一个插件,供其他小程序使用。小程序开发者也可以直接把插件添加到自己的小程
3月13日消息,亿邦动力网获悉,微信公众平台发布,小程序开放插件功能。一、开发者可开发小程序插件开发者可以像开发小程序一样开发一个插件,提供给其他小程序使用。二
【怎么做微信小程序】如何制作自己的微信小程序?制作简单的微信程序开发周期有多长?制作微信小程序要花多少钱?如何使用Python开发微信小程序?如何通过微信小