fragment stack

原创 2015年11月19日 16:03:28
public class FragmentStackFragmentSupport extends Fragment {
    int mStackLevel = 1;


    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);


        if (savedInstanceState == null) {
            // Do first time initialization -- add initial fragment.
            Fragment newFragment = FragmentStackSupport.CountingFragment.newInstance(mStackLevel);
            FragmentTransaction ft = getChildFragmentManager().beginTransaction();
            ft.add(R.id.simple_fragment, newFragment).commit();
        } else {
            mStackLevel = savedInstanceState.getInt("level");
        }
    }


    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        View v = inflater.inflate(R.layout.fragment_stack, container, false);


        // Watch for button clicks.
        Button button = (Button)v.findViewById(R.id.new_fragment);
        button.setOnClickListener(new OnClickListener() {
            public void onClick(View v) {
                addFragmentToStack();
            }
        });
        button = (Button)v.findViewById(R.id.delete_fragment);
        button.setOnClickListener(new OnClickListener() {
            public void onClick(View v) {
                getChildFragmentManager().popBackStack();
            }
        });
        button = (Button)v.findViewById(R.id.home);
        button.setOnClickListener(new OnClickListener() {
            public void onClick(View v) {
                // If there is a back stack, pop it all.
                FragmentManager fm = getChildFragmentManager();
                if (fm.getBackStackEntryCount() > 0) {
                    fm.popBackStack(fm.getBackStackEntryAt(0).getId(),
                            FragmentManager.POP_BACK_STACK_INCLUSIVE);
                }
            }
        });


        return v;
    }


    @Override
    public void onSaveInstanceState(Bundle outState) {
        super.onSaveInstanceState(outState);
        outState.putInt("level", mStackLevel);
    }


    void addFragmentToStack() {
        mStackLevel++;


        // Instantiate a new fragment.
        Fragment newFragment = FragmentStackSupport.CountingFragment.newInstance(mStackLevel);


        // Add the fragment to the activity, pushing this transaction
        // on to the back stack.
        FragmentTransaction ft = getChildFragmentManager().beginTransaction();
        ft.replace(R.id.simple_fragment, newFragment);
        ft.setTransition(FragmentTransaction.TRANSIT_FRAGMENT_OPEN);
        ft.addToBackStack(null);
        ft.commit();
    }
}

FragmentStack的使用心得一

在工作中使用fragment的时候遇到的一些问题,写出来希望对其他人有一点帮助,也感谢那些无私的大神。这个文章是关于getBackStackEntryCount的注意...
  • huxl2015
  • huxl2015
  • 2017年02月23日 20:07
  • 275

简析 addToBackStack使用和Fragment执行流程

在使用Fragment的时候我们一般会这样写:         FragmentTransaction transaction = getSupportFragmentManager().beginT...
  • wenxuzl99
  • wenxuzl99
  • 2013年11月14日 14:46
  • 73237

纠正对Fragment Transaction BackStack的误解

目前在开发APP时,Fragment已经被g
  • guxiao1201
  • guxiao1201
  • 2014年10月26日 13:28
  • 24428

简析 addToBackStack使用和Fragment执行流程

在使用Fragment的时候我们一般会这样写:         FragmentTransaction transaction = getSupportFragmentManager().beginT...
  • wenxuzl99
  • wenxuzl99
  • 2013年11月14日 14:46
  • 73237

java_集合体系之Stack详解、源码及示例——06

摘要: 本文从Stack的结构图、源码、示例来说明Stack的特性、使用方法。...
  • chenghuaying
  • chenghuaying
  • 2013年12月23日 15:25
  • 3794

C++中stack的用法

转载:xueruifan的博客 C++ Stack(堆栈) 是一个容器类的改编,为程序员提供了堆栈的全部功能,——也就是说实现了一个先进后出(FILO)的数据结构。 c++ stl栈sta...
  • u012655441
  • u012655441
  • 2017年03月22日 16:10
  • 799

C2000 DSP中stack用量的计算

我本身是做电力电子软件的,一般这一行的代码不多,往往几行代码调几个月,比如并网算法、H桥控制。前段时间同事做通讯的时候,发现TMS320F280XX这款芯片有时会死机。他通讯的软件使用了TI给的库,自...
  • seabreeze1986
  • seabreeze1986
  • 2014年07月02日 14:13
  • 909

面试题思考:Stack和Heap的区别

堆和栈的区别
  • u014306011
  • u014306011
  • 2016年04月02日 15:30
  • 3289

STACK 栈函数

抽时间特地将数据结构 一章温习一遍。 看了下清华大学《数据结构》严蔚敏版的数据结构,看的真心很累,一股子浓浓的应试教育的风格扑面而来。实在是难受。 本想将数据结构和算法一起打发,却发现算法环节之精妙,...
  • hesiyuan4
  • hesiyuan4
  • 2013年12月11日 11:08
  • 1615

模型集成方法: Stacked generation

Stacked generation分为两个阶段   1. Level-0 generalizers Level-0 generalizers阶段生成Level-1 generalizers阶段...
  • hero_fantao
  • hero_fantao
  • 2014年06月22日 23:24
  • 2212
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:fragment stack
举报原因:
原因补充:

(最多只允许输入30个字)