Я пытаюсь отфильтровать нативные события в React Native с помощью RxJS.Я использую response-native-ble-manager, который выставляет EventEmitter.В основном, без RxJS Я делаю следующее (здесь показан только соответствующий код):
import React from 'react';
import RX from 'reactxp';
import { AppState, Platform, NativeModules, NativeEventEmitter, EmitterSubscription, PermissionsAndroid, ListView } from 'react-native';
import BleManager, { Peripheral } from 'react-native-ble-manager';
const BleManagerModule = NativeModules.BleManager;
const bleManagerEmitter = new NativeEventEmitter(BleManagerModule);
export class App extends RX.Component<IAppProps, IAppState> {
private handlerDiscover!: EmitterSubscription;
private handlerStop!:EmitterSubscription;
private handlerDisconnect!:EmitterSubscription;
private handlerUpdate!:EmitterSubscription;
componentDidMount() {
AppState.addEventListener('change', this.handleAppStateChange);
BleManager.start({ showAlert: false });
this.handlerDiscover = bleManagerEmitter.addListener('BleManagerDiscoverPeripheral', this.handleDiscoverPeripheral);
this.handlerStop = bleManagerEmitter.addListener('BleManagerStopScan', this.handleStopScan);
this.handlerDisconnect = bleManagerEmitter.addListener('BleManagerDisconnectPeripheral', this.handleDisconnectedPeripheral);
this.handlerUpdate = bleManagerEmitter.addListener('BleManagerDidUpdateValueForCharacteristic', this.handleUpdateValueForCharacteristic);
}
componentWillUnmount() {
this.handlerDiscover.remove();
this.handlerStop.remove();
this.handlerDisconnect.remove();
}
handleUpdateValueForCharacteristic = (data:any) => {
console.log('Received data from ' + data.peripheral + ' characteristic ' + data.characteristic + ' length ' + data.value.length + ' values ' + data.value);
}
}
После подключения к периферийному устройству BLE и запуска данныхпри извлечении функция стрелки handleUpdateValueForCharacteristic вызывается с данными.Это работает нормально.
Теперь я хотел бы использовать RxJS для фильтрации событий, потому что я мог получать до 200 событий в секунду, но меня интересует только 1/4 из них.
Я просто не могу обернуться вокруг fromEventPattern Использование.
То, что я до сих пор пробовал, это следующее:
Добавлена некоторая функция обработчика в классе:
private addHandler:Function = (handler:NodeEventHandler):any => {
this.handlerUpdate = bleManagerEmitter.addListener('BleManagerDidUpdateValueForCharacteristic', handler);
return this.handlerUpdate;
}
private removeHandler:Function = (handler:EmitterSubscription, _signal?:any) => {
handler.remove();
}
В componentDidMount ():
this.emitter = fromEventPattern<any>(this.addHandler(this.handleUpdateValueForCharacteristic), this.removeHandler(this.handlerUpdate));
this.emitter.subscribe(...);
Но подписка не выполняется со следующей ошибкой:
addHandler не является функцией.