ActivityGroup相关--getLocalActivityManager()

ActivityGroup简介


ActivityGroup相关--getLocalActivityManager()_第1张图片
1.ActivityGroup
的核心就是继承了该类,能够通过getLocalActivityManager()得到一个LocalActivityManager

,LocalActivityManager  am= this.getLocalActivityManager();

2.
然后通过LocalActivityManager通过startActivity(String id, Intent intent),可以与指定的Actiivty绑定,并且返回一个WindowLocalActivityManager可以同时管理多个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()

实际中多用简写形式,,
containerScrollView的一个实例

[java]  view plain copy
  1. container.removeAllViews();     //移除其他所有子视图  
  2. container.addView(getLocalActivityManager().startActivity(  
  3.                        "Module2",  
  4.                        new Intent(TestView.this, ModuleView2.class)  
  5.                          .addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP)                                                     )  
  6.                        .getDecorView());  

[java]  view plain copy
  1. intent.setClass(getApplicationContext(),TestAutoLayoutActivity.class);  
  2. intent.putExtra("buttonid", jujiPage);  
  3. context.removeAllViews();  
  4. context.addView(getLocalActivityManager().startActivity(  
  5.             intent.getComponent().getShortClassName(),  
  6.             intent.addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP))  
  7.                 .getDecorView());  

[java]  view plain copy
  1. intent.getComponent().getShortClassName()是TestAutoLayoutActivity.class在mainfest.xml的activity Id .testAutoLayout.TestAutoLayoutActivity  

[html]  view plain copy
  1. <activity android:name=".testAutoLayout.TestAutoLayoutActivity" >  
  2. lt;/activity>  



注意 :
container.removeAllViews():
表示在显示该视图之前,先移除其他所有视图 .
Intent.FLAG_ACTIVITY_CLEAR_TOP:
如果在当前 Task 中,有要启动的 Activity ,那么把该 Acitivity 之前的所有 Activity 都关掉,并把此 Activity 置前以避免创建 Activity 的实例

这种方式具有很大的灵活性,常用的就是实现TabHost分页效果,但很好的避免的TabHost的缺点,如title

 

 

 

如果已经启动了四个Activity:A,B,C和D。在D Activity里,我们要跳到B Activity,同时希望C finish掉,可以在startActivity(intent)里的intent里添加flags标记,如下所示:


[java]  view plain copy
  1. Intent intent = new Intent(this, B.class);   
  2. intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);  
  3. startActivity(intent);  


这样启动B Activity,就会把D,C都finished掉,如果你的B Activity的启动模式是默认的(multiple) ,则B Activity会finished掉,再启动一个新的Activity B。  如果不想重新再创建一个新的B Activity,则在上面的代码里再加上:


[java]  view plain copy
  1. intent.addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP);  

 这样B Activity就不会再创建一个新的了,而是会重用之前的B Activity,同时调用B Activity的onNewIntent()方法。

 

 

 

问题:
多activity中退出整个程序,例如从A->B->C->D,这时我需要从D直接退出程序。

网上资料:{
finish()和system(0)都只能退出单个activity。杀进程等的等方式都不行~~~
解决问题:
我们知道Android的窗口类提供了历史栈,我们可以通过stack的原理来巧妙的实现,这里我们在D窗口打开A窗口时在Intent中直接加入标志Intent.FLAG_ACTIVITY_CLEAR_TOP,再次开启A时将会清除该进程空间的所有Activity。
在D中使用下面的代码:


[java]  view plain copy
  1. Intent intent = new Intent();   
  2. intent.setClass(D.this, A.class);  
  3. intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); //注意本行的FLAG设置  
  4. startActivity(intent);  
  5. finish();  


关掉自己
在A中加入代码:

[java]  view plain copy
  1. Override  
  2. protected void onNewIntent(Intent intent) {  
  3. // TODO Auto-generated method stub  
  4. super.onNewIntent(intent);  
  5. //退出  
  6.  if ((Intent.FLAG_ACTIVITY_CLEAR_TOP & intent.getFlags()) != 0) {  
  7.  finish();  
  8.  }  
  9. }  


A的Manifest.xml配置成android:launchMode="singleTop"

原理总结:
一般A是程序的入口点,从D起一个A的activity,加入标识Intent.FLAG_ACTIVITY_CLEAR_TOP这个过程中会把栈中B,C,都清理掉。因为A是android:launchMode="singleTop"
不会调用oncreate(),而是响应onNewIntent()这时候判断Intent.FLAG_ACTIVITY_CLEAR_TOP,然后把A finish()掉。
栈中A,B,C,D全部被清理。所以整个程序退出了。

你可能感兴趣的:(ActivityGroup)