uniapp 蓝牙分包发送数据

javascript 复制代码
// 连接蓝牙设备并发送数据
function sendDataOverBLE(deviceId, data) {
  // 首先连接蓝牙设备
  uni.createBLEConnection({
    deviceId: deviceId,
    success: function(res) {
      // 连接成功后,获取服务
      uni.getBLEDeviceServices({
        deviceId: deviceId,
        success: function(res) {
          // 假设我们使用第一个服务
          var serviceId = res.services[0].uuid;
          uni.getBLEDeviceCharacteristics({
            deviceId: deviceId,
            serviceId: serviceId,
            success: function(res) {
              // 假设我们写入特性的uuid是已知的
              var characteristicId = res.characteristics[0].uuid;
              // 分包发送数据
              var chunkSize = 20; // 假设每个包的大小是20字节
              var chunks = splitArrayIntoChunks(data, chunkSize);
              chunks.forEach((chunk, index) => {
                uni.writeBLECharacteristicValue({
                  deviceId: deviceId,
                  serviceId: serviceId,
                  characteristicId: characteristicId,
                  value: chunk,
                  success: function(res) {
                    if (index === chunks.length - 1) {
                      // 所有分包发送成功后的回调
                      console.log('所有数据分包发送成功');
                    }
                  },
                  fail: function(err) {
                    console.error('分包发送失败', err);
                  }
                });
              });
            },
            fail: function(err) {
              console.error('获取特性失败', err);
            }
          });
        },
        fail: function(err) {
          console.error('获取服务失败', err);
        }
      });
    },
    fail: function(err) {
      console.error('连接蓝牙设备失败', err);
    }
  });
}
 
// 分割数组为指定大小的多个分包
function splitArrayIntoChunks(array, chunkSize) {
  var chunks = [];
  for (var i = 0; i < array.length; i += chunkSize) {
    chunks.push(array.slice(i, i + chunkSize));
  }
  return chunks;
}
 
// 使用示例
var deviceId = 'your-device-id'; // 蓝牙设备ID
var data = new Uint8Array([/* 你的数据 */]); // 需要发送的数据
sendDataOverBLE(deviceId, data);
相关推荐
AAA大运重卡何师傅(专跑国道)18 小时前
力扣hot100
服务器·前端·数据库
GISer_Jing18 小时前
前端沙箱开源项目推荐(React/Next/Vue优先)
前端·react.js·开源
云水一下18 小时前
CSS3从零基础到精通(三):动感地带——过渡、动画、变形与响应式
前端·css3
黄同学real18 小时前
uni-app 真机调试:手动代理环境下访问内网 API 的解决方案
uni-app
KaMeidebaby19 小时前
卡梅德生物技术快报|Western Blot 实验应用:肺肠轴机制研究全流程技术解析
前端·数据库·人工智能·算法·百度
MageGojo19 小时前
做节日活动页时,如何用 API 快速生成对联内容
javascript·python·节日·对联生成
达达爱吃肉19 小时前
claude 接入deepseek 运行报错
java·服务器·前端
jingling55519 小时前
Flutter | Dio网络请求实战
android·开发语言·前端·flutter
向上的车轮19 小时前
Next.js 入门指南:从零到一构建全栈应用
开发语言·javascript·ecmascript
freeinlife'19 小时前
精准秒表计时器实现---基于js
开发语言·前端·javascript