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

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

相关推荐
董员外1 分钟前
LangChain.js 快速上手指南:Tool的使用,给大模型安上了双手
前端·javascript·后端
willow33 分钟前
Generator与Iterator
javascript
wuhen_n1 小时前
Pinia状态管理原理:从响应式核心到源码实现
前端·javascript·vue.js
晴殇i2 小时前
CommonJS 与 ES6 模块引入的区别详解
前端·javascript·面试
wuhen_n2 小时前
KeepAlive:组件缓存实现深度解析
前端·javascript·vue.js
wuhen_n2 小时前
Vue Router与响应式系统的集成
前端·javascript·vue.js
FansUnion2 小时前
用 AI 自动生成壁纸标题、描述和 SEO Slug
javascript
codingWhat2 小时前
小程序里「嵌」H5:一套完整可落地的 WebView 集成方案
前端·uni-app·webview
大雨还洅下2 小时前
前端 JS: async, await; Generator
javascript
juejin_cn2 小时前
[转][译] 从零开始构建 OpenClaw — 第三部分(元技能)
javascript