虽然从Android 3.0(android-11)开始就建议使用Fragment、FragmentManager来替代ActivityGroup,但毕竟老版本还有很大的市场,一时半会不会选择那么高的版本,还得用ActivityGroup。
下面以一个简单的例子说明应该如何通过ActivityGroup来管理Activity。
程序截图:
图1 两个子Activity的截图
在屏幕底部是一排按钮(上图中的“Button1”和“Button2”),用于显示不同的TAB标签。
按钮上方的部分是Activity显示区域。
1 创建ActivityGroup对应的Layout
文件 layout/group1.xml
<?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" >
<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中为底部的按钮添加事件。
注意事项:
1、在显示新的Activity之前,需要先清除老的Activity。
2、新的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来接收用户的输入。
完整的工程代码见附件。
- 大小: 13.9 KB
- 大小: 20.1 KB
- 大小: 42.6 KB
- 大小: 39 KB
分享到:
相关推荐
`ActivityGroup`是`Sherlock`库中的一个类,它扩展了`Activity`,并提供了管理子`Activity`的能力。通过`LocalActivityManager`,我们可以启动、切换和管理子`Activity`,同时保持它们的状态。 在实现过程中,我们...
这个过程通常需要重写`startChildActivity()`方法,以便在ActivityGroup内部管理子Activity的生命周期。例如: ```java public void startChildActivity(String tag, Intent intent) { Window window = ...
为了实现这个功能,我们可以使用 ActivityGroup 来管理不同的 Activity。 首先,让我们来了解一下 ActivityGroup 的概念。ActivityGroup 是 Android 中的一种特殊的 Activity,它可以容纳多个 Activity,并且可以在...
这通常通过自定义的启动方法实现,如`startChildActivity()`,在该方法中,你需要管理Activity的生命周期,并将新Activity的视图添加到ActivityGroup的布局中。 Activity外跳转则是指从ActivityGroup中的子Activity...
在Android开发中,ActivityGroup是一种特殊类型的Activity,它允许开发者在一个Activity内嵌套其他Activity,实现类似TabHost或Fragment的效果,但这是在Android早期版本(API级别较低)中的一种实现方式。...
这样,在TabHost中,我们可以创建一个包含多个子Activity的ActivityGroup,而不是创建多个独立的Activity,从而简化了回退栈的管理和内存管理。 具体实现ActivityGroup的方法包括: 1. **定义ActivityGroup**:...
本文将详细讲解如何将这两个组件结合使用,以实现多Activity间的高效跳转和堆栈管理。 首先,TabHost是Android提供的一种布局容器,用于创建带有标签页的用户界面。它允许开发者在同一个界面上展示多个不同的视图,...
然而,由于它存在一些局限性和问题,如内存泄漏和生命周期管理复杂,从Android 3.0(API级别11)开始,官方推荐使用Fragment替代ActivityGroup。尽管如此,在某些场景下,开发者可能仍会使用ActivityGroup来实现特定...
尽管ActivityGroup已不再推荐使用,但它为我们理解Android中的Activity栈管理提供了一个历史视角。现在,我们应该使用Fragment和FragmentManager来实现更现代、更高效的界面堆栈管理,它们提供了更好的生命周期管理...
`ActivityGroup`在早期的Android版本中被用来解决在同一个栈内管理多个`Activity`的需求,但在Android 3.0(API Level 11)之后,官方推荐使用`Fragment`来替代,因为`Fragment`提供了更灵活且性能更好的解决方案。...
4. 子Activity的生命周期管理:由于ActivityGroup内嵌了Activity,所以必须手动处理子Activity的生命周期。例如,当用户在选项卡之间切换时,需要调用finish()方法结束当前子Activity,并启动新的子Activity。 5. ...
ActivityGroup是Android早期版本(API Level 13之前)提供的一种方式,用来在TabHost或者StackView等组件中嵌套管理Activity。它允许你在同一个窗口内启动和切换多个子Activity,使得这些子Activity看起来像是在一...
然而,自Android 3.0(API Level 11)起,官方推荐使用Fragment替代ActivityGroup,因为Fragment提供了更好的回退栈管理和生命周期管理。 在ActivityGroup中,我们主要关注以下几个关键知识点: 1. **...
2. **ActivityGroup的使用**:ActivityGroup通过覆盖onCreateView()和onDestroyView()方法来管理子Activity的生命周期。当用户点击某个标签时,ActivityGroup会调用这些方法来加载或销毁相应的视图。 3. **Intent的...
TabHost主要用于创建带有标签页的应用界面,而ActivityGroup则允许你在同一个父Activity下管理多个子Activity,使得在不同页面间切换时可以保持状态。下面我们将详细探讨这两个组件以及它们在实际应用中的用法。 **...
1. **LocalActivityManager的使用**:LocalActivityManager是ActivityGroup的核心,用于管理和维护子Activity。它提供了startActivity()、finishActivity()和saveInstanceState()等方法,用于启动、结束和保存子...
"TabHost内嵌ActivityGroup界面管理源码.zip"这个压缩包文件可能包含了一个使用旧版Android界面管理技术的示例项目,展示了如何利用TabHost创建带有标签的导航,以及如何使用ActivityGroup在单个Activity内实现界面...
使用LocalActivityManager的startActivity和windowFocusChanged方法可以启动和管理子Activity。startActivity方法会返回一个用于表示该Activity的别名ID,这个ID在后续操作中会被用到。 ```java Intent intent = ...
5. 添加子Activity:在ActivityGroup中,通过LocalActivityManager的startActivity()方法添加子Activity,并使用addWindow()方法将其添加到ActivityGroup的窗口栈中。 6. 在ActivityGroup中切换子Activity:根据...