android Fragments詳解六:處理fragement的生命週期

yangxi_001發表於2014-06-10

把條目新增到動作欄

你的fragment們可以向activity的選單(按Manu鍵時出現的東西)新增項,同時也可向動作欄(介面中頂部的那個區域)新增條目,這都需通過實現方法onCreateOptionManu()來完成。

你從fragment新增到選單的任何條目,都會出現在現有選單項之後。Fragment之後可以通過方法onOptionsItemSelected()來響應自己的選單項被選擇的事件。

你也可以在fragemnt中註冊一個view來提供快捷選單(上下文選單)。當使用者要開啟快捷選單時,fragmentonCreateContextMenu()方法會被呼叫。當使用者選擇其中一項時,fragemntonContextItemSelected()方法會被呼叫。

注:儘管你的fragment可以分別收到它所新增的選單項的選中事件,但是activity才是第一個接收這些事件的傢伙,只有當activity對某個事件置之不理時,fragment才能接收到這個事件,對於選單和快捷選單都是這樣。


處理fragement的生命週期

管理fragment的生命週期有些像管理activity的生命週期。Fragment可以生存在三種狀態:

Resumed:

Fragment在一個執行中的activity中並且可見。

Paused:

另一個activity處於最頂層,但是fragment所在的activity並沒有被完全覆蓋(頂層的activity是半透明的或不佔據整個螢幕)。

Stoped:

Fragment不可見。可能是它所在的activity處於stoped狀態或是fragment被刪除並新增到後退棧中了。此狀態的fragment仍然存在於記憶體中。

同樣類似於activity,你可以把fragment的狀態儲存在一個Bundle中,在activityrecreated時就需用到這個東西。你可以在onSaveInstanceState()方法中儲存狀態並在onCreate()onCreateView()onActivityCreated()中恢復,關於更多的儲存狀態的資訊,請參考Activitys章節。

FragmentActivity的生命週期中最大的不同就是儲存到後退棧中的過程。Activity是在停止時自動被系統壓入停止棧,並且這個棧是被系統管理的;而fragment是被壓入activity所管理的一個後退棧,並且只有你在刪除fragment後並明確呼叫addToBackStack()方法時才被壓入。

然而,管理fragment的生命週期與管理activity的生命週期極其相似。你所需要去思考的是activity的生命週期如何影響fragment的生命週期。



協調與activity生命週期的關係

Activity直接影響它所包含的fragment的生命週期,所以對activity的某個生命週期方法的呼叫也會產生對fragment相同方法的呼叫。例如:當activityonPause()方法被呼叫時,它所包含的所有的fragment們的onPause()方法都會被呼叫。

Fragmentactivity還要多出幾個生命週期回撥方法,這些額外的方法是為了與activity的互動而設立,如下:

onAttach()

fragment被加入到activity時呼叫(在這個方法中可以獲得所在的activity)。

onCreateView()

activity要得到fragmentlayout時,呼叫此方法,fragment在其中建立自己的layout(介面)

onActivityCreated()

activityonCreated()方法返回後呼叫此方法。

onDestroyView()

fragmentlayout被銷燬時被呼叫。

onDetach()

fragment被從activity中刪掉時被呼叫。

一旦activity進入resumed狀態(也就是running狀態),你就可以自由地新增和刪除fragment了。因此,只有當activityresumed狀態時,fragment的生命週期才能獨立的運轉,其它時候是依賴於activity的生命週期變化的。

轉自:http://blog.csdn.net/niu_gao/article/details/7185189

相關文章