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 小时前
Vue 教程 自定义指令 + 生命周期全解析
开发语言·前端·javascript·vue.js·前端框架·html
coloma201216 小时前
COCOS代码动态增加刚体和碰撞体的方法
前端·uv
●VON16 小时前
React Native for OpenHarmony:解构 TouchableOpacity 的触摸反馈与事件流控制
javascript·学习·react native·react.js·性能优化·openharmony
有诺千金16 小时前
VUE3入门很简单(5)---组件通信(自定义事件)
javascript·vue.js·ecmascript
想逃离铁厂的老铁16 小时前
Day60 >> 94、城市间货物运输1️⃣ + 95、城市间货物运输 2️⃣ + 96、城市间货物运输 3️⃣
java·服务器·前端
GISer_Jing17 小时前
WebGL跨端兼容实战:移动端适配全攻略
前端·aigc·webgl
迦南giser17 小时前
前端性能——传输优化
前端
小白_ysf17 小时前
Vue 中常见的加密方法(对称、非对称、杂凑算法)
前端·vue.js·算法
2501_9444480018 小时前
Flutter for OpenHarmony衣橱管家App实战:支持我们功能实现
android·javascript·flutter
人工智能训练1 天前
【极速部署】Ubuntu24.04+CUDA13.0 玩转 VLLM 0.15.0:预编译 Wheel 包 GPU 版安装全攻略
运维·前端·人工智能·python·ai编程·cuda·vllm