今天讲解一下Fragment的控制,主要是切换View和页面替换等操做。还有就是如何获取Fragment的管理对象,以及与Activity的通讯方式。
一、管理Fragment
要在activity中管理fragment,须要使用FragmentManager. 经过调用activity的getFragmentManager()取得它的实例.android
•能够经过FragmentManager作一些事情, 包括: 使用findFragmentById()(用于在activity layout中提供一个UI的fragment)或findFragmentByTag()(适用于有或没有UI的fragment)获取activity中存在的fragment。
•将fragment从后台堆栈中弹出, 使用 popBackStack() (模拟用户按下BACK 命令)。
•使用addOnBackStackChangeListener()注册一个监听后台堆栈变化的listener。动画
二、处理Fragment事务
关于在activity中使用fragment的很强的一个特性是:根据用户的交互状况,对fragment进行添加、移除、替换以及执行其余动做。提交给activity的每一套变化被称为一个事务,可使用在FragmentTransaction中的 API 处理。咱们也能够保存每个事务到一个activity管理的backstack,容许用户经由fragment的变化往回导航(相似于经过 activity日后导航)。this
从 FragmentManager 得到一个FragmentTransaction实例:spa
在调用commit()以前,你可能想调用 addToBackStack(),将事务添加到一个fragment事务的backstack。这个back stack由activity管理, 并容许用户经过按下 BACK按键返回到前一个fragment状态。.net
若是添加多个变化到事务(例如add()或remove())并调用addToBackStack(),而后在你调用commit()以前的全部应用的变化会被做为一个单个事务添加到后台堆栈,BACK按键会将它们一块儿回退。添加变化到 FragmentTransaction的顺序不重要, 除如下例外: 线程
•必须最后调用 commit()
•若是添加多个fragment到同一个容器, 那么添加的顺序决定了它们在view hierarchy中显示的顺序code
当执行一个移除fragment的事务时, 若是没有调用 addToBackStack(), 那么当事务提交后,那个fragment会被销毁,而且用户不能导航回到它。有鉴于此,当移除一个fragment时,若是调用了addToBackStack(), 那么fragment会被中止,若是用户导航回来,它将会被恢复。另外,对于每个fragment事务,你能够应用一个事务动画,经过在提交事务以前调用setTransition()实现。htm
调用 commit() 并不当即执行事务。偏偏相反,它将事务安排排期, 一旦准备好,就在activity的UI线程上运行(主线程)。若是有必要, 不管如何,你能够从你的UI线程调用executePendingTransactions()来当即执行由commit()提交的事务。但这么作一般没必要要,除非事务是其余线程中的任务的一个从属。
警告:你只能在activity保存它的状态(当用户离开activity)以前使用commit()提交事务.
三、与Activity通讯
尽管Fragment被实现为一个独立于Activity的对象,而且能够在多个activity中使用,但一个给定的fragment实例是直接绑定到包含它的activity的。 特别的fragment可使用 getActivity() 访问Activity实例, 而且容易地执行好比在activity layout中查找一个view的任务。以下面的代码:对象