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);
    }
});

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

相关推荐
Heo10 分钟前
关于XSS和CSRF,面试官更喜欢这样的回答!
前端·javascript·面试
dchen7715 分钟前
uniapp实现上拉刷新和下拉刷新的两种方式
uni-app
徐小夕1 小时前
耗时一周,我把可视化+零代码+AI融入到了CRM系统,使用体验超酷!
javascript·vue.js·github
5***a9751 小时前
React Native性能优化技巧
javascript·react native·react.js
A3608_(韦煜粮)1 小时前
深入理解React Hooks设计哲学与实现原理:从闭包陷阱到并发模式
javascript·性能优化·react·前端开发·react hooks·并发模式·自定义hooks
玉宇夕落1 小时前
🔁 字符串反转 × 两数之和:前端面试高频题深度拆解(附5种反转写法 + 哈希优化)
javascript
神秘的猪头1 小时前
🧱 深入理解栈(Stack):原理、实现与实战应用
前端·javascript·面试
StockPP2 小时前
印度尼西亚股票多时间框架K线数据可视化页面
前端·javascript·后端
FinelyYang2 小时前
uniapp+unipush2.0+WebRTC实现h5一对一视频通话
uni-app·音视频·webrtc
心随雨下2 小时前
typescript中Triple-Slash Directives如何使用
前端·javascript·typescript