当前位置: 首页 > news >正文

谈谈Fragment中的onActivityResult

    转载自http://www.cnblogs.com/tangZH/archive/2016/10/04/5930491.html     大家或许有遇到这个神坑,在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也是不对的。若是用getActivity().startActivityForResult,则传出来的requestCode和rusultCode就都是对的。     当然若是直接按返回键返回,那么会自动给一个resultCode,这个resultCode和我们设定的是不一样的,因此在重写onActivityResult的时候需要判定resultCode。     由于我们是手动将activity中的onActivityResult的调用传进每一层的每一个Fragment中去的,所以不管在Fragment中是使用startActivityForResult(),还是使用getActivity().startActivityForResult,都没关系,使用getActivity().startActivityForResult不会出现activity中onActivityResult中的调用无法传进去的情况。会影响的只有requestCode。

相关文章:

  • angular 2 - 002 - 基本概念和使用
  • CAD常用命令和快捷键的设置方法
  • 集合源码解析之HashMap(基于Java8)
  • 页面大小和页表项之间有必然的联系么?【转】
  • ZOJ1072 Microprocessor Simulation
  • IntelliJ IDEA 初始化项目时No Java SDK Found
  • MySql查询时间段的方法
  • NtQuerySystemInformation的使用
  • ASP.NET MVC2右键菜单和最简单分页
  • 2017年度中国SDN、NFV优秀案例投票正式启动
  • 扑朔迷离的属性和特性【彻底弄清】
  • 2.3. 插件
  • 四层、七层负载均衡的区别
  • 查找python项目依赖并生成requirements.txt——pipreqs 真是很好用啊
  • 从如何停掉 Promise 链说起
  • 4个实用的微服务测试策略
  • android高仿小视频、应用锁、3种存储库、QQ小红点动画、仿支付宝图表等源码...
  • Angularjs之国际化
  • docker python 配置
  • HTML-表单
  • javascript从右向左截取指定位数字符的3种方法
  • JAVA之继承和多态
  • Sublime text 3 3103 注册码
  • win10下安装mysql5.7
  • 看域名解析域名安全对SEO的影响
  • 让你的分享飞起来——极光推出社会化分享组件
  • 移动互联网+智能运营体系搭建=你家有金矿啊!
  • 正则表达式
  • 如何用纯 CSS 创作一个货车 loader
  • 智能情侣枕Pillow Talk,倾听彼此的心跳
  • ​RecSys 2022 | 面向人岗匹配的双向选择偏好建模
  • ​第20课 在Android Native开发中加入新的C++类
  • #1014 : Trie树
  • #绘制圆心_R语言——绘制一个诚意满满的圆 祝你2021圆圆满满
  • #微信小程序:微信小程序常见的配置传旨
  • (3)nginx 配置(nginx.conf)
  • (echarts)echarts使用时重新加载数据之前的数据存留在图上的问题
  • (Redis使用系列) Springboot 整合Redisson 实现分布式锁 七
  • (附源码)springboot助农电商系统 毕业设计 081919
  • (附源码)计算机毕业设计SSM保险客户管理系统
  • (求助)用傲游上csdn博客时标签栏和网址栏一直显示袁萌 的头像
  • ***监测系统的构建(chkrootkit )
  • .mysql secret在哪_MySQL如何使用索引
  • .Net Redis的秒杀Dome和异步执行
  • .NET6使用MiniExcel根据数据源横向导出头部标题及数据
  • .NET面试题解析(11)-SQL语言基础及数据库基本原理
  • /etc/sudoer文件配置简析
  • @PreAuthorize注解
  • [52PJ] Java面向对象笔记(转自52 1510988116)
  • [Android]通过PhoneLookup读取所有电话号码
  • [CC2642r1] ble5 stacks 蓝牙协议栈 介绍和理解
  • [Codeforces] combinatorics (R1600) Part.2
  • [CVPR 2023:3D Gaussian Splatting:实时的神经场渲染]
  • [C语言]——函数递归
  • [ERROR] ocp-server-ce-py_script_start_check-4.2.1 RuntimeError: ‘tenant_name‘