flutter如何实现BLE通信

在Flutter中如何实现BLE通信?需要用到哪些插件或库?具体的实现步骤是什么?能否提供一个简单的示例代码?在Android和iOS上是否有兼容性问题需要注意?

2 回复

Flutter通过flutter_blue插件实现BLE通信。步骤:1. 添加依赖;2. 扫描设备;3. 连接设备;4. 读写特征值。支持Android和iOS平台。

更多关于flutter如何实现BLE通信的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


在Flutter中实现BLE通信,可以使用flutter_blue_plus库,这是目前最稳定且功能完整的BLE插件。以下是实现步骤:

1. 添加依赖

pubspec.yaml 中添加:

dependencies:
  flutter_blue_plus: ^1.30.0

运行 flutter pub get 安装。

2. 配置权限

Android(在 android/app/src/main/AndroidManifest.xml 中添加):

<uses-permission android:name="android.permission.BLUETOOTH" />
<uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.BLUETOOTH_CONNECT" />

iOS(在 ios/Runner/Info.plist 中添加):

<dict>
  <key>NSBluetoothAlwaysUsageDescription</key>
  <string>需要蓝牙权限以连接设备</string>
</dict>

3. 核心代码示例

import 'package:flutter_blue_plus/flutter_blue_plus.dart';

class BleManager {
  // 扫描设备
  void startScan() {
    FlutterBluePlus.startScan(timeout: Duration(seconds: 10));
    FlutterBluePlus.scanResults.listen((results) {
      for (ScanResult result in results) {
        print('发现设备: ${result.device.name} | RSSI: ${result.rssi}');
      }
    });
  }

  // 停止扫描
  void stopScan() {
    FlutterBluePlus.stopScan();
  }

  // 连接设备
  Future<void> connect(BluetoothDevice device) async {
    await device.connect();
    print("已连接: ${device.name}");
    
    // 发现服务
    List<BluetoothService> services = await device.discoverServices();
    for (BluetoothService service in services) {
      for (BluetoothCharacteristic characteristic in service.characteristics) {
        // 读取特征值
        List<int> value = await characteristic.read();
        print('特征值: $value');
        
        // 写入数据(示例)
        await characteristic.write([0x12, 0x34]);
      }
    }
  }
}

4. 关键功能说明

  • 设备扫描:通过 startScan()scanResults 监听器获取设备列表。
  • 设备连接:使用 device.connect() 建立连接。
  • 服务发现:连接后调用 discoverServices() 获取服务列表。
  • 数据读写:通过特征的 read()/write() 方法进行通信。

5. 注意事项

  • 需要处理蓝牙权限请求(Android 6.0+ 和 iOS 需要动态申请)。
  • 在真实环境中需要处理连接超时和错误重试机制。
  • iOS 设备名称可能为空,建议通过广播数据识别设备。

建议查看官方文档(https://pub.dev/packages/flutter_blue_plus)获取完整示例和API详情。

回到顶部