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

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

相关推荐
JackieDYH6 小时前
CSS实现跑马灯效果-案例
前端·css·css3
羽沢316 小时前
Vue3组件间通信——pinia
前端·javascript·vue.js
BBB努力学习程序设计6 小时前
简易横向导航制作指南
前端·html
BBB努力学习程序设计6 小时前
深入理解CSS定位叠放次序:z-index完全指南
前端·html
头疼8466 小时前
vue 组件实现 、background-hover随鼠标丝滑移动~
前端
焦糖小布丁7 小时前
加http和https访问的网站不同?
前端
人工智能的苟富贵7 小时前
用 Rust 写一个前端项目辅助工具:JSON 格式化器
前端·rust·json
季春二九7 小时前
Edge 卸载工具 | 版本号1.0 | 专为彻底卸载Microsoft Edge设计
前端·microsoft·edge·edge 卸载工具
雨过天晴而后无语7 小时前
HTML中JS监听输入框值的即时变化
前端·javascript·html
座山雕~7 小时前
html 和css基础常用的标签和样式(2)-css
前端·css·html