实现一个简单的登陆功能,账号为“admin”密码为“123456”当账号密码输入正确时,进入新活动,活动内有一个按钮,点击后实现强制下线。发送广播通知,然后返回登陆界面。
1.新建ActivityCollector类,实现关闭所有活动功能,代码如下:
package com.example.broadcastbestpractice;
import android.app.Activity;
import java.util.ArrayList;
import java.util.List;
public class ActivityCollector {
public static List<Activity> activities = new ArrayList<>();
public static void addActivity(Activity activity) {
activities.add(activity);
}
public static void removeActivity(Activity activity){
activities.remove(activity);
}
public static void finishAll(){
for (Activity activity:activities){
if(!activity.isFinishing()){
activity.finish();
}
}
activities.clear();
}
}
2.新建BaseActivity类作为所有活动的父类,重写onResume()方法和onPause()方法。我们需要在onResume()方法内添加注册广播的代码。在onPause()方法内添加取消注册代码。
package com.example.broadcastbestpractice;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.content.IntentFilter;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v7.app.AlertDialog;
import android.support.v7.app.AppCompatActivity;
public class BaseActivity extends AppCompatActivity {
private ForceOfflineReceiver forceOfflineReceiver;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
ActivityCollector.addActivity(this);
}
@Override
protected void onPause() {
super.onPause();
if(forceOfflineReceiver!=null){
unregisterReceiver(forceOfflineReceiver);
}
forceOfflineReceiver=null;
}
@Override
protected void onResume() {
super.onResume();
IntentFilter intentFilter=new IntentFilter();
intentFilter.addAction("com.example.broadcastbestpractice.FORCE_OFFLINE");
forceOfflineReceiver=new ForceOfflineReceiver();
registerReceiver(forceOfflineReceiver,intentFilter);
}
@Override
protected void onDestroy() {
super.onDestroy();
ActivityCollector.removeActivity(this);
}
class ForceOfflineReceiver extends BroadcastReceiver{
@Override
public void onReceive(final Context context, Intent intent) {
AlertDialog.Builder builder=new AlertDialog.Builder(BaseActivity.this);
builder.setTitle("Worning");
builder.setMessage("您的账号在别处登陆!");
builder.setCancelable(false);
builder.setPositiveButton("OK", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
ActivityCollector.finishAll();
Intent intent1=new Intent(context,LoginActivity.class);
startActivity(intent1);
}
});
builder.show();
}
}
}
解释一下为什么要这么做,首先可以肯定的是我们需要一条广播接收器来接受下线广播,然后在广播接收器里面写强制下线的逻辑,首先静态注册广播接收器是不可以的,因为无法在静态注册的onReceive()方法中添加提示退出的对话框UI控件。那么就只能动态注册了,但是该在哪里注册呢,以后程序可能会有很多活动,我们不能在每一个活动都注册动态的广播接收器呀。所以我们就像想到了BaseActivity类,因为我们所有的活动都是继承它的,那么只需要重写onResume()方法,这样每次处于正在操作的栈顶活动都会注册广播接收器,同样,重写onPause()方法是在要启动其他活动时便取消当前注册的广播接收器。
3.在新的活动中添加一个按钮,当点击时便发送一个广播
package com.example.broadcastbestpractice;
import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
public class MainActivity extends BaseActivity {
private Button button;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
button=findViewById(R.id.another_login);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent intent=new Intent("com.example.broadcastbestpractice.FORCE_OFFLINE");
sendBroadcast(intent);
}
});
}
}
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<Button
android:id="@+id/another_login"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="强制下线"
tools:ignore="MissingConstraints" />
</android.support.constraint.ConstraintLayout>
这样点击时就会提示强制下线。