Fragment与Activity通讯
来源:互联网 发布:三星i9300软件下载 编辑:程序博客网 时间:2024/05/18 03:48
与activity通讯
尽管fragment的实现是独立于activity的,可以被用于多个activity,但是每个activity所包含的是同一个fragment的不同的实例。
Fragment可以调用getActivity()方法很容易的得到它所在的activity的对象,然后就可以查找activity中的控件们(findViewById())。例如:
ViewlistView =getActivity().findViewById(R.id.list);同样的,activity也可以通过FragmentManager的方法查找它所包含的frament们。例如:
activity响应fragment的事件
有时,你可能需要fragment与activity共享事件。一个好办法是在fragment中定义一个回调接口,然后在activity中实现之。
例如,还是那个新闻程序的例子,它有一个activity,activity中含有两个fragment。fragmentA显示新闻标题,fragmentB显示标题对应的内容。fragmentA必须在用户选择了某个标题时告诉activity,然后activity再告诉fragmentB,fragmentB就显示出对应的内容(为什么这么麻烦?直接fragmentA告诉fragmentB不就行了?也可以啊,但是你的fragment就减少了可重用的能力。现在我只需把我的事件告诉宿主,由宿主决定如何处置,这样是不是重用性更好呢?)。如下例,OnArticleSelectedListener接口在fragmentA中定义:
然后activity实现接口OnArticleSelectedListener,在方法onArticleSelected()中通知fragmentB。当fragment添加到activity中时,会调用fragment的方法onAttach(),这个方法中适合检查activity是否实现了OnArticleSelectedListener接口,检查方法就是对传入的activity的实例进行类型转换,如下所示:
如果activity没有实现那个接口,fragment抛出ClassCastException异常。如果成功了,mListener成员变量保存OnArticleSelectedListener的实例。于是fragmentA就可以调用mListener的方法来与activity共享事件。例如,如果fragmentA是一个ListFragment,每次选中列表的一项时,就会调用fragmentA的onListItemClick()方法,在这个方法中调用onArticleSelected()来与activity共享事件,如下:
onListItemClick()传入的参数id是列表的被选中的行ID,另一个fragment用这个ID来从程序的ContentProvider中取得标题的内容。
- Fragment与Activity通讯
- fragment与activity通讯
- Fragment与Activity通讯
- Fragment与Activity通讯
- Fragment与Activity通讯
- Fragment与Activity通讯
- Fragment与Activity通讯
- Fragment与Activity通讯
- Fragment与Activity通讯
- fragment与activity通讯
- Fragment与Activity的通讯
- Fragment与Activity的通讯
- Android Fragment与Activity通讯
- Android Fragment(四)---Fragment与Activity通讯
- Android Fragment详解(五):Fragment与Activity通讯
- Android Fragment详解(五):Fragment与Activity通讯
- Android Fragment详解(五):Fragment与Activity通讯
- Android Fragment详解(五):Fragment与Activity通讯
- spring使用xml配置mysql,mongodb,redis,activemq
- int和unsigned int的细节问题(重要细节)
- PATB1048:数字加密
- PATB1014:福尔摩斯的约会
- strlen和str.length()的区别 .
- Fragment与Activity通讯
- 循环语句
- GUi组件篇1
- JSP动作元素
- PATB1024:科学记数法
- ubuntu下jdk安装
- Codeforces Round #353 (Div. 2) E. Trains and Statistic (线段树+dp)
- Hadoop 2.6 MapReduce运行原理详解
- 入侵防御系统