专栏首页刘晓杰Fragment栈回退和传参方式

Fragment栈回退和传参方式

1.返回栈

当你需要点击返回键是返回上一个Fragment而不是直接退出Activity时,需要把之前的fragment加入返回栈。

ft.addToBackStack(null),然后重写退出键的方法。( public boolean onKeyDown(int keyCode, KeyEvent event) )

具体的解释点击打开链接

2.AVD横竖屏切换

我们都知道让AVD在横竖屏切换的时候,当前Activity中的fragment都会通过Fragment.instantiate重新生成,该方法将使用默认的构造函数来生成相应的Fragment。因此,使用

public PopFragment(String titleString) {
		this.titleString = titleString;
}

该方法来传参,然后new一个对象是不安全的。

可以通过getArguments获得之前设置的数据,其原理是在FragmentActivity切换时会调用onRetainNonConfigurationInstance方法将FragmentManager中管理的所有Fragment其状态数据(其中就包括了这个设置的Bundle)保存在一个FragmentActivity.NonConfigurationInstances对象实例中,这样在新的FragmentActivity启动时在onCreate方法中可以使用Activity.getLastNonConfigurationInstance()方法来获取这个对象,然后通过FragmentManager.restoreAllState方法还原所有Fragment及其状态,需要注意的是在这种情况下可能会出现之前的Fragment没有detach而处于活动状态导致该Fragment的视图生成,可能会造成两个Fragment视图重叠的情况,在官方的Support.v4的例子FragmentTabs.TabManager.addTab里有一段检查Fragment是否detach的代码正是用于解决这个问题。

具体代码我把它贴出来

PopActivity.java

public class PopActivity extends Activity{
	private Button one, two;
	
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.pop);
        
        one = (Button)findViewById(R.id.button1);
        two = (Button)findViewById(R.id.button2);
        one.setOnClickListener(new OnClickListener(){
			@Override
			public void onClick(View v) {
				PopFragment p1 = PopFragment.getInstance("one");
				FragmentTransaction ft = getFragmentManager().beginTransaction();
				ft.replace(R.id.content, p1);
				ft.addToBackStack(null);////////////
				ft.commit();
			}
        });
        
        two.setOnClickListener(new OnClickListener(){
			@Override
			public void onClick(View v) {
				PopFragment p1 = PopFragment.getInstance("two");
				FragmentTransaction ft = getFragmentManager().beginTransaction();
				ft.replace(R.id.content, p1);
				ft.addToBackStack(null);///////////////////////////
				ft.commit();
			}
        });
    }

	@Override
	public boolean onKeyDown(int keyCode, KeyEvent event) {//实现回退
        if (keyCode == KeyEvent.KEYCODE_BACK) {
        	if(getFragmentManager().getBackStackEntryCount() == 0){
        		finish();
        	}else{
        		getFragmentManager().popBackStack();// 返回上一个fragment
        	}
        }
        return super.onKeyDown(keyCode, event);
    }
}

对应的pop布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity" >

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="one" />

    <Button
        android:id="@+id/button2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="two" />

    <FrameLayout
        android:id="@+id/content"
        android:layout_width="match_parent"
        android:layout_height="match_parent" >
    </FrameLayout>

</LinearLayout>

PopFragment.java

public class PopFragment extends Fragment {
	
	public static PopFragment getInstance(String title){//安全的传参方式
		PopFragment popFragment = new PopFragment();
		Bundle bundle = new Bundle();
		bundle.putString("title", title);
		popFragment.setArguments(bundle);
		return popFragment;
	}

	@Override
	public View onCreateView(LayoutInflater inflater, ViewGroup container,
			Bundle savedInstanceState) {
		// TODO Auto-generated method stub
		View view = inflater.inflate(R.layout.pop_test, container, false);
		TextView tView = (TextView)view.findViewById(R.id.textView1);
		tView.setText(getArguments().getString("title"));
		return view;
	}
}

对应的pop_test布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity" >

    <TextView
        android:id="@+id/textView1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />

</LinearLayout>

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • flutter混合开发运行报错:VM snapshot must be valid. /Check failed: vm. Must be able to initialize the VM.

    找遍了google和flutter github的issue, 目前发现的可行解决办法如下: 1.在flutter module的build文件的andr...

    coderZhen
  • 史上最全的Android开发学习教程集锦【初学者】

    根据Google的报告,截止2017年5月为止,Android活跃用户已超过20亿,并还在持续增长中。Android系统在几个主要的市场上已超过了iOS系统,特...

    奔跑的小鹿
  • Android Clean 架构

    Clean 一般是指,代码以洋葱的形状依据一定的依赖规则被划分为多层:内层对于外层一无所知。这就意味着依赖只能由外向内。

    用户3596197
  • 对开源的认知

    没有开源软件,现在的互联网根本无法存在,开源的历史可以追溯到ARPANET建立。开源在今天已经不再是一个时髦的词了,对于互联网的开发者来说,它现在就像空气和水一...

    半吊子全栈工匠
  • Flutter: Semantics控件

    前言 如果你读过有关于Flutter的代码,那么你有时候你会注意到Semantics或者SemanticsConfiguration,但官方文档却对这个很有趣...

    JarvanMo
  • Android使用bindService作为中间人对象开启服务

    <pre spellcheck="false" class="md-fences md-end-block contain-cm modeLoaded" lan...

    Dream城堡
  • Dart 笔记 13 - 库

    只有一个表达式的函数,可以简写,类似 Kotlin。=> 后跟着一条表达式,不能是语句,比如 if 语句。

    七适散人
  • Java项目转VS code

    近期更换了电脑,上一部电脑的开发环境和代码都找不回来。幸好上一篇中通过自建的Git仓库保存了自己平常开发的Java项目,而且项目是由Gradle进行构建的,所以...

    Jeffery
  • 安卓中gravity和layout_gravity的区别

    (1).android:gravity:是对view控件本身来说的,是用来设置view本身的内容应该显示在view的什么位置,默认值是左侧。也可以用来设置布局中...

    ZY_FlyWay
  • android的电话监听

    Dream城堡

扫码关注云+社区

领取腾讯云代金券