使用react native ble manager获取可用蓝牙设备的列表

Getting a list of available bluetooth devices using react-native-ble-manager

本文关键字:列表 native react ble manager 获取 使用      更新时间:2023-09-26

如何使用react native ble manager获取可用蓝牙设备的列表?

我最近不得不使用这个库,这对我来说很有效:

import { NativeModules, NativeEventEmitter } from 'react-native';
import BleManager from 'react-native-ble-manager';
const BleManagerModule = NativeModules.BleManager;
const bleManagerEmitter = new NativeEventEmitter(BleManagerModule);
...
state = {
  peripherals: new Map(),
};
componentDidMount() {
  BleManager.start({ showAlert: false })
  this.handlerDiscover = bleManagerEmitter.addListener(
    'BleManagerDiscoverPeripheral',
    this.handleDiscoverPeripheral
  );
  this.handlerStop = bleManagerEmitter.addListener(
    'BleManagerStopScan',
    this.handleStopScan
  );
  this.scanForDevices(); // I chose to start scanning for devices here
}
scanForDevices() {
  BleManager.scan([], 15);
}
handleDiscoverPeripheral = (peripheral) => {
  const { peripherals } = this.state;
  if (peripheral.name) {
    peripherals.set(peripheral.id, peripheral.name);
  }
  this.setState({ peripherals });
};
handleStopScan = () => {
  console.log('Scan is stopped. Devices: ', this.state.peripherals);
}

编辑:别忘了申请位置许可!

  1. 首先你应该:

    import BleManager from 'react-native-ble-manager';
    

    别忘了:

    import { NativeAppEventEmitter } from 'react-native'
    
  2. 然后,在你的组件内部(我在componentDidMount上做):

    2.1在'BleManagerDiscoverPeripheral'事件上向NativeAppEventEmitter添加句柄:

    NativeAppEventEmitter.addListener('BleManagerDiscoverPeripheral',(data) => 
        {
          console.log(data) // Name of peripheral device
        });
    

    2.2.启动您的BleManager经理:

    BleManager.start({showAlert: false});
    

    2.3.BleManager.scan([], 30),其中第一个值是一个数组(如果服务UUID),第二个值是扫描将运行的时间(秒)

您可以在官方lib的页面react native ble manager 上找到原始示例

要扫描附近的设备,请使用以下代码,

scanNearByDevices(serviceUUIDList, duration, isAllowDuplicates) {
bleManager
  .scan(serviceUUIDList, duration, isAllowDuplicates)
  .then(results => {
    console.log('Scanning...');
    // this.setState({scanning: true});
  });
}

之后使用以下代码获取发现设备列表,

getDiscoverdDevices() {
return new Promise((resolve, reject) => {
 bleManager
    .getDiscoveredPeripherals()
    .then(devices => {
      console.log('Discovered devices:', devices);
      this.deviceMap.set(device.id, device);
      }
      resolve(devices);
    })
    .catch(error => {
      console.log('error fail: ', error);
      reject(error);
    });
});
}

如果您在android上运行应用程序,请确保您已授予应用程序的位置权限