ActivityGroup 例子

雖然從Android 3.0(android-11)開始就建議使用Fragment、FragmentManager來替代ActivityGroup,但畢竟老版本還有很大的市場,一時半會不會選擇那麼高的版本,還得用ActivityGroup。android

下面以一個簡單的例子說明應該如何經過ActivityGroup來管理Activity。ide

程序截圖:佈局

 




 

     

 

圖1 兩個子Activity的截圖this

 

在屏幕底部是一排按鈕(上圖中的「Button1」和「Button2」),用於顯示不一樣的TAB標籤。spa

按鈕上方的部分是Activity顯示區域。orm

1 建立ActivityGroup對應的Layout

文件 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 則用來顯示屏幕底部的按鈕。

2 編寫 Group 代碼

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實例,不用從新建立。

 

 

3 編寫子Activity

3.1 View1

3.1.1 佈局

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>

3.1.2 代碼

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();

    }

    

}


3.2 View2

3.2.1 佈局

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>

3.2.2 代碼

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;

    }

}



4 已知問題

若是用戶在View2的界面下,按HOME回到Launcher,而後再經過Launcher返回View2,再按「Button1」切換到View1,若是點擊EditText,彈出的虛擬鍵盤會將按鈕區域頂到上方。


圖2 異常界面

 

正常狀況下應該是虛擬鍵盤覆蓋住按鈕。


圖3 正常界面

規避方法:不在子Acvivity中出現EditText,而是經過跳轉到新的Acvivity來接收用戶的輸入。

 

 

完整的工程代碼見附件。

 

轉載自:http://fanhongtao.iteye.com/blog/1430893

相關文章
相關標籤/搜索