本机AppState在Android上没有“无效”状态

时间:2016-11-03 15:31:58

标签: android react-native

我试图在用户离开应用程序之前更改UI(用户处于多任务视图或切换到其他应用程序)。要在用户离开应用时更加具体,我想添加带有应用徽标的全屏视图。

我正在使用AppState。

在iOS上它按预期工作:在多任务处理视图应用程序变为非活动状态,一旦切换到其他应用程序状态转到后台。当状态处于非活动状态时,我仍然可以更改UI。

但是,在Android上,状态是活动状态还是后台状态。 问题是在后台状态下我不能再改变UI了。

这是Android上的错误吗?如果没有,我有什么选择让它在Android上运行。

感谢。

2 个答案:

答案 0 :(得分:5)

如果需要,可以通过向MainActivity.java添加一些代码来监听其生命周期事件来模拟与iOS相同的状态

//onResume = 'active'  
//onPause = 'inactive'  
//onStop = 'background' 

@Override
public void onResume() {
    super.onResume();
    ReactContext reactContext = getReactInstanceManager().getCurrentReactContext();
    WritableMap params = Arguments.createMap();
    params.putString("event", "active");

    // when app starts reactContext will be null initially until bridge between Native and React Native is established
    if(reactContext != null) {
        getReactInstanceManager().getCurrentReactContext()
            .getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class)
            .emit("ActivityStateChange", params);
    }
}

@Override
public void onPause() {
    super.onPause();
    ReactContext reactContext = getReactInstanceManager().getCurrentReactContext();
    WritableMap params = Arguments.createMap();
    params.putString("event", "inactive");

    if(reactContext != null) {
        getReactInstanceManager().getCurrentReactContext()
                .getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class)
                .emit("ActivityStateChange", params);
    }
}

@Override
public void onStop() {
    super.onStop();
    ReactContext reactContext = getReactInstanceManager().getCurrentReactContext();
    WritableMap params = Arguments.createMap();
    params.putString("event", "background");

    if(reactContext != null) {
        getReactInstanceManager().getCurrentReactContext()
                .getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class)
                .emit("ActivityStateChange", params);
    }
}

然后在您的JS中使用DeviceEventEmitter

监听这些生命周期更改
const nativeEventListener = DeviceEventEmitter.addListener('ActivityStateChange',
  (e)=>{
      console.log(e.event);
})

答案 1 :(得分:2)

对于Android,您可以这样使用“背景” 而不是“非活动”

  AppState.addEventListener('change', state => {

  if ( state === 'background') {
    //write your code here
   }

});