多篇文章摘录
在一个主界面中做Activity切换一般都会用TabActivity,使用方便,Activity互相之间相对独立,但是可定制性不强,而且修改起来很麻烦。当然也可以把layout分开,把逻辑代码全写在主界面的逻辑代码中,但是很明显可维护性相当差,这里通过ActivityGroup来解决这个问题。
基本使用情况
1.ActivityGroup的核心就是继承了该类,能够通过getLocalActivityManager()得到一个LocalActivityManager
如,LocalActivityManager am= getLocalActivityManager();
2.然后通过LocalActivityManager通过startActivity(String id, Intent intent),可以与指定的Actiivty绑定,并且返回一个Window。LocalActivityManager可以同时管理多个Activity
Window window1 = am.startActivity("Module1", newIntent(TestView.this, ModuleView1.class));
Window window2 = am.startActivity("Module2", newIntent(TestView.this, ModuleView2.class));
3.然后Window可以通过getDecorView()方法,返回一个View,然后通过与指定容器的addView(View)方法,实现不同的效果
View view1 = window1.getDecorView()
View view2 = window2.getDecorView()
实际中多用简写形式,如,
container是ScrollView的一个实例
container.removeAllViews(); //移除其他所有子视图
container.addView(getLocalActivityManager().startActivity(
"Module2",
new Intent(TestView.this, ModuleView2.class)
.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP) )
.getDecorView());
注意:
container.removeAllViews():表示在显示该视图之前,先移除其他所有视图.
Intent.FLAG_ACTIVITY_CLEAR_TOP:如果在当前Task中,有要启动的Activity,那么把该Acitivity之前的所有Activity都关掉,并把此Activity置前以避免创建Activity的实例
这种方式具有很大的灵活性,常用的就是实现TabHost分页效果,但很好的避免的TabHost的缺点,如title等
public class MainActivityGroup extends ActivityGroup {
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); requestWindowFeature(Window.FEATURE_NO_TITLE); setContentView(R.layout.main_layout);
}
}
布局文件的weight属性这里第一次派上了用途,我的布局类似新浪微博的界面,上边是一个刷新按钮跟文字,下面是一排ImageView来点击切换Activity,中间是Activity的布局。上下的高度定义好以后,我要让activity充满剩余空间,就用了weight=1这个属性。其他用法暂时没用到。
点击开始用ActivityGroup来启动子Activity:
1,activity_container(这是Group布局里面的用来装Activity的Layout)要移除所有的view
activity_container.removeAllViews();
2,增加view到里面
activity_container.addView(
this.getLocalActivityManager().startActivty(str_id,intent).getDecorView());
其中的ActivityManager是ActivityGroup私有的一个成员,用来管理子Activity,这里用来启动。参数是id,和一个intent对象。根据id用key-value的方式,把intent放入到自己的Map里面,用于自己的管理。
(1)当StartActivity时,如果key是不存在的,那么启动一个新的Activity,然后把key与intent放到自己的map
这就跟Intent的Flag相关了。第一,如果当前的Activity的intent.Flag设置的是多模式或者FLAG_ACTIVITY_SINGLE_TOP,那么子Activity就会被切换到后台,调用Intent传来的Activity,这个新的Activity也会根据自身的Flag,而出现不同的生命周期变化。
举个例子,如果每个子Activity都是这样的方式启动的
getLocalActivityManager().
startActivity(CampusConstants.ID_ACTIVITY[id], new Intent(MainActivityGroup.this,activity).
addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP)).getDecorView());
如果使用的是