- 其中大多數程序必須使用Fragments 必須實現的三個回調方法分別爲:
- onCreate
- 系統創建Fragments 時調用,可做執行初始化工作或者當程序被暫停或停止時用來恢復狀態,跟Activity 中的onCreate相當。
- onCreateView
- 用於首次繪製用戶界面的回調方法,必須返回要創建的Fragments 視圖UI。假如你不希望提供Fragments 用戶界面則可以返回NULL。
- onPause
- 當用戶離開這個Fragments 的時候調用,這時你要提交任何應該持久的變化,因爲用戶可能不會回來。
- 系統內置了三種Fragments ,這三種Fragments 分別有不同的應用場景分別爲:
- DialogFragment
- 對話框式的Fragments,可以將一個fragments 對話框併到activity 管理的fragments back stack 中,允許用戶回到一個前曾摒棄fragments.
- ListFragments
- 類似於ListActivity 的效果,並且還提供了ListActivity 類似的onListItemCLick和setListAdapter等功能。
- PreferenceFragments
- 類似於PreferenceActivity .可以創建類似IPAD的設置界面。
可以分爲下面的幾部分:
- 使用支持庫
- 創建一個Fragment
- 創建一個動態UI
- 多個Fragment之間的通信
1、使用支持庫
如果您的應用需要運行在3.0及以上的版本,可以忽略這部分內容。
如果您的應用使用在3.0以下、1.6及以上的版本,需要使用支持庫來構建。android-support-v4.jar
2、創建一個Fragment
Fragment支持在不同的Activity中使用並且可以處理自己的輸入事件以及生命週期方法等。可以看做是一個子Activity。
創建一個Fragment
創建一個Fragment和創建一個Activity很類似,繼承Fragment類,重寫生命週期方法,主要的不同之處就是需要重寫一個onCreateView()方法來返回這個Fragment的佈局
- public class Fragment1 extends Fragment{
- @Override
- public View onCreateView(LayoutInflater inflater, ViewGroup container,
- Bundle savedInstanceState) {
- // TODO Auto-generated method stub
- super.onCreateView(inflater, container, savedInstanceState);
- return inflater.inflate(R.layout.fragment, container,false);
- }
- }
Fragment的生命週期方法依賴於Activity的生命週期,例如一個Activity的onPause()的生命週期方法被調用的時候這個Activity中的所有的Fragment的onPause()方法也將被調用。
使用XML添加Fragment到Activity
儘管Fragment可以被多個Activity重用,但是您也必須把Fragment關聯到一個FragmentActivity上。可以使用XML佈局文件的方式來實現這種關聯。
上面的所說的FragmentActivity適用在API在3.0以下的版本,3.0及以上的版本可以使用普通的Activity。
fragment.xml
- <?xml version="1.0" encoding="utf-8"?>
- <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="match_parent"
- android:layout_height="match_parent"
- android:orientation="vertical" >
- <TextView
- android:layout_width="match_parent"
- android:layout_height="match_parent"
- android:text="Fragment" />
- </LinearLayout>
activity_main.xml
- <?xml version="1.0" encoding="utf-8"?>
- <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="match_parent"
- android:layout_height="match_parent"
- android:orientation="vertical" >
- <!-- 使用fragment標籤,android:name=””指定一個添加到xml中的Fragment -->
- <fragment
- android:id="@+id/fragment1"
- android:name="com.example.demo.Fragment.Fragment1"
- android:layout_width="match_parent"
- android:layout_height="0dp"
- android:layout_weight="1" >
- </fragment>
- <fragment
- android:id="@+id/fragment2"
- android:name="com.example.demo.Fragment.Fragment1"
- android:layout_width="match_parent"
- android:layout_height="0dp"
- android:layout_weight="1" >
- </fragment>
- </LinearLayout>
MainActivity.java
- //3.0以下必須使用FragmentActivity
- public class MainActivity extends FragmentActivity {
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- }
- }
Fragment1.java
- public class Fragment1 extends Fragment{
- @Override
- public View onCreateView(LayoutInflater inflater, ViewGroup container,
- Bundle savedInstanceState) {
- // TODO Auto-generated method stub
- super.onCreateView(inflater, container, savedInstanceState);
- return inflater.inflate(R.layout.fragment, container,false);
- }
- }
上面就是第一個例子的代碼 可運行在3.0以下的系統上
當您添加一個片段一個活動佈局定義的佈局XML文件中的片段,你不能刪除在運行時的片段。如果您打算在用戶交互和交換片段,你必須添加的活性片段的活動時第一次啓動。
3、構建一個靈活的UI
FragmentManager提供了對Activity運行時的Fragment的添加、刪除、替換的操作。
在Activity運行期間你可以添加Fragment而不是在XML佈局文件中進行定義。如果你打算在Activity中改變Fragment的生命過程。
如果要執行添加、刪除、修改的操作,你必須通過FragmentManager的對象獲得一個FragmentTransaction對象,通過它的API來執行這些操作。
添加一個Fragment到一個Activity,必須把這個Fragment添加到一個容器視圖中。
在Activity中你可以通過getFragmentManager()來獲得Fragment對象,然後通過FragmentManager對象的beginFragmentTransaction()方法來獲得FragmentTransaction對象。通過它的add()方法來添加一個Fragment到當前的Activity中。
activity_main.xml
- <?xml version="1.0" encoding="utf-8"?>
- <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:id="@+id/fragment_container"
- android:layout_width="match_parent"
- android:layout_height="match_parent"
- android:orientation="vertical" >
- </LinearLayout>
一個FragmentTransaction對象可以執行多個增刪修的方法,如果你想把這些修改提交到Activity上,必須在最後調用一下這個對象的commit()方法。
- public class MainActivity extends FragmentActivity {
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- Fragment1 fragment1 = new Fragment1();
- //3.0之前需要getSupportFragmentManager()
- //3.0之後只需getFragmentManager()
- getSupportFragmentManager().beginTransaction()
- .add(R.id.fragment_container, fragment1).commit();
- }
- }
如果替換或者刪除一個Fragment然後讓用戶可以導航到上一個Fragment,你必須在調用commit()方法之前調用addToBackStack()方法添加到回退棧。如果你把這個Fragment添加到了回退棧,在提交之後這個Fragment是會被Stop而不是Destroyed。如果用戶導航到這個Fragment,這個Fragment會被Restart而不是重新創建。如果你沒有把它添加到回退棧,則在刪除或者替換的時候它將被Destroyed。
- public class MainActivity extends FragmentActivity {
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- Fragment1 fragment1 = new Fragment1();
- // 3.0之前需要getSupportFragmentManager()
- // 3.0之後只需getFragmentManager()
- FragmentTransaction transaction = getSupportFragmentManager()
- .beginTransaction();
- transaction.replace(R.id.fragment_container, fragment1);
- transaction.addToBackStack(null);
- transaction.commit();
- }
- }
4、與其他Fragment的交互
兩個單獨的Fragment之間是不應該進行通信的。應該使用他們所存在的Activity作爲溝通的紐帶。
爲了實現兩個Fragment的交互,您可以在Fragment中定義一個接口,然後再這個接口中定義一個方法,在Fragment的onAttach()方法中調用這個接口中的方法。然後讓Activity實現這個方法來完成Activity和Fragment之間的通信。
- public class MainActivity extends FragmentActivity implements Fragment1.Testinterface{
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- Fragment1 fragment1 = new Fragment1();
- // 3.0之前需要getSupportFragmentManager()
- // 3.0之後只需getFragmentManager()
- FragmentTransaction transaction = getSupportFragmentManager()
- .beginTransaction();
- transaction.replace(R.id.fragment_container, fragment1);
- transaction.addToBackStack(null);
- transaction.commit();
- }
- @Override
- public void Test(String msg) {
- // TODO Auto-generated method stub
- Log.e("----", msg);
- }
- }
- package com.example.demo.Fragment;
- import com.example.demo.R;
- import android.app.Activity;
- import android.os.Bundle;
- import android.support.v4.app.Fragment;
- import android.view.LayoutInflater;
- import android.view.View;
- import android.view.ViewGroup;
- public class Fragment1 extends Fragment{
- Testinterface testinterface;
- public interface Testinterface{
- public void Test(String msg);
- }
- @Override
- public void onAttach(Activity activity) {
- // TODO Auto-generated method stub
- super.onAttach(activity);
- try {
- testinterface = (Testinterface)activity;
- } catch (Exception e) {
- // TODO: handle exception
- System.err.println(e.toString());
- }
- }
- @Override
- public View onCreateView(LayoutInflater inflater, ViewGroup container,
- Bundle savedInstanceState) {
- // TODO Auto-generated method stub
- super.onCreateView(inflater, container, savedInstanceState);
- testinterface.Test("測試");
- return inflater.inflate(R.layout.fragment, container,false);
- }
- }