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

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

相关推荐
Front思12 小时前
AI前端工程师需要具备能力+
前端·人工智能·ai
ZC跨境爬虫14 小时前
跟着 MDN 学CSS day_29:(掌握文本与字体样式的核心艺术)
前端·css·ui·html·tensorflow
李子琪。15 小时前
网络空间安全深度实战:CSRF 漏洞原理剖析与基于 Token 的纵深防御体系构建(全栈实验报告)
前端·安全·csrf
冰暮流星15 小时前
javascript之history对象介绍
前端·笔记
IT_陈寒16 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端
丷丩16 小时前
MapLibre GL JS第19课:实时更新要素
前端·javascript·gis·map·mapbox·maplibre gl js
Mr.Daozhi16 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具
哆来A梦没有口袋16 小时前
干货精讲 | 初级CSS面试高频考题
前端·css·面试
掘金0117 小时前
EmbedPDF Vue 版 完整正文文档 全网首发
前端
OpenTiny社区17 小时前
操作ArkTS页面跳转及路由相关心得
前端·typescript·web·opentiny