FragmentManager
為了管理Activity中的fragments,需要使用FragmentManager.
為了得到它,需要調用Activity中的getFragmentManager()方法。
因為FragmentManager的API是在Android 3.0,也即API level 11開始引入的,所以對于之前的版本,需要使用support library中的FragmentActivity,并且使用getSupportFragmentManager()方法。
用FragmentManager可以做的工作有:
得到Activity中存在的fragment:
使用findFragmentById()或findFragmentByTag()方法。
將fragment彈出back stack:
popBackStack():將back stack中最后一次的fragment轉換彈出。如果沒有可以出棧的東西,返回false。
這個函數是異步的:它將彈出棧的請求加入隊列,但是這個動作直到應用回到事件循環才會執行。
為back stack加上監聽器:
addOnBackStackChangedListener()
Performing Fragment Transactions
使用Fragment時,可以通過用戶交互來執行一些動作,比如增加、移除、替換等。
所有這些改變構成一個集合,這個集合被叫做一個transaction。
可以調用FragmentTransaction中的方法來處理這個transaction,并且可以將transaction存進由activity管理的back stack中,這樣用戶就可以進行fragment變化的回退操作。
可以這樣得到FragmentTransaction類的實例:
FragmentManager fragmentManager = getFragmentManager();

FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
每個transaction是一組同時執行的變化的集合。
用add(), remove(), replace()方法,把所有需要的變化加進去,然后調用commit()方法,將這些變化應用。
在commit()方法之前,你可以調用addToBackStack(),把這個transaction加入back stack中去,這個back stack是由activity管理的,當用戶按返回鍵時,就會回到上一個fragment的狀態。
比如下面的代碼就是用一個新的fragment取代之前的fragment,并且將前次的狀態存儲在back stack中。
// Create new fragment and transaction
Fragment newFragment = new ExampleFragment();
FragmentTransaction transaction = getFragmentManager().beginTransaction();

// Replace whatever is in the fragment_container view with this fragment,
// and add the transaction to the back stack
transaction.replace(R.id.fragment_container, newFragment);
transaction.addToBackStack(null);

// Commit the transaction
transaction.commit();
在這個例子中,newFragment將取代在R.id.fragment_container容器中的fragment,如果沒有,將直接添加新的fragment。
通過調用addToBackStack(),commit()的一系列轉換作為一個transaction被存儲在back stack中,用戶按Back鍵可以返回上一個轉換前的狀態。
當你移除一個fragment的時候,如果commit()之前沒有調用addToBackStack(),那個fragment將會是destroyed;如果調用了addToBackStack(),這fragment會是stopped,可以通過返回鍵來恢復。
關于commit()方法
調用commit()方法并不能立即執行transaction中包含的改變動作,commit()方法把transaction加入activity的UI線程隊列中。
但是,如果覺得有必要的話,可以調用executePendingTransactions()方法來立即執行commit()提供的transaction。
這樣做通常是沒有必要的,除非這個transaction被其他線程依賴。
注意:你只能在activity存儲它的狀態(當用戶要離開activity時)之前調用commit(),如果在存儲狀態之后調用commit(),將會拋出一個異常。
這是因為當activity再次被恢復時commit之后的狀態將丟失。如果丟失也沒關系,那么使用commitAllowingStateLoss()方法。
實例程序
寫了個小程序實踐了一下fragment的管理,程序不是很完善,就是試試基本用法,先按第一個按鈕添加一個fragment,第二個按鈕將其替換,第三個按鈕將第二個按鈕添加的fragment刪除。
相關代碼:
第一個fragment:
1
ExampleFragment.java
2
3
package com.xqsh.future;
4
5
import android.os.Bundle;
6
import android.support.v4.app.Fragment;
7
import android.util.Log;
8
import android.view.LayoutInflater;
9
import android.view.View;
10
import android.view.ViewGroup;
11
12
public class ExampleFragment extends Fragment
{
13
14
public static String TAG = "--ExampleFragment--";
15
@Override
16
public void onCreate(Bundle savedInstanceState)
{
17
// TODO Auto-generated method stub
18
super.onCreate(savedInstanceState);
19
Log.v(TAG, "oncreate");
20
}
21
22
@Override
23
public View onCreateView(LayoutInflater inflater, ViewGroup container,
24
Bundle savedInstanceState)
{
25
// TODO Auto-generated method stub
26
Log.v(TAG, "onCreateView");
27
return inflater.inflate(R.layout.example_fragment_layout,container,false);
28
}
29
30
@Override
31
public void onPause()
{
32
// TODO Auto-generated method stub
33
super.onPause();
34
Log.v(TAG, "onPause");
35
}
36
37
@Override
38
public void onResume()
{
39
// TODO Auto-generated method stub
40
super.onResume();
41
Log.v(TAG, "onResume");
42
}
43
44
@Override
45
public void onStop()
{
46
// TODO Auto-generated method stub
47
super.onStop();
48
Log.v(TAG, "onStop");
49
}
50
}
51
它的布局:
example_fragment_layout.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="wrap_content"
android:gravity="left"
android:textSize="20dip"
android:text="@string/fragment1"
/>
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/num1"
/>
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/num2"
/>
</LinearLayout>
第二個fragment:
1
NewFragment.java
2
3
package com.xqsh.future;
4
5
import android.os.Bundle;
6
import android.support.v4.app.Fragment;
7
import android.util.Log;
8
import android.view.LayoutInflater;
9
import android.view.View;
10
import android.view.ViewGroup;
11
12
public class NewFragment extends Fragment
{
13
public static String TAG = "--NewFragment--";
14
// 三個一般必須重載的方法
15
@Override
16
public void onCreate(Bundle savedInstanceState)
{
17
// TODO Auto-generated method stub
18
super.onCreate(savedInstanceState);
19
Log.v(TAG,"NewFragment--onCreate");
20
}
21
22
@Override
23
public View onCreateView(LayoutInflater inflater, ViewGroup container,
24
Bundle savedInstanceState)
{
25
Log.v(TAG,"NewFragment--onCreateView");
26
return inflater.inflate(R.layout.new_fragment_layout, container, false);
27
28
}
29
30
@Override
31
public void onPause()
{
32
// TODO Auto-generated method stub
33
super.onPause();
34
Log.v(TAG,"NewFragment--onPause");
35
}
36
37
}
38
它的布局:
new_fragment_layout.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="wrap_content"
android:gravity="left"
android:text="@string/fragment2"
android:textSize="20dip" />

<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/num3" />

<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/num4" />

</LinearLayout>
主Activity:
1
package com.xqsh.future;
2
3
import android.os.Bundle;
4
import android.support.v4.app.FragmentActivity;
5
import android.support.v4.app.FragmentManager;
6
import android.support.v4.app.FragmentTransaction;
7
import android.view.View;
8
import android.view.View.OnClickListener;
9
import android.widget.Button;
10
11
public class MainViewActivity extends FragmentActivity
{
12
13
private Button btn1,btn2,btn3;
14
private ExampleFragment fragmentE;
15
private NewFragment fragmentN;
16
private FragmentManager fragmentManager;
17
@Override
18
protected void onCreate(Bundle savedInstanceState)
{
19
super.onCreate(savedInstanceState);
20
setContentView(R.layout.activity_main_view);
21
findViews();
22
setListeners();
23
24
//獲得Fragment管理所需要的類的對象
25
fragmentManager = getSupportFragmentManager();
26
}
27
28
private void findViews()
{
29
btn1 = (Button) findViewById(R.id.btn1);
30
btn2 = (Button) findViewById(R.id.btn2);
31
btn3 = (Button) findViewById(R.id.btn3);
32
}
33
34
private void setListeners()
{
35
//第一個按鈕,增加一個ExampleFragment
36
btn1.setOnClickListener(new Button.OnClickListener()
{
37
@Override
38
public void onClick(View v)
{
39
// TODO Auto-generated method stub
40
//在程序中加入ExampleFragment
41
fragmentE = new ExampleFragment();
42
43
FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
44
fragmentTransaction.add(R.id.linear1,fragmentE);
45
fragmentTransaction.addToBackStack(null);
46
fragmentTransaction.commit();
47
}
48
});
49
50
btn2.setOnClickListener(new OnClickListener()
{
51
52
@Override
53
public void onClick(View v)
{
54
// TODO Auto-generated method stub
55
fragmentN = new NewFragment();
56
FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
57
fragmentTransaction.replace(R.id.linear1, fragmentN);
58
fragmentTransaction.addToBackStack(null);
59
fragmentTransaction.commit();
60
}
61
});
62
63
btn3.setOnClickListener(new OnClickListener()
{
64
@Override
65
public void onClick(View v)
{
66
// TODO Auto-generated method stub
67
FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
68
fragmentTransaction.remove(fragmentN);
69
fragmentTransaction.addToBackStack(null);
70
fragmentTransaction.commit();
71
}
72
});
73
}
74
}
75
它的布局:
activity_main_view.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/linear1"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >

<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_horizontal"
android:text="@string/layout1"
android:textSize="20dip" />

<Button
android:id="@+id/btn1"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/btn1" />

<fragment
android:id="@+id/fragment1"
android:name="com.xqsh.future.ExampleFragment"
android:layout_width="match_parent"
android:layout_height="wrap_content" />

<Button
android:id="@+id/btn2"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/btn2" />

<LinearLayout
android:id="@+id/linear2"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >

<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_horizontal"
android:text="@string/layout2"
android:textSize="20dip" />
<Button
android:id="@+id/btn3"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/btn3" />
</LinearLayout>

</LinearLayout>
資源:
1
<?xml version="1.0" encoding="utf-8"?>
2
<resources>
3
4
<string name="app_name">LearningFragment</string>
5
<string name="hello_world">Hello world!</string>
6
<string name="menu_settings">Settings</string>
7
<string name="title_activity_learn_fragment">LearnFragment</string>
8
9
<string name="layout1">LinearLayout1</string>
10
<string name="layout2">LinearLayout2</string>
11
12
<string name="fragment1">FragmentType1</string>
13
<string name="fragment2">FragmentType2</string>
14
15
<string name="num1">NO.1</string>
16
<string name="num2">NO.2</string>
17
<string name="num3">NO.3</string>
18
<string name="num4">NO.4</string>
19
20
<string name="btn1">Add fragment</string>
21
<string name="btn2">Replace fragment</string>
22
<string name="btn3">Remove fragment</string>
23
24
</resources>
程序運行截圖:

參考資料:
API Guides:Fragments
http://developer.android.com/guide/components/fragments.html
FragmentManager類文檔:
http://developer.android.com/reference/android/app/FragmentManager.html
FragmentTransaction類文檔
http://developer.android.com/reference/android/app/FragmentTransaction.html
轉載:http://www.cnblogs.com/mengdd/archive/2013/01/09/2853254.html
posted on 2015-05-18 18:28
Terry Zou 閱讀(419)
評論(0) 編輯 收藏 所屬分類:
Android