强制下线的应用场景很多, 比如我们好多账号都有抢登的显现, 会被挤下线.

详细实现:
其实实现强制下线功能的思路也比较简单, 只需要在界面弹出一个对话框, 让用户无法进行其他操作, 必须点击对话框中的确定按钮, 然后回到登录界面即可.
但是又有一个问题, 我们通知用户强制下线, 用户可能正处于任何一个界面, 难道需要在每个界面上都编写一个弹出对话框的逻辑? 当然不是! 我们可以借助本章中所学的广播知识来轻松实现这一功能.
public class ActivityConllector {
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();
}
}
}
创建BaseActivity类作为所有活动的父类, 代码如下:
public class BaseActivity extends AppCompatActivity{
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
ActivityConllector.addActivity(this);
}
@Override
protected void onDestroy() {
super.onDestroy();
ActivityConllector.removeActivity(this);
}
}
首先编写布局文件activity_login文件:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="60dp"
android:orientation="horizontal">
<TextView
android:layout_width="90dp"
android:layout_height="wrap_content"
android:text="User Name"
android:textSize="18sp"
android:layout_gravity="center_vertical"/>
<EditText
android:id="@+id/account"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:layout_gravity="center_vertical"
/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="60dp"
android:orientation="horizontal">
<TextView
android:layout_width="90dp"
android:layout_height="wrap_content"
android:text="Password"
android:textSize="18sp"
android:layout_gravity="center_vertical"/>
<EditText
android:id="@+id/password"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:layout_gravity="center_vertical"
android:inputType="textPassword"/>
</LinearLayout>
<Button
android:id="@+id/login"
android:layout_width="match_parent"
android:layout_height="60dp"
android:text="Login"/>
</LinearLayout>
LoginActivity.java中代码:
public class LoginActivity extends BaseActivity implements View.OnClickListener{
private EditText userName;
private EditText passWord;
private Button login;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_login);
userName = (EditText)findViewById(R.id.account);
passWord = (EditText)findViewById(R.id.password);
login = (Button) findViewById(R.id.login);
login.setOnClickListener(this);
}
@Override
public void onClick(View v) {
switch (v.getId()){
case R.id.login:
String username = userName.getText().toString();
String password = passWord.getText().toString();
if(username.equals("admin") && password.equals("123")){
Intent intent = new Intent(LoginActivity.this, MainActivity.class);
startActivity(intent);
finish();
} else {
Toast.makeText(this, "用户名或者密码错误!", Toast.LENGTH_SHORT).show();
}
}
}
}
我们这时可以理解成, 登录界面之后, 进入的activity_main.xml就是主界面. 主界面没有其他功能, 只有一个用于显示的TextView和一个用作下线功能的按钮
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="这是主页面"
android:layout_gravity="center_horizontal"/>
<Button
android:id="@+id/force_offline"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="强制下线"/>
</LinearLayout>
MainActivity.java中代码:
public class MainActivity extends BaseActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button forceOffline = (Button) findViewById(R.id.force_offline);
forceOffline.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent intent = new Intent("com.junzaivip.broadcastbestpractice.FORCE_OFFLINE");
sendBroadcast(intent);
}
});
}
}
我们按钮的点击事件里面发送了一条广播, 广播的值为com.junzaivip.broadcastbestpractice.FORCE_OFFLINE, 这条广播就是用于通知程序强制用户下线的.
也就是说强制用户下线的逻辑并不是写在MainActivity里的, 而是应该写在接收这条广播的接收器里面. 这样的好处是, 强制下线的功能就不会依附于任何的界面, 不管是在程序的任何地方, 只需要发出一条这样的广播,就可以完成强制下线的操作了.
那么, 需要创建一个广播接收器, 用于接收这条强制下线的广播, 唯一的问题就是, 应该在哪里创建呢? 由于广播接收器里面需要弹出一个对话框来阻塞用户的正常操作. 但如果创建的是一个静态注册的广播接收器, 是没有办法在onReceive()方法里弹出对话框这样的UI控件的, 而我们显然不能也不可能在每个活动中注册一个动态的广播接收器.
那么到底应该怎么办呢? 其实很明显, 只需要在BaseActivity中动态注册一个广播接收器就可以了. 因为所有的活动都继承自BaseActivity的.
BaseActivity中的代码:
public class BaseActivity extends AppCompatActivity{
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
ActivityConllector.addActivity(this);
}
@Override
protected void onDestroy() {
super.onDestroy();
ActivityConllector.removeActivity(this);
}
class ForceOffLineReceiver extends BroadcastReceiver{
@Override
public void onReceive(final Context context, final Intent intent) {
AlertDialog.Builder builder = new AlertDialog.Builder(context);
builder.setTitle("warning");
builder.setMessage("您被强制下线, 请您重新登录!");
builder.setCancelable(false); // 将对话框设置为不可取消
// 给按钮添加注册监听
builder.setPositiveButton("OK", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// 点击按钮所调用的方法
ActivityConllector.finishAll();//销毁所有的活动
Intent intent1 = new Intent(context, LoginActivity.class);
context.startActivity(intent);
}
});
builder.show();
}
}
}
我们需要设置主活动为LoginActivity, 而不再是MainActivity, 模拟访问一个程序首先在登录页面.
修改AndroidManifest.xml文件:
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".MainActivity">
</activity>
<activity android:name=".LoginActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
运行效果如下:
源码: BroadcastBestPractice_jb51.rar
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# android
# 强制下线
# 强制下线功能
# Android模拟强制下线通知功能实例代码
# Android使用广播(BroadCast)实现强制下线的方法
# Android运用BroadcastReceiver实现强制下线
# 对话框
# 弹出
# 这条
# 只需
# 要在
# 写在
# 就可以
# 的是
# 这是
# 这一
# 是在
# 都有
# 又有
# 请您
# 在每个
# 我们可以
# 作了
# 只有一个
# 只需要
# 没有办法
相关文章:
外贸公司网站制作,外贸网站建设一般有哪些步骤?
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
建站之星安装路径如何正确选择及配置?
建站主机解析:虚拟主机配置与服务器选择指南
IOS倒计时设置UIButton标题title的抖动问题
C++如何使用std::optional?(处理可选值)
网站制作免费,什么网站能看正片电影?
全景视频制作网站有哪些,全景图怎么做成网页?
移民网站制作流程,怎么看加拿大移民官网?
北京企业网站设计制作公司,北京铁路集团官方网站?
已有域名建站全流程解析:网站搭建步骤与建站工具选择
江苏网站制作公司有哪些,江苏书法考级官方网站?
无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?
Swift中循环语句中的转移语句 break 和 continue
Swift中swift中的switch 语句
如何使用Golang table-driven基准测试_多组数据测量函数效率
网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?
如何用已有域名快速搭建网站?
企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化
如何通过FTP空间快速搭建安全高效网站?
建站之星IIS配置教程:代码生成技巧与站点搭建指南
已有域名和空间,如何快速搭建网站?
建站之星备案是否影响网站上线时间?
如何在IIS中配置站点IP、端口及主机头?
网站制作报价单模板图片,小松挖机官方网站报价?
威客平台建站流程解析:高效搭建教程与设计优化方案
微网站制作教程,我微信里的网站怎么才能复制到浏览器里?
宁波自助建站系统如何快速打造专业企业网站?
如何快速上传自定义模板至建站之星?
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
天津个人网站制作公司,天津网约车驾驶员从业资格证官网?
制作旅游网站html,怎样注册旅游网站?
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
湖州网站制作公司有哪些,浙江中蓝新能源公司官网?
专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?
如何在西部数码注册域名并快速搭建网站?
如何在搬瓦工VPS快速搭建网站?
建站主机数据库如何配置才能提升网站性能?
如何在万网自助建站平台快速创建网站?
网站建设制作需要多少钱费用,自己做一个网站要多少钱,模板一般多少钱?
如何在万网自助建站中设置域名及备案?
如何通过VPS建站实现广告与增值服务盈利?
在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?
南京网站制作费用,南京远驱官方网站?
建站主机选购指南:核心配置与性价比推荐解析
长沙企业网站制作哪家好,长沙水业集团官方网站?
制作网站外包平台,自动化接单网站有哪些?
湖北网站制作公司有哪些,湖北清能集团官网?
*请认真填写需求信息,我们会在24小时内与您取得联系。