kotlin实现强制下线功能
时间:2019-04-15
本文章向大家介绍kotlin实现强制下线功能,主要包括kotlin实现强制下线功能使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
强制下线是需要关闭所有的活动,先创建一个类来管理所有的活动。
class ActivityCollector { //var activities :MutableList<Activity>=MutableList<Activity>() companion object{ val activities = ArrayList<Activity>() fun addActivity( activity:Activity){ activities.add(activity) } fun removeActivity(activity:Activity){ activities.remove(activity) } fun finsishAll(){ for(activity:Activity in activities){ if(!activity.isFinishing){ activity.finish() } } activities.clear() } } }
然后建立一个所有活动的父类
open class BaseActivity : AppCompatActivity(){ var activityCollector=ActivityCollector() lateinit var receiver:ForceOfflineReceiver override fun onCreate(savedInstanceState: Bundle?, persistentState: PersistableBundle?) { super.onCreate(savedInstanceState, persistentState) ActivityCollector.addActivity(this) //activityCollector.addActivity(this) } override fun onResume() { super.onResume() var inetnefilter:IntentFilter=IntentFilter() inetnefilter.addAction("FORCE_FOOLINE") receiver=ForceOfflineReceiver() registerReceiver(receiver,inetnefilter) } override fun onPause() { super.onPause() if(receiver!=null){ unregisterReceiver(receiver) // receiver=null } } override fun onDestroy() { super.onDestroy() ActivityCollector.removeActivity(this) } open class ForceOfflineReceiver : BroadcastReceiver(){ override fun onReceive(context: Context, intent: Intent?) { var builder :AlertDialog.Builder=AlertDialog.Builder(context) builder.setTitle("Warning") builder.setMessage("you are forced to be offline .please try to login again") builder.setCancelable(false) builder.setPositiveButton("ok",object :DialogInterface.OnClickListener{ override fun onClick(dialog: DialogInterface?, which: Int) { ActivityCollector.finsishAll() var intent=Intent(context,LoginActivity::class.java) context.startActivity(intent) } }) builder.show() } } }
建立一个登录的布局文件
<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:layout_gravity="center_vertical" android:textSize="18sp" android:text="account:" /> <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:layout_gravity="center_vertical" android:textSize="18sp" android:text="password:" /> <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>
然后编写一个登录的活动,这里写了一个简单的登录,密码正确的话就进入主页面,否则给出提示。
class LoginActivity:BaseActivity(){ lateinit var accountEdid:EditText lateinit var passwordEdit :EditText lateinit var login:Button override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.login) accountEdid=findViewById(R.id.account) passwordEdit=findViewById(R.id.password) login=findViewById(R.id.login) login.setOnClickListener(View.OnClickListener { var account =accountEdid.text.toString() var password=passwordEdit.text.toString() if(account.equals("admin")&&password.equals("123")){ var intent:Intent=Intent(this, MainActivity::class.java) startActivity(intent) finish() }else{ Toast.makeText(this,"账号或密码错误",Toast.LENGTH_SHORT).show() } }) } }
然后修改一下mainactivity的代码
class MainActivity : BaseActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) var forceOffline :Button =findViewById(R.id.force_offline) forceOffline.setOnClickListener(View.OnClickListener { var intent:Intent=Intent("FORCE_FOOLINE") sendBroadcast(intent) }) } }
最后对AndroidManifest.xml修改,把主活动设置更换一下。
<application android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:roundIcon="@mipmap/ic_launcher_round" android:supportsRtl="true" android:theme="@style/AppTheme"> <activity android:name=".MainActivity"> </activity> <activity android:name=".LoginActivity" android:launchMode="singleTask"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
- 在网页中给Flash加上超级链接
- ASP.NET MVC HandleErrorAttribute 和 远程链接
- javascript实现数字转大写金额的函数
- 如何在GridView的Footer内显示总计?
- 自定义WCF的配置文件
- Centos中动态扩容lvm逻辑卷的操作记录
- Visual Round Trip Analyzer
- ASP.NET可以在Windows Server 2008 R2 Server Core上运行
- SOA十大设计原则
- 中国人民大学文继荣:大数据的经验主义解释
- 检查Python对象
- 分布式监控系统Zabbix-3.0.3-完整安装记录(6)-微信报警部署
- Android 命名规范 (提高代码可以读性)
- Msdn 杂志 asp.net ajax 文章汇集
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- sql注入总结笔记
- WebRTC | Web服务器原理、Nodejs工作原理、Nodejs事件处理流程、V8引擎等要点解析
- OpenGL ES 3.0 | 围绕HelloTriangle实战案例 展开 渲染流程分析
- 基于 Kotlin + Netty 实现一个简单的 TCP 自定义协议
- dnslog带出——sqli-labs第8关
- Boolean源码解剖学
- SpringBoot+Mybatis整合出现org.apache.ibatis.binding.BindingException: Invalid bound statement (not found
- xss-labs第1~13关
- 在虚拟机上搭建xss平台
- 一个速度快,内存占用小的一致性哈希算法
- 一文搞定web微信第三方登录
- python学习笔记(1)
- Swift Mutating
- 31.opengl高级光照-泛光bloom
- Swift 泛型