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

在微信小程序中,蓝牙发送的数据包 需要分包 发送给设备,特别是当数据长度超过单个 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 分包发送数据 了 🚀🚀🚀

相关推荐
IT_陈寒12 小时前
Java性能优化:从这8个关键指标开始,让你的应用提速50%
前端·人工智能·后端
天生我材必有用_吴用12 小时前
Vue3+Node.js 实现大文件上传:断点续传、秒传、分片上传完整教程(含源码)
前端
摸鱼的春哥12 小时前
前端程序员最讨厌的10件事
前端·javascript·后端
牧羊狼的狼16 小时前
React 中的 HOC 和 Hooks
前端·javascript·react.js·hooks·高阶组件·hoc
知识分享小能手18 小时前
React学习教程,从入门到精通, React 属性(Props)语法知识点与案例详解(14)
前端·javascript·vue.js·学习·react.js·vue·react
魔云连洲18 小时前
深入解析:Vue与React的异步批处理更新机制
前端·vue.js·react.js
mCell18 小时前
JavaScript 的多线程能力:Worker
前端·javascript·浏览器
超级无敌攻城狮20 小时前
3 分钟学会!波浪文字动画超详细教程,从 0 到 1 实现「思考中 / 加载中」高级效果
前端
excel21 小时前
用 TensorFlow.js Node 实现猫图像识别(教学版逐步分解)
前端
gnip21 小时前
JavaScript事件流
前端·javascript