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

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

相关推荐
广州华水科技1 小时前
单北斗变形监测一体机在基础设施安全与地质灾害监测中的应用价值分析
前端
Dragon Wu1 小时前
Electron Forge集成React Typescript完整步骤
前端·javascript·react.js·typescript·electron·reactjs
芳草萋萋鹦鹉洲哦1 小时前
【Tailwind】动画解读:Tailwind CSS Animation Examples
前端·css
华仔啊1 小时前
jQuery 4.0 发布,IE 终于被放弃了
前端·javascript
一心赚狗粮的宇叔1 小时前
03.Node.js依赖包补充说明及React&Node.Js项目
前端·react.js·node.js
子春一1 小时前
Flutter for OpenHarmony:音律尺 - 基于Flutter的Web友好型节拍器开发与节奏可视化实现
前端·flutter
JarvanMo1 小时前
150万开发者“被偷家”!这两款浓眉大眼的 VS Code 插件竟然是间谍
前端
亿元程序员1 小时前
大佬,现在AI游戏开发教程那么多,你不搞点卖给大学生吗?
前端
未来龙皇小蓝1 小时前
RBAC前端架构-02:集成Vue Router、Vuex和Axios实现基本认证实现
前端·vue.js·架构
晓得迷路了2 小时前
栗子前端技术周刊第 116 期 - 2025 JS 状态调查结果、Babel 7.29.0、Vue Router 5...
前端·javascript·vue.js