原地址:http://blog.****.net/weiwozhiyi/article/details/50791416
在Android中如果关闭一个Activity调用finish即可,但是在我们的应用都有多个Activity,如何动态的关闭所有的Activity显得非常的重要,本文介绍四种方法:1、使用Application来关闭。2、使用广播的方式来关闭。3、使用onActivityResult递归回调的方式关闭。4.使用setFlags的方式来关闭
1、使用Application来进行关闭
-
public class App extends Application {
-
-
private static List<Activity> lists = new ArrayList<>();
-
-
public static void addActivity(Activity activity) {
-
lists.add(activity);
-
}
-
-
public static void clearActivity() {
-
if (lists != null) {
-
for (Activity activity : lists) {
-
activity.finish();
-
}
-
-
lists.clear();
-
}
-
}
-
}
写一个基类Activity,在构造构造方法调用App.addActivity(this);就可以实现。
2、使用广播的方式来进行关闭
在基类构造方法中实现注册广播,onDestroy方法取消注册
-
public class BaseActivity extends AppCompatActivity {
-
-
@Override
-
protected void onCreate(Bundle savedInstanceState) {
-
super.onCreate(savedInstanceState);
-
-
IntentFilter intentFilter = new IntentFilter();
-
intentFilter.addAction("com.andly.bro");
-
registerReceiver(receiver, intentFilter);
-
}
-
-
BroadcastReceiver receiver = new BroadcastReceiver() {
-
@Override
-
public void onReceive(Context context, Intent intent) {
-
finish();
-
}
-
};
-
-
@Override
-
protected void onDestroy() {
-
super.onDestroy();
-
unregisterReceiver(receiver);
-
}
-
}
接下来只需要你在想要关闭所有Activity的界面调用
-
//销毁所有的Activity
-
Intent intent = new Intent();
-
intent.setAction("com.andly.bro");
-
sendBroadcast(intent);
3、使用onActivityResult递归回调的方式关闭
在基类Activity重写onActivityResult方法通过识别ResultCode来调用finish方法
-
public class BaseActivity extends AppCompatActivity {
-
protected final static int RESULT_CLOSE = 0;
-
@Override
-
protected void onCreate(Bundle savedInstanceState) {
-
super.onCreate(savedInstanceState);
-
}
-
-
@Override
-
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
-
super.onActivityResult(requestCode, resultCode, data);
-
if(resultCode == RESULT_CLOSE){
-
setResult(RESULT_CLOSE);
-
finish();
-
}
-
}
-
}
接下来只需要在你想要关闭Activity调用setResult(Result_CLOSE)就可以了
4.使用setFalgs的方式来关闭
首先先来介绍一个LaunchMode四种模式:
##LaunchMode
standard和singleTop是相同的,每次都会创建一个新的Activity实例,区别是singleTop当压入栈的Activity与任务栈的栈顶Activit相同则不会创建实例(会调用onNewIntent方法)
singleInstance和singleTask是相同的,都会保证任务中没有相同的任务,(当执行的Activity与任务中某个Activity相同则会调用onNewIntent方法),不同点是(singleInstance每次都会创建一个任务栈并将Activity压入栈中),(singleTask是在一个任务栈中,如果压入栈的Activity与栈内Activity某个相同则直接将那个Activity移动到栈顶不会创建新的实例)
当然这里并没有用到这四种模式而是运用的是Intent.FLAG_ACTIVITY_CLEAR_TOP,这种标示基本和singleTop类似不同的是如果压入栈的Activity在栈内某个Activity相同则将它上面的所有Activity进行出栈操作。
在每次跳转都加上
-
intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
所以在最后一个Activity后退应用:
-
@Override
-
public boolean onKeyDown(int keyCode, KeyEvent event) {
-
if (keyCode == KeyEvent.KEYCODE_BACK) {
-
//销毁所有的Activity
-
Intent intent = new Intent(this,FirstActivity.class);
-
intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
-
startActivity(intent);
-
}
-
return super.onKeyDown(keyCode, event);
-
}
这样略先复杂,现在来说一下使用flag的另一种方法:
在退出的Activity的前一个Activity跳转加上
-
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TASK | Intent.FLAG_ACTIVITY_TASK_ON_HOME);
就可以了,现在来说一下这几个什么意思
-
/*
-
FLAG_ACTIVITY_CLEAR_TASK 这个标示将在这个活动开始之前清除该栈中所有的任务,将里面的Activity都finish掉
-
FLAG_ACTIVITY_TASK_ON_HOME 这个flag将造成新任务在home的上面,就是在启动的Activity点击back之后就会回到home界面
-
*/
附上效果: