uniapp 低功耗蓝牙BLE分包

ble.js

javascript 复制代码
  // 分包写入蓝牙
  async sendWriteBLECharacteristicValue(
    deviceId,
    serviceId,
    writeCharacteristicId,
    readCharacteristicId,
    buffer,
    success, // 成功回调
    failure, // 失败回调
  ) {
    const offset = 500; // 偏移量
    let pos = 0; // 位置
    let bytes = buffer.byteLength; // 总字节
    let that = this;
    while (bytes > 0) {
      let endPos = bytes > offset ? pos + offset : pos + bytes;
      const tempBuffer = buffer.slice(pos, endPos);
      pos += offset;
      bytes -= offset;
      // 延迟发送
      await that.sendDelay(150, tempBuffer).then((buffer) => {
        that.writeBLECharacteristicValue(
          deviceId,
          serviceId,
          writeCharacteristicId,
          buffer,
          (res) => {
            if (buffer.byteLength < offset) {
              success(res);
            }
          },
          (err) => {
            failure(err);
          }
        );
      });
      if (readCharacteristicId) {
        console.log(readCharacteristicId, "读文件");
        uni.readBLECharacteristicValue({
          deviceId: deviceId,
          serviceId: serviceId,
          characteristicId: readCharacteristicId,
        });
      }
    }
  }

  sendDelay(delay, buffer) {
    return new Promise((resolve, reject) => {
      setTimeout(() => resolve(buffer), delay);
    });
  }

  writeBLECharacteristicValue(
    deviceId,
    serviceId,
    characteristicId,
    buffer,
    success,
    failure
  ) {
    plus.bluetooth.writeBLECharacteristicValue({
      deviceId: deviceId,
      serviceId: serviceId,
      characteristicId: characteristicId,
      value: buffer,
      success(res) {
        success(res);
      },
      fail(err) {
        if (res.errCode == "10006") {
          //当前连接已断开,清空连接数据
        }
        console.log("发送失败", res);
        failure(err);
      },
    });
  }

index.vue使用分包

javascript 复制代码
this.$ble.sendWriteBLECharacteristicValue(
        deviceId, // 蓝牙地址ID
        serveiceId, // ABF0
        writeCharId, // 写入蓝牙通道 此处用ABF3
        readCharId,// 读取蓝牙返回数据通道 此处用ABF4
        buffer, // 要写入蓝牙的数据 Uint8Array
        (res) => {
          console.log("打印完成: " + JSON.stringify(res));},
        (err) => {
          console.log("打印失败: " + JSON.stringify(err));
        }
    );
相关推荐
于慨16 小时前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz16 小时前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
从前慢丶16 小时前
前端交互规范(Web 端)
前端
@yanyu66616 小时前
07-引入element布局及spring boot完善后端
javascript·vue.js·spring boot
CHU72903516 小时前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序
财迅通Ai16 小时前
6000万吨产能承压 卫星化学迎来战略窗口期
大数据·人工智能·物联网·卫星化学
GISer_Jing16 小时前
Page-agent MCP结构
前端·人工智能
王霸天17 小时前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
小领航17 小时前
用 Three.js + Vue 3 打造炫酷的 3D 行政地图可视化组件
前端·github
@大迁世界17 小时前
2026年React大洗牌:React Hooks 将迎来重大升级
前端·javascript·react.js·前端框架·ecmascript