使用React-Navigation并且有多个ReactActivity交互遇到的问题

问题来源

1.我们的项目中用到了React-Navigation来处理路由,其中用的又是StackNavigation。
2.使用的是ActivityA横屏承载ReactNative的js页面,并且对Android的虚拟按键进行了统一处理
3.最近突然有一个需求,需要再搞一个ActivityB承载一个单页面的竖屏视图

问题暴露

上面的需求实现起来很简单
1.定义一个ActivityB

public class ActivityB extends ReactActivity {
    @Override
    protected String getMainComponentName() {
        return "ActivityB";
    }

    @Override
    protected ReactActivityDelegate createReactActivityDelegate() {
        return new ReactActivityDelegate(this, getMainComponentName()) {
            @Override
            protected ReactRootView createRootView() {
                //处理手势,也可以不用实现这个
                return new RNGestureHandlerEnabledRootView(ActivityB.this);
            }

            @Nullable
            @Override
            protected Bundle getLaunchOptions() {
                Intent intent = getIntent();
                String flag="";
                Bundle bundle = new Bundle();
                if (intent.hasExtra("flag")){
                    flag = intent.getStringExtra("flag");
                    bundle.putString("flag",flag);
                }

                return bundle;
            }
        };
    }
}

2.在清单文件中声明

<activity android:name=".ActivityB"
            android:screenOrientation="portrait"/>

3.实现桥接方法让ReactNative调用,并且添加到package中,最终注册在Application中

public IntentModule(@NonNull ReactApplicationContext reactContext) {
       super(reactContext);

       reactContext.addActivityEventListener(new ActivityEventListener() {
           @Override
           public void onActivityResult(Activity activity, int requestCode, int resultCode, Intent data) {
               if (requestCode==110&&resultCode==111){
                   if (data!=null){
                       WritableMap map = Arguments.createMap();
                       if (data.hasExtra("data")) {
                           String datas = data.getStringExtra("data");
                           map.putString("data",datas);
                       }

                       if (data.hasExtra("uri")) {
                           String uri = data.getStringExtra("uri");
                           map.putString("uri",uri);
                       }
                       reactContext.getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class)
                               .emit("ActivityB", map);
                   }
               }
           }

           @Override
           public void onNewIntent(Intent intent) {

           }
       });
   }

   @NonNull
   @Override
   public String getName() {
       return "IntentModule";
   }


   @ReactMethod
   public void jumpCameraActivityForResult(ReadableMap map){
       String flag = "";
      if (map.hasKey("flag")){
          flag = map.getString("flag");
      }

       Intent intent = new Intent(getCurrentActivity(), ActivityB.class);

      if (!TextUtils.isEmpty(flag)){
          intent.putExtra("flag",flag);
      }

      Objects.requireNonNull(getCurrentActivity()).startActivityForResult(intent,CAMERA_REQUEST_CODE);
   }

   @ReactMethod
   public void finish(ReadableMap map){
       String data="";
       if (map.hasKey("data")){
           data = map.getString("data");
       }

       String uri="";
       if (map.hasKey("uri")){
           uri=map.getString("uri");
       }
       Intent intent=new Intent();
       if (!TextUtils.isEmpty(data)) {
           intent.putExtra("data", data);
       }
       if (!TextUtils.isEmpty(uri)) {
           intent.putExtra("uri", uri);
       }
       Objects.requireNonNull(getCurrentActivity()).setResult(ACTIVITY_RESULT_CODE,intent);
       getCurrentActivity().finish();
   }

4.直接在首页中点击进入的二级页面中加入跳转,并且点击返回
最终会发现除了ActivityB返回了,二级页面也不在了。。。。。。。

分析问题

1.首先在跳转ActivityB之前我打印了路由栈中的所有路由
2.在ActivityB退出之后我又打印了路由栈中的所有路由
经过对比确实发现二级页面不见了(不在栈中了)

3.我在路由的pop,rest等页面分别打了日志,发现并没有被调用
排除了方法误调导致的问题

4.去github的issuse里面去看看有没有别人遇到过这个问题
5.百度(无果)
查了一圈发现没有人提到这个问题(得嘞,还得自己排查)

6.我后来就琢磨是不是把ActivityB的虚拟返回去掉,并且ActivityB显示全屏是不是可以解决这个问题
尝试后发现果然可以。。。

7.那没毛病,肯定是ReactNative的返回处理和原生的返回处理都被执行了,导致不仅ActivityB退出了,ReactNative中的二级页面也退出了
8.去看看ReactActivity是如何处理返回的,果不其然发现优先处理ReactNative内部的返回

  @Override
  public void onBackPressed() {
    if (!mDelegate.onBackPressed()) {
      super.onBackPressed();
    }
  }

到这里就简单了我不让他走ReactNative内部的返回不就行了,返回false给他


到这里本次的问题就圆满解决了。
附上ActivityB的整体源码

public class ActivityB extends ReactActivity {

    @Override
    protected String getMainComponentName() {
        return "ActivityB";
    }

    @Override
    protected ReactActivityDelegate createReactActivityDelegate() {
        return new ReactActivityDelegate(this, getMainComponentName()) {

            @Override
            public boolean onBackPressed() {
                return false;
            }

            @Nullable
            @Override
            protected Bundle getLaunchOptions() {
                Intent intent = getIntent();
                String flag="";
                Bundle bundle = new Bundle();
                if (intent.hasExtra("flag")){
                    flag = intent.getStringExtra("flag");
                    bundle.putString("flag",flag);
                }

                return bundle;
            }
        };
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 195,980评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,422评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,130评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,553评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,408评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,326评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,720评论 3 386
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,373评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,678评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,722评论 2 312
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,486评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,335评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,738评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,009评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,283评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,692评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,893评论 2 335