• 谈谈Fragment中的onActivityResult


    大家或许有遇到这个神坑,在Fragment中使用startActivityForResult能够成功,可是在Fragment中的onActivityResult却无法被调用。一不注意就让人一夜愁白了头。苦经探索(当然包括亲爱的百度和谷歌),终于总结出了一些规律。

    在Fragment中使用startActivityForResult之后,onActivityResult的调用是从activity中开始的(即会先调用activity中的onActivityResult)。

    一.只嵌套了一层Fragment(比如activity中使用了viewPager,viewPager中添加了几个Fragment)

    在这种情况下要注意几个点:

    1.在Fragment中使用startActivityForResult的时候,不要使用getActivity().startActivityForResult,而是应该直接使startActivityForResult()。

    2.如果activity中重写了onActivityResult,那么activity中的onActivityResult一定要加上super.onActivityResult(requestCode, resultCode, data)。

    如果违反了上面两种情况,那么onActivityResult只能够传递到activity中的,无法传递到Fragment中的。

    没有违反上面两种情况的前提下,可以直接在Fragment中使用startActivityForResult和onActivityResult,和在activity中使用的一样。

    二.嵌套多层Fragment(比如activity中使用了viewPager,viewPager中添加了几个Fragment,即第一层Fragment。其中一个Fragment又使用了一个ViewPager,这个ViewPager又加入了几个Fragment,即第二层Fragment)

    在这种情况下activity中的onActivityResult调用无法传到第二层Fragment中。自己动手丰衣足食,我们只有手动传了。

    package neo.door.main;
    
    import java.util.List;
    
    import android.content.Intent;
    import android.support.v4.app.Fragment;
    import android.support.v4.app.FragmentActivity;
    import android.support.v4.app.FragmentManager;
    import android.util.Log;
    
    public class MyBaseFragmentActivity extends FragmentActivity
    {
        private String TAG="MyBaseFragmentActivity";
        @Override
        protected void onActivityResult(int requestCode, int resultCode, Intent data) 
        {
            super.onActivityResult(requestCode, resultCode, data);
            FragmentManager fragmentManager=getSupportFragmentManager();
            for(int indext=0;indext<fragmentManager.getFragments().size();indext++)
            {
                Fragment fragment=fragmentManager.getFragments().get(indext); //找到第一层Fragment
                if(fragment==null)
                     Log.w(TAG, "Activity result no fragment exists for index: 0x"  
                             + Integer.toHexString(requestCode));  
                else 
                    handleResult(fragment,requestCode,resultCode,data);
            }
        }
        /**
         * 递归调用,对所有的子Fragment生效
         * @param fragment
         * @param requestCode
         * @param resultCode
         * @param data
         */
        private void handleResult(Fragment fragment,int requestCode,int resultCode,Intent data) 
        {
            fragment.onActivityResult(requestCode, resultCode, data);//调用每个Fragment的onActivityResult
            Log.e(TAG, "MyBaseFragmentActivity");
            List<Fragment> childFragment = fragment.getChildFragmentManager().getFragments(); //找到第二层Fragment 
            if(childFragment!=null)
                for(Fragment f:childFragment)
                    if(f!=null)
                    {
                        handleResult(f, requestCode, resultCode, data);
                    }
            if(childFragment==null)
                Log.e(TAG, "MyBaseFragmentActivity1111");
        }
    
    }

    让activity继承上面的MyBaseFragmentActivity 。这样就手动把onActivityResult的调用传递到每一层的每一个Fragment里面了。然后在每一个Fragment里面重写onActivityResult就行了,然后根据requestCode和resultCode来分别执行对应事件。

    当然,不管是哪个Fragment调用startActivityForResult,onActivityResult的调用都会传递到每个Fragment中。

    同样需要注意:

    1.如果activity中重写了onActivityResult,那么activity中的onActivityResult一定要加上super.onActivityResult(requestCode, resultCode, data),否则也无法传进Fragment中。

    不过有点值得注意的是:

    在所有的Fragment中若是直接使用startActivityForResult(),那么传到activity中的onActivityResult中的requestCode就会不对,resultCode是对的,当然,这样的话传到每个Fragment中的onActivityResult的requestCode也是不对的(这里大家留意一下,评论里有人说传到Fragment中的是对的)。若是用getActivity().startActivityForResult,则传出来的requestCode和rusultCode就都是对的。

    当然若是直接按返回键返回,那么会自动给一个resultCode,这个resultCode和我们设定的是不一样的,因此在重写onActivityResult的时候需要判定resultCode。

    由于我们是手动将activity中的onActivityResult的调用传进每一层的每一个Fragment中去的,所以不管在Fragment中是使用startActivityForResult(),还是使用getActivity().startActivityForResult,都没关系,使用getActivity().startActivityForResult不会出现activity中onActivityResult中的调用无法传进去的情况。会影响的只有requestCode。

    转载请标明出处,维权必究:

    https://www.cnblogs.com/tangZH/p/5930491.html 

    http://77blogs.com/?p=11

  • 相关阅读:
    2016多校赛1 A 期望 B SG博弈,状压 D 倍增,二分
    POWOJ 1739: 魔术球问题 DAG最小路径覆盖转最大流
    Codeforces 743D 树形dp
    线性规划与网络流24题 索引
    WangEditor富文本编辑器的简单使用,并将文本数据发往后台
    SSRF
    关于Blind XXE
    blind xxe攻击
    linux awk命令详解
    kali
  • 原文地址:https://www.cnblogs.com/tangZH/p/5930491.html
Copyright © 2020-2023  润新知