Fragments之间的交互(实现参数传递)

日常开发中,通常Fragments之间可能需要交互,比如基于用户事件改变Fragment的内容。所有Fragment之间的交互需要通过他们关联的Activity,两个Fragment之间不应该直接交互。

采用接口回调的方式来实现Fragments之间的交互,大致分为四步:

1.定义一个接口

  • 为了让Fragment与Activity交互,可以在Fragment类中定义一个接口,并在Activity中实现。Fragment在它们的生命周期的onAttach()方法中获取接口的实现,然后调用接口的方法来与Activity交互。

定义接口的代码如下:

public class ListFragment extends Fragment implements AdapterView.OnItemClickListener {

    private ListView mListView;
private ListAdapter mAdapter;
private List<String> mData; public ListFragment() {
// Required empty public constructor
} public static ListFragment newInstance(String type) {
Bundle args = new Bundle();
args.putString("type", type);
ListFragment fragment = new ListFragment();
fragment.setArguments(args);
return fragment;
} @Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
if (mData == null) {
mData = new ArrayList<>();
}
loadData();
} private void loadData() {
for (int i = 0; i < 10; i++) {
mData.add("Item" + i);
}
} @Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// Inflate the layout for this fragment
View rootView = inflater.inflate(R.layout.fragment_list, container, false);
mListView = (ListView) rootView.findViewById(R.id.list_view); mAdapter = new ListAdapter(getActivity(), mData);
mListView.setAdapter(mAdapter);
mListView.setOnItemClickListener(this);
return rootView;
} @Override
public void onAttach(Context context) {
super.onAttach(context);
// This makes sure that the container activity has implemented
// the callback interface. If not, it throws an exception
try {
mOnListItemSelectedListener = (OnListItemSelectedListener) context;
} catch (ClassCastException e) {
throw new ClassCastException(context.toString()
+ " must implement OnListItemSelectedListener");
}
} @Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
mOnListItemSelectedListener.onListItemSelected(position);
} private OnListItemSelectedListener mOnListItemSelectedListener; public interface OnListItemSelectedListener {
void onListItemSelected(int position);
} /* ================适配器相关===============*/
public class ListAdapter extends BaseAdapter { private List<String> mData;
private Context mContext; public ListAdapter(Context context, List<String> data) {
this.mContext = context;
this.mData = data;
} @Override
public int getCount() {
return mData.size() == 0 ? 0 : mData.size();
} @Override
public Object getItem(int position) {
return mData == null ? null : mData.get(position);
} @Override
public long getItemId(int position) {
return position;
} @Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if (convertView == null) {
holder = new ViewHolder();
convertView = LayoutInflater.from(mContext).inflate(R.layout.item_list, parent, false);
holder.mTextView = (TextView) convertView.findViewById(R.id.text_view);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
String text = mData.get(position);
if (text != null && !"".equals(text)) {
holder.mTextView.setText(text);
}
return convertView;
} public class ViewHolder {
TextView mTextView;
}
} }
  • 现在Fragment就可以通过OnListItemSelectedListener 接口实例的mOnListItemSelectedListener中的onListItemSelected()方法与Activity传递消息。
  • 我这个例子实现的是在ListFragment中点击ListView的一个Item,把这个Item的position传递给DetailFragment,DetailFragment展示具体的信息,如新闻列表,点击Item之后进入新闻详情页。
  • 当我们点击Item时,ListFragment用回调接口来传递事件给父Activity。
 @Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
mOnListItemSelectedListener.onListItemSelected(position);
}

2.实现接口

  • 为了接收回调事件,宿主Activity必须实现Fragment中定义的接口。
  • MainActivity实现了ListFragment中的接口,如下代码:
public class MainActivity extends AppCompatActivity
implements ListFragment.OnListItemSelectedListener { private static final String TAG = "MainActivity"; private ListFragment mListFragment; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); mListFragment = ListFragment.newInstance("ListFragment");
ActivityUtil.addFragmentToActivity(getSupportFragmentManager(),
mListFragment, R.id.frame_container);
} @Override
public void onListItemSelected(int position) {
Log.d(TAG, position + "");
Bundle args = new Bundle();
args.putInt("position",position);
DetailFragment fragment = DetailFragment.newInstance("DetailFragment");
fragment.setArguments(args);
ActivityUtil.addFragmentToActivity(getSupportFragmentManager(), fragment, R.id.frame_container);
}
}

3.传递消息给Fragment

  • 宿主MainActivity中还包含了另外一个Fragment(DetailFragment),DetailFragment用来展示回调方法中指定Item的内容。在这种情况下,MainActivity可以把回调方法中接收到的position传递给DetailFragment。
 @Override
public void onListItemSelected(int position) {
Log.d(TAG, position + "");
Bundle args = new Bundle();
args.putInt("position",position);
DetailFragment fragment = DetailFragment.newInstance("DetailFragment");
fragment.setArguments(args);
ActivityUtil.addFragmentToActivity(getSupportFragmentManager(), fragment, R.id.frame_container);
}

4.接收传递的参数

  • 在DetailFragment中接收ListFragment传递的position参数
public class DetailFragment extends Fragment {

    private TextView mTextView;
private Bundle args; public DetailFragment() {
// Required empty public constructor
} public static DetailFragment newInstance(String type) {
Bundle args = new Bundle();
args.putString("type", type);
DetailFragment fragment = new DetailFragment();
fragment.setArguments(args);
return fragment;
} @Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
args = getArguments();//获取传递的参数
} @Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// Inflate the layout for this fragment
View rootView = inflater.inflate(R.layout.fragment_detail, container, false);
mTextView = (TextView) rootView.findViewById(R.id.text_view);
mTextView.setText(args.get("position").toString());
return rootView;
}
}

这样就实现了两个Fragment之间的交互。其核心就是拥有同一个宿主Activity的Fragments利用接口回调的方式实现参数的传递。

博客地址:http://tonycheng93.github.io/

源码地址:https://github.com/tonycheng93/Fragment2Fragment

Fragments之间的交互(实现参数传递)的更多相关文章

  1. Salesforce视图与控制器之间的交互

    刚接触Salesforce,过程的确是比较艰难了,中文资料几乎没有,看英文资料学的效率却不高,不过看了一段时间的英文资料发现自己英语水平挺高不少啊,现在看都不用工具翻译,早知道就再次尝试报个6级,看下 ...

  2. python基础--面向对象基础(类与对象、对象之间的交互和组合、面向对象的命名空间、面向对象的三大特性等)

    python基础--面向对象 (1)面向过程VS面向对象 面向过程的程序设计的核心是过程(流水线式思维),过程即解决问题的步骤,面向过程的设计就好比精心设计好一条流水线,考虑周全什么时候处理什么东西. ...

  3. 我的Android第五章:通过Intent实现活动与活动之间的交互

    Intent在活动的操作 作用: Itent是Android程序中各个组件直接交换的一个重要方式可以指定当前组件要执行任务同时也可以给各个组件直接进行数据交互              同时Inten ...

  4. AngularJs-指令和指令之间的交互(动感超人)

    前言: 上节我们学习到了指令和控制器之间的交互,通过给指令添加动作,调用了控制器中的方法.本节我们学习指令和指令之间是如何交互的,我们通过一个小游戏来和大家一起学习,听大漠老师说这是国外的人写的dem ...

  5. OC和JS之间的交互

    OC和JS之间的交互 目录 对OC和JS之间交互的理解 JS调用OC OC调用JS 对OC和JS之间交互的理解 JS调用OC JS文件 function sendCommand(cmd,param){ ...

  6. 安卓任意两个或多个Fragment之间的交互与刷新界面

    平时项目中遇到一个问题:在子fragment中刷新父fragment的界面,通俗的说也就是在任何一个fragment中来刷新另一个fragment.大家都知道activity和fragment之间的交 ...

  7. WPF自学入门(八)WPF窗体之间的交互

    今天我们一起来看一下WPF窗体之间的交互-窗体之间的传值.有两个窗体,一个是父窗体,一个是子窗体.要将父窗体的文本框中的值传递给子窗体中的控件.我们该怎么实现? 接下来我们一起来实现窗体之间的传值,在 ...

  8. python 全栈开发,Day18(对象之间的交互,类命名空间与对象,实例的命名空间,类的组合用法)

    一.对象之间的交互 现在我们已经有一个人类了,通过给人类一些具体的属性我们就可以拿到一个实实在在的人.现在我们要再创建一个狗类,狗就不能打人了,只能咬人,所以我们给狗一个bite方法.有了狗类,我们还 ...

  9. iOS原生和React-Native之间的交互1

    今天,记录一下iOS原生和React-Native之间的交互.如果第一次接触最好先移步至 http://www.cnblogs.com/shaoting/p/6388502.html 先看一下怎么在i ...

随机推荐

  1. CSS程序思想

    CSS的设计思想,比如:CSS预处理器.CSS对像(OOCSS).SMACSS.Atomic设计和OrganicCSS等             一.CSS预处理器最重要的功能:      1.连接: ...

  2. 基于.NET C#的 sqlite 数据库 ORM 【Easyliter】

    因为工作原因经常用到SQLITE数据库,但又找不到好用的ORM所以自个整理了一个简单好用的轻量极ORM框架:Easyliter 功能介绍: 1.支持SQL语句操作 2.支持 List<T> ...

  3. CentOS6.5菜鸟之旅:纯转载Linux目录结构

    来自:http://www.iteye.com/topic/1125162 使用linux也有一年多时间了  最近也是一直在维护网站系统主机  下面是linux目录结构说明 本人使用的是centos系 ...

  4. springMVC源码分析之拦截器

    一个东西用久了,自然就会从仅使用的层面上升到探究其原理的层面,在javaweb中springmvc更是如此,越是优秀的框架,其底层实现代码更是复杂,而在我看来,一个优秀程序猿就相当于一名武林高手,不断 ...

  5. 如何花样展示自己的摄影作品?CSS+JS+Html

    注意:Windows平台推荐使用Edge.Chrome.FireFox,部分浏览器打不开 P.S.慢慢用鼠标在图片上拖拽会感觉更神奇     // 0.5 ? 1 : -1; }, ease: fun ...

  6. jQuery的 delegate问题

    习惯了bind,用惯了live,就不习惯delegate了呀有木有... 支持为动态生成的标签元素绑定事件也许就live和delegate了吧,不过新版本已经不支持live了,只有delegate d ...

  7. 重构第12天 分解依赖(Break Dependencies)

    理解:“分解依赖” 是指对部分不满足我们要求的类和方法进行依赖分解,通过装饰器来达到我们需要的功能. 详解:今天我们所讲的这个重构方法对于单元测试是非常有用的.如果你要在你的代码中加入单元测试但有一部 ...

  8. UnityShader快速上手指南(三)

    简介 这一篇还是一些基本的shader操作:裁剪.透明和法向量的应用 (纠结了很久写不写这些,因为代码很简单,主要是些概念上的东西) 先来看下大概的效果图:(从左到右依次是裁剪,透明,加了法向量的透明 ...

  9. Equeue初识

    详细解说: http://www.cnblogs.com/netfocus/p/3595410.html 简单代码用法: Producer 端代码用法实例 和 Customer 端代码用法示例: ht ...

  10. DataList分页访问FooterTemplate模板里的控件

    今天做DataList分页的时候,突然想把分页控件写在FooterTemplate模板里面,弄了很久都访问不到控件,终于发现问题所在,以下是访问FooterTemplate里控件的方法: <Fo ...