uniapp BLE低功耗蓝牙插件 支持安卓 iOS 鸿蒙NEXT 微信小程序

xl-ble插件

概述

本SDK提供了一套完整的蓝牙低功耗(BLE)设备交互接口,采用模块化设计,将功能接口与回调监听分离,便于开发者灵活使用。

  • 支持蓝牙扫描、连接、断开;

  • 支持字节数据、字符串数据写入;

  • 蓝牙状态监听、连接状态监听、数据回传监听、数据写入是否完成监听;

  • 支持GBK编码;

导入

javascript 复制代码
import * as ble from '@/uni_modules/xl-ble';

功能接口说明

扫描设备

javascript 复制代码
// callback: 发现设备回调
ble.startScan((device) => {
  console.log(`发现设备: ${JSON.stringify(device)}`);
});

停止扫描

javascript 复制代码
ble.stopScan();

连接设备

javascript 复制代码
// 参数1: 设备id
// 参数2(可选):指定服务与特征,未指定内部会自动匹配
ble.connect(
  deviceId,
  // {
  // 	seviceUuid: '0000ff00-0000-1000-8000-00805f9b34fb',
  // 	writeUuid: '0000ff02-0000-1000-8000-00805f9b34fb',
  // 	notifyUuid: '0000ff01-0000-1000-8000-00805f9b34fb'
  // },
)

断开设备

javascript 复制代码
ble.disconnect()

写入数据

  • 写入字节数组

    javascript 复制代码
    // 参数为字节数组,需设备支持的指令,这点很重要
    ble.writeBytes([0x10, 0xff, 0x30])
  • 写入字符串

    javascript 复制代码
    // 参数1: 字符串内容,传的字符串需设备支持的指令,这点很重要
    // 参数2(可选): 字符串编码, 默认 "UTF_8" 编码, 传 "GBK" 使用GBK编码
    ble.writeString('ABC')
    ble.writeString('ABC', 'GBK')

设置MTU分包大小

javascript 复制代码
ble.setMtu(100)

蓝牙事件监听

蓝牙状态监听
javascript 复制代码
ble.onBluetoothStatusChanged((isOn) => {
  uni.showToast({
    title: isOn ? "蓝牙已开启" : "蓝牙已关闭",
    icon: 'none'
  });
});
蓝牙连接状态监听
javascript 复制代码
ble.onConnectionStateChange((connectionState) => {
  uni.showToast({
    title: connectionState.msg,
    icon: 'none'
  })
  switch (connectionState.state) {
    case 'connectFail':
				// 连接失败
      break;
    case 'disconnected':
				// 断开连接
      break;
    case 'connected':
      // 断开成功
      break;
  }
});
蓝牙数据回传监听
javascript 复制代码
ble.onDataReceived((data) => {
  let result = String.fromCharCode(...data);
  console.log(`收到蓝牙数据: ${data}`)
  console.log(`收到蓝牙数据转字符串: ${result}`);
});
数据写入是否完成监听
javascript 复制代码
ble.onWriteComplete((isComplete) => {
  console.log(isComplete ? "写入完成" : "写入失败");
})

蓝牙权限

  • 安卓

    html 复制代码
    <uses-permission android:name="android.permission.BLUETOOTH"/>
    <uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />
    <uses-permission android:name="android.permission.BLUETOOTH_CONNECT"/>
    <uses-permission android:name="android.permission.BLUETOOTH_SCAN"/>
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
    <uses-permission android:name="android.permission.BLUETOOTH_SCAN" />
  • iOS

    html 复制代码
    <key>NSBluetoothAlwaysUsageDescription</key>
    <string>开启蓝牙</string>
    <key>NSBluetoothPeripheralUsageDescription</key>
    <string>蓝牙</string>
    <key>UIBackgroundModes</key>
    <array>
        <string>bluetooth-central</string>
    </array>

类型定义

设备信息

typescript 复制代码
interface BLEDevice {
  name: string       // 设备名称
  deviceId: string   // 设备唯一标识
  rssi: number       // 信号强度
}

连接配置

typescript 复制代码
interface ConnectOptions {
  serviceUuid: string   // 主服务UUID
  writeUuid: string     // 写入特征UUID
  notifyUuid: string    // 通知特征UUID
  autoConnect?: boolean // 是否自动重连
}

服务信息

typescript 复制代码
interface ServiceAndCharacteristics {
  service: string         // 服务UUID
  characteristics: string[] // 特征值列表
}

连接状态

typescript 复制代码
type ConnectionState = {
  status: 'connected' | 'disconnected' | 'failed'
  message?: string
}
相关推荐
游戏开发爱好者85 小时前
日常开发与测试的 App 测试方法、查看设备状态、实时日志、应用数据
android·ios·小程序·https·uni-app·iphone·webview
2501_915106327 小时前
app 上架过程,安装包准备、证书与描述文件管理、安装测试、上传
android·ios·小程序·https·uni-app·iphone·webview
2501_915106327 小时前
使用 Sniffmaster TCP 抓包和 Wireshark 网络分析
网络协议·tcp/ip·ios·小程序·uni-app·wireshark·iphone
宠友信息8 小时前
2025社交+IM及时通讯社区APP仿小红书小程序
java·spring boot·小程序·uni-app·web app
“负拾捌”9 小时前
python + uniapp 结合腾讯云实现实时语音识别功能(WebSocket)
python·websocket·微信小程序·uni-app·大模型·腾讯云·语音识别
局外人LZ1 天前
Uniapp脚手架项目搭建,uniapp+vue3+uView pro+vite+pinia+sass
前端·uni-app·sass
2501_915918411 天前
在 iOS 环境下查看 App 详细信息与文件目录
android·ios·小程序·https·uni-app·iphone·webview
前端呆头鹅1 天前
Websocket使用方案详解(uniapp版)
websocket·网络协议·uni-app
浮桥1 天前
uniapp+h5 公众号实现分享海报绘制
uni-app·notepad++
2501_916007471 天前
没有 Mac 用户如何上架 App Store,IPA生成、证书与描述文件管理、跨平台上传
android·macos·ios·小程序·uni-app·iphone·webview