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

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

相关推荐
灵感__idea12 小时前
Hello 算法:让前端人真正理解算法
前端·javascript·算法
excel12 小时前
🧩 Vue 3 watch 源码详解(含完整注释)
前端·javascript·vue.js
苏打水com15 小时前
JavaScript 入门学习指南:从零基础到能写交互效果
javascript
大前端helloworld15 小时前
前端梳理体系从常问问题去完善-框架篇(Vue2&Vue3)
前端·javascript·面试
嫂子的姐夫16 小时前
11-py调用js
javascript·爬虫·python·网络爬虫·爬山算法
Dajiaonew16 小时前
Vue3 + TypeScript 一篇文章 后端变全栈
前端·javascript·typescript
铉铉这波能秀17 小时前
如何在Android Studio中使用Gemini进行AI Coding
android·java·人工智能·ai·kotlin·app·android studio
勤奋菲菲18 小时前
Koa.js 完全指南:下一代 Node.js Web 框架
前端·javascript·node.js
10年前端老司机18 小时前
面试官爱问的 Object.defineProperty,90%的人倒在这些细节上!
前端·javascript
用户479492835691520 小时前
TypeScript 和 JavaScript 的 'use strict' 有啥不同
前端·javascript·typescript