ActivityGroup简单介绍

it2025-09-23  97

ActivityGroup简单介绍 1.ActivityGroup 的核心就是继承了该类,可以通过getLocalActivityManager()得到一个 LocalActivityManager,LocalActivityManager  am= 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的一个实例 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

 

 

 

假设已经启动了四个Activity:A,B,C和D。在D Activity里,我们要跳到B Activity,同一时候希望C finish掉,能够在startActivity(intent)里的intent里加入flags标记,例如以下所看到的:

Intent intent = new Intent(this, B.class); intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); startActivity(intent);

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

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中使用以下的代码:

Intent intent = new Intent(); intent.setClass(D.this, A.class); intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); //注意本行的FLAG设置 startActivity(intent); finish();

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

Override protected void onNewIntent(Intent intent) { // TODO Auto-generated method stub super.onNewIntent(intent); //退出 if ((Intent.FLAG_ACTIVITY_CLEAR_TOP & intent.getFlags()) != 0) { finish(); } }

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所有被清理。所以整个程序退出了。

 

转载于:https://www.cnblogs.com/bhlsheji/p/4316163.html

相关资源:数据结构—成绩单生成器
最新回复(0)