雖然從Android 3.0(android-11)開始就建議使用Fragment、FragmentManager來替代ActivityGroup,但畢竟老版本還有很大的市場,一時半會不會選擇那麼高的版本,還得用ActivityGroup。android
下面以一個簡單的例子說明應該如何經過ActivityGroup來管理Activity。ide
程序截圖:佈局
圖1 兩個子Activity的截圖this
在屏幕底部是一排按鈕(上圖中的「Button1」和「Button2」),用於顯示不一樣的TAB標籤。spa
按鈕上方的部分是Activity顯示區域。orm
文件 layout/group1.xml xml
<?xml version="1.0" encoding="utf-8"?>blog <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"事件 android:layout_width="fill_parent"utf-8 android:layout_height="fill_parent" android:orientation="vertical" > <LinearLayout android:id="@+id/container1" android:layout_width="fill_parent" android:layout_height="fill_parent" android:layout_weight="1" android:orientation="vertical" > </LinearLayout>
<LinearLayout android:id="@+id/linearLayout1" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_gravity="bottom" android:orientation="horizontal" android:gravity="center" > <Button android:id="@+id/button1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Button1" android:background="@drawable/button_bg" /> <Button android:id="@+id/button2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Button2" android:background="@drawable/button_bg" /> </LinearLayout> </LinearLayout> |
在上面的佈局中,使用id爲container1 的 LinearLayout 來表示 Acvivity的顯示區域。另一個LinearLayout 則用來顯示屏幕底部的按鈕。
public class Group1 extends ActivityGroup { private static final String TAG = "Group1";
private LinearLayout container = null;
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.group1); Log.i(TAG, "onCreate");
container = (LinearLayout) findViewById(R.id.container1);
Button btnView1 = (Button) findViewById(R.id.button1); btnView1.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { launchActivity("View1", View1.class); } });
Button btnView2 = (Button) findViewById(R.id.button2); btnView2.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { launchActivity("View2", View2.class); } });
launchActivity("View1", View1.class); } private void launchActivity(String id, Class<?> activityClass) { container.removeAllViews();
Intent intent = new Intent(Group1.this, activityClass); intent.addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP);
Window window = getLocalActivityManager().startActivity(id, intent); View view = window.getDecorView(); container.addView(view); }
} |
從ActivityGroup 派生一個子類,在onCreate中爲底部的按鈕添加事件。
注意事項:
一、在顯示新的Activity以前,須要先清除老的Activity。
二、新的Activity以 FLAG_ACTIVITY_SINGLE_TOP 方式打開,這樣在子Activity之間切換時能夠複用已有的Activity實例,不用從新建立。
在View1中,顯示了一個TextView和一個EditText。
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" android:focusable="true" android:focusableInTouchMode="true"> <TextView android:id="@+id/textView1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/view1" /> <EditText android:id="@+id/editText1" android:layout_width="fill_parent" android:layout_height="wrap_content" > </EditText> </LinearLayout> |
public class View1 extends Activity {
private EditText editText; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.view1);
editText = (EditText) findViewById(R.id.editText1); }
@Override protected void onResume() { editText.clearFocus(); super.onResume(); }
} |
在View2中,顯示了一個TextView和一個ListView。
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" > <TextView android:id="@+id/textView1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/view2" /> <ListView android:id="@+id/item_list" android:layout_width="fill_parent" android:layout_height="wrap_content" > </ListView> </LinearLayout> |
public class View2 extends Activity { private ListView listView;
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.view2);
listView = (ListView)findViewById(R.id.item_list); listView.setAdapter(new ArrayAdapter<String>(this, android.R.layout.simple_expandable_list_item_1, getData())); }
private List<String> getData(){ List<String> data = new ArrayList<String>(26); for (int i=0; i<26; i++) { data.add("Item " + (char)('A' + i)); } return data; } } |
若是用戶在View2的界面下,按HOME回到Launcher,而後再經過Launcher返回View2,再按「Button1」切換到View1,若是點擊EditText,彈出的虛擬鍵盤會將按鈕區域頂到上方。
圖2 異常界面
正常狀況下應該是虛擬鍵盤覆蓋住按鈕。
圖3 正常界面
規避方法:不在子Acvivity中出現EditText,而是經過跳轉到新的Acvivity來接收用戶的輸入。
完整的工程代碼見附件。