uniapp蓝牙连接设备并发送接收信息

项目中有这样一个需求就是通过蓝牙连接设备,并传输一些数据给设备,并接收设备回传过来的信息,经过探索,下面整理了一下我的经验分享给大家。

uniapp开发中,可以使用uni-app提供的uni.bluetoothAdapter API来实现。这些API允许你管理蓝牙适配器状态、搜索蓝牙设备、连接设备、传输数据等。

1. 开启蓝牙适配器

首先,你需要调用uni.openBluetoothAdapter来开启蓝牙模块。

javascript 复制代码
uni.openBluetoothAdapter({
    success: function (res) {
        console.log('蓝牙模块初始化成功');
    },
    fail: function (err) {
        console.error('蓝牙模块初始化失败', err);
    }
});

2. 获取已搜索到的蓝牙设备

你可以使用uni.getBluetoothDevices来获取已搜索到的蓝牙设备列表。

javascript 复制代码
uni.getBluetoothDevices({
    success: function (res) {
        console.log('已搜索到的蓝牙设备列表', res.devices);
    },
    fail: function (err) {
        console.error('获取蓝牙设备失败', err);
    }
});

3. 搜索附近的蓝牙设备

使用uni.startBluetoothDevicesDiscovery来搜索附近的蓝牙设备。

javascript 复制代码
uni.startBluetoothDevicesDiscovery({
    success: function (res) {
        console.log('开始搜索附近的蓝牙设备');
    },
    fail: function (err) {
        console.error('搜索蓝牙设备失败', err);
    }
});

4. 连接蓝牙设备

找到目标设备后,可以使用uni.createBLEConnection来连接设备。

javascript 复制代码
uni.createBLEConnection({
    deviceId: '目标设备的deviceId', // 设备的deviceId,在搜索到的设备列表中获取
    success: function (res) {
        console.log('蓝牙设备连接成功');
    },
    fail: function (err) {
        console.error('蓝牙设备连接失败', err);
    }
});

5. 传输数据(读写)

连接成功后,你可以使用uni.writeBLECharacteristicValue来写入数据,使用uni.notifyBLECharacteristicValueChange来监听数据变化。

javascript 复制代码
// 写入数据到蓝牙设备
uni.writeBLECharacteristicValue({
    deviceId: '目标设备的deviceId', // 设备的deviceId,在搜索到的设备列表中获取
    serviceId: '服务UUID', // 服务的UUID,例如 '0000fff0-0000-1000-8000-00805f9b34fb'
    characteristicId: '特征UUID', // 特征的UUID,例如 '0000fff3-0000-1000-8000-00805f9b34fb'
    value: new Uint8Array([1, 2, 3, 4]), // 要写入的数据,格式为Uint8Array或ArrayBuffer等二进制数据格式
    success: function (res) {
        console.log('写入数据成功');
    },
    fail: function (err) {
        console.error('写入数据失败', err);
    }
});

6. 断开连接和关闭蓝牙适配器(可选)

使用uni.closeBLEConnection来断开与蓝牙设备的连接,使用uni.closeBluetoothAdapter来关闭蓝牙模块。

javascript 复制代码
// 断开连接
uni.closeBLEConnection({
    deviceId: '目标设备的deviceId', // 设备的deviceId,在搜索到的设备列表中获取
    success: function (res) {
        console.log('断开蓝牙设备连接成功');
    },
    fail: function (err) {
        console.error('断开蓝牙设备连接失败', err);
    }
});
javascript 复制代码
// 关闭蓝牙模块
uni.closeBluetoothAdapter({
    success: function (res) {
        console.log('关闭蓝牙模块成功');
    },
    fail: function (err) {
        console.error('关闭蓝牙模块失败', err);
    }
});

在开发的过程中记得将蓝牙权限打开哟

相关推荐
吴声子夜歌6 小时前
TypeScript——webpack
javascript·webpack·typescript
han_6 小时前
JavaScript设计模式(六):职责链模式实现与应用
前端·javascript·设计模式
进击的尘埃7 小时前
Navigation API 如何重塑前端路由
javascript
早點睡3907 小时前
ReactNative项目OpenHarmony三方库集成实战:react-native-orientation-locker
javascript·react native·react.js
早點睡3907 小时前
ReactNative项目OpenHarmony三方库集成实战:react-native-localize
javascript·react native·react.js
棋鬼王7 小时前
Cesium(十) 动态修改白模颜色、白模渐变色、白模光圈特效、白模动态扫描光效、白模着色器
前端·javascript·vue.js·智慧城市·数字孪生·cesium
酉鬼女又兒7 小时前
零基础快速入门前端蓝桥杯Web备考:BOM与定时器核心知识点详解(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·javascript·职场和发展·蓝桥杯
ThridTianFuStreet小貂蝉7 小时前
面试题1:请系统讲讲 Vue2 与 Vue3 的核心差异(响应式、API 设计、性能与编译器)。
前端·javascript·vue.js
竹林8187 小时前
在NFT项目中集成IPFS:从Pinata上传到前端展示的完整实战与踩坑
前端·javascript
我命由我123458 小时前
Vite - Vite 最小项目
服务器·前端·javascript·react.js·ecmascript·html5·js