微信小程序 蓝牙发送的数据包 分包发送给设备

在微信小程序中,蓝牙发送的数据包 需要分包 发送给设备,特别是当数据长度超过单个 BLE 传输的最大字节限制时(一般为 20 字节 )。以下是详细的 分包发送流程代码示例


📌 1. 分包发送的核心思路

  1. 确定最大传输字节数(一般 20 字节,部分设备可调节 MTU)
  2. 将数据按最大字节数进行拆分
  3. 逐包发送,每次等待上一个包发送完成后再发送下一个
  4. 如果设备支持更大 MTU,可适当增加单包大小

📌 2. 代码实现

(1)封装一个分包发送的函数

javascript 复制代码
javascript
复制编辑
function sendBLEData(deviceId, serviceId, characteristicId, data) {
    const MAX_PACKET_SIZE = 20; // 单次发送最大字节数(一般 BLE 设备默认 20)
    const buffer = new Uint8Array(data); // 转换成 Uint8Array
    let offset = 0;

    function sendNextChunk() {
        if (offset >= buffer.length) {
            console.log("📢 数据发送完成");
            return;
        }

        // 计算当前要发送的长度
        let chunkSize = Math.min(MAX_PACKET_SIZE, buffer.length - offset);
        let chunk = buffer.slice(offset, offset + chunkSize);

        wx.writeBLECharacteristicValue({
            deviceId,
            serviceId,
            characteristicId,
            value: chunk.buffer, // 需要转换成 ArrayBuffer
            success(res) {
                console.log(`📤 发送成功: ${offset} ~ ${offset + chunkSize - 1}`);
                offset += chunkSize; // 更新偏移量,发送下一个数据包
                sendNextChunk(); // 递归发送下一个包
            },
            fail(err) {
                console.error("❌ 发送失败", err);
            }
        });
    }

    sendNextChunk(); // 开始发送
}

(2)调用分包发送函数

ini 复制代码
javascript
复制编辑
const deviceId = "你的设备ID";
const serviceId = "你的服务UUID";
const characteristicId = "你的特征UUID";

// 需要发送的完整数据(示例)
const data = new Uint8Array([0x01, 0x02, 0x03, 0x04, ..., 0xFF]);

// 调用分包发送
sendBLEData(deviceId, serviceId, characteristicId, data);

📌 3. 关键点

  1. MAX_PACKET_SIZE = 20 ,微信小程序默认 BLE 传输 最大 20 字节,如果设备支持更大 MTU,可调整。
  2. wx.writeBLECharacteristicValue 需要传 ArrayBuffer,所以用 Uint8Array.slice() 处理后转换成 buffer 传输。
  3. 递归方式 控制发送顺序,确保一个包发送成功后再发下一个,防止数据丢失。
  4. console.log() 便于调试,观察数据发送进度。

📌 4. 设备支持 MTU 调整

某些 BLE 设备支持更大的 MTU(最大传输单元) ,可用 wx.setBLEMTU() 设置:

javascript 复制代码
javascript
复制编辑
wx.setBLEMTU({
    deviceId: deviceId,
    mtu: 512, // 设置更大 MTU(根据设备支持的最大值)
    success(res) {
        console.log("MTU 设置成功:", res.mtu);
    },
    fail(err) {
        console.error("MTU 设置失败", err);
    }
});

然后修改 MAX_PACKET_SIZE = MTU - 3,提高单次传输效率。


📌 5. 总结

如果数据小于 20 字节 ,直接发送

如果数据大于 20 字节 ,按 20 字节 分包发送

如果设备支持更大 MTU ,先调整 wx.setBLEMTU() ,然后增大单包大小

确保每个数据包发送成功后再发下一个,避免丢包

这样就可以稳定地在 微信小程序中通过 BLE 分包发送数据 了 🚀🚀🚀

相关推荐
典学长编程3 分钟前
前端开发(HTML,CSS,VUE,JS)从入门到精通!第三天(JavaScript)
前端·javascript·css·html·前端开发
德育处主任10 分钟前
p5.js 用 beginGeometry () 和 endGeometry () 打造自定义 3D 模型
前端·前端框架·canvas
文火冰糖的硅基工坊21 分钟前
[硬件电路-124]:模拟电路 - 信号处理电路 - 测量系统的前端电路详解
前端·嵌入式硬件·fpga开发·架构·信号处理·电路
爷_1 小时前
手把手教程:用腾讯云新平台搞定专属开发环境,永久免费薅羊毛!
前端·后端·架构
狂炫一碗大米饭1 小时前
如何在 Git 中检出远程分支
前端·git·github
东风西巷2 小时前
猫眼浏览器:简约安全的 Chrome 内核增强版浏览器
前端·chrome·安全·电脑·软件需求
太阳伞下的阿呆2 小时前
npm安装下载慢问题
前端·npm·node.js
pe7er2 小时前
Tauri 应用打包与签名简易指南
前端
前端搬砖仔噜啦噜啦嘞2 小时前
Cursor AI 编辑器入门教程和实战
前端·架构
Jimmy2 小时前
TypeScript 泛型:2025 年终极指南
前端·javascript·typescript