Fragment跳转时传递参数及结果回传的方法(推荐)
今天总结一下Fragment间的参数传递及结果返回的方法。
效果图:
1、点击“加载第二个Fragment按钮”,加载出第二个Fragment,同时传递过去参数:“从Fragment1传来的参数”这几个String;
2、当用户点击第二个Fragment中的几个图片时,将点中的结果返回给第一个Fragment,将用户的选择在第一个Fragment显示出来
一、基本架构搭建
首先,我们要把整个架构搭起来,然后再进行参数传递和回传
(一)、基本XML构建:
根据上面的效果,大家很容易看到两个Fragment的布局:
1、Fragment1的布局:(fragment1.xml)
很简单,垂直布局,上面一个ImageView来盛装返回过来的图片结果,下面一个Button来用来点击加载第二个Fragment;
<LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#ffffff" android:orientation="vertical"> <ImageView android:id="@+id/img_result" android:layout_width="100dp" android:layout_height="100dp" android:scaleType="center"/> <Button android:id="@+id/load_fragment2_btn" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="加载第二个Fragment"/> </LinearLayout>
2、Fragment2的布局:(fragment2.xml)
这个也是垂直布局,上面的一个TextView用来盛装从Fragment1传过来的String参数,下面的几个ImageView用来显示几个供用户选择的图片
<LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#ffffff" android:orientation="vertical"> <TextView android:id="@+id/textview" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Thisisfragment2" android:textColor="#000000" android:textSize="25sp"/> <ImageView android:id="@+id/img1" android:layout_width="100dip" android:layout_height="100dp" android:scaleType="center" android:src="@drawable/animal1"/> <ImageView android:id="@+id/img2" android:layout_width="100dip" android:layout_height="100dp" android:scaleType="center" android:src="@drawable/animal2"/> <ImageView android:id="@+id/img3" android:layout_width="100dip" android:layout_height="100dp" android:scaleType="center" android:src="@drawable/animal3"/> <ImageView android:id="@+id/img4" android:layout_width="100dip" android:layout_height="100dp" android:scaleType="center" android:src="@drawable/animal4"/> </LinearLayout>
(二)对应的Fragment类
1、在MainActivity初始化时,将Fragment1显示出来:
MainActivity对应的XML文件:(main_activity.xml)
<RelativeLayoutxmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/main_layout" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity"> <TextView android:text="@string/hello_world" android:layout_width="wrap_content" android:layout_height="wrap_content"/> </RelativeLayout>
对应的代码:
publicclassMainActivityextendsActivity{ @Override protectedvoidonCreate(BundlesavedInstanceState){ super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Fragment1fragment1=newFragment1(); getFragmentManager().beginTransaction().replace(R.id.main_layout,fragment1).commit(); } }
2、Fragment1:在用户点击时,将fragment2添加到当前页面显示出来;
publicclassFragment1extendsFragment{ @Override publicViewonCreateView(LayoutInflaterinflater,ViewGroupcontainer, BundlesavedInstanceState){ Viewview=inflater.inflate(R.layout.fragment1,container,false); Buttonbtn=(Button)view.findViewById(R.id.load_fragment2_btn); btn.setOnClickListener(newView.OnClickListener(){ @Override publicvoidonClick(finalViewview){ Fragment2fragment2=newFragment2(); FragmentTransactiontransaction=getFragmentManager().beginTransaction(); transaction.add(R.id.main_layout,fragment2); transaction.addToBackStack(null); transaction.commit(); } }); returnview; } }
3、Fragment2:至于目前的它还是很简单的,只要能显示出来就好了,所以他的代码为:
publicclassFragment2extendsFragmentimplementsView.OnClickListener{ @Override publicViewonCreateView(LayoutInflaterinflater,ViewGroupcontainer,BundlesavedInstanceState){ Viewview=inflater.inflate(R.layout.fragment2,container,false); returnview; } }
二、Fragment间参数传递
至于Fragment间参数为什么要用SetArguments来传递,我就不讲了,看这篇文章:《Android解惑-为什么要用Fragment.setArguments(Bundlebundle)来传递参数》,我这里只说项目中如何使用:
在Fragment2中,新建一个函数:newInstance(String text)来接收传过来的参数:
新建一个Fragment2实例,然后将参数通过SetArguments设置到其中;
publicstaticFragment2newInstance(Stringtext){ Fragment2fragment=newFragment2(); Bundleargs=newBundle(); args.putString("param",text); fragment.setArguments(args); returnfragment; }
然后在Fragment2的OnCreateView的时候再从arguments中获取参数:
publicViewonCreateView(LayoutInflaterinflater,ViewGroupcontainer,BundlesavedInstanceState){ Viewview=inflater.inflate(R.layout.fragment2,container,false); if(getArguments()!=null){ StringmParam1=getArguments().getString("param"); TextViewtv=(TextView)view.findViewById(R.id.textview); tv.setText(mParam1); } returnview; }
在Fragment1中,在调起Fragmen2t时,通过调用newInstance函数来获取实例并传递参数:
publicclassFragment1extendsFragment{ @Override publicViewonCreateView(LayoutInflaterinflater,ViewGroupcontainer, BundlesavedInstanceState){ Viewview=inflater.inflate(R.layout.fragment1,container,false); Buttonbtn=(Button)view.findViewById(R.id.load_fragment2_btn); btn.setOnClickListener(newView.OnClickListener(){ @Override publicvoidonClick(finalViewview){ Fragment2fragment2=Fragment2.newInstance("从Fragment1传来的参数"); FragmentTransactiontransaction=getFragmentManager().beginTransaction(); transaction.add(R.id.main_layout,fragment2); transaction.addToBackStack(null); transaction.commit(); } }); returnview; } }
(三)、从Fragment2向Fragment1回传参数
这里只有利用回调,有关回调传递参数的问题,我在前一篇文章中:《详解Dialog(三)——自定义对话框视图及参数传递》第三部分:参数传递;详细讲过,大家可以先看源码,如果源码不懂,可以参考下这篇文章,这里就不再赘述。