kotlin實(shí)現(xiàn)強(qiáng)制下線功能
強(qiáng)制下線是需要關(guān)閉所有的活動(dòng),先創(chuàng)建一個(gè)類來管理所有的活動(dòng)。
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() } } }
然后建立一個(gè)所有活動(dòng)的父類
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() } } }
建立一個(gè)登錄的布局文件
<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>
然后編寫一個(gè)登錄的活動(dòng),這里寫了一個(gè)簡單的登錄,密碼正確的話就進(jìn)入主頁面,否則給出提示。
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,"賬號(hào)或密碼錯(cuò)誤",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) }) } }
最后對(duì)AndroidManifest.xml修改,把主活動(dòng)設(shè)置更換一下。
<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>
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
分享Android開發(fā)中最有效率最快的循環(huán)代碼
分享Android開發(fā)中最有效率最快的循環(huán)代碼,需要的朋友可以參考下2013-01-01Android上傳文件到服務(wù)端并顯示進(jìn)度條
這篇文章主要為大家詳細(xì)介紹了Android上傳文件到服務(wù)端,并顯示進(jìn)度條,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11Android通過繼承Binder類實(shí)現(xiàn)多進(jìn)程通信
本篇文章主要介紹了Android通過繼承Binder類實(shí)現(xiàn)多進(jìn)程通信,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-03-03Android的HTTP類庫Volley入門學(xué)習(xí)教程
這篇文章主要介紹了Android應(yīng)用開發(fā)框架Volley的入門學(xué)習(xí)教程,Volley適合于輕量級(jí)的通信功能開發(fā),善于處理JSON對(duì)象,需要的朋友可以參考下2016-02-02Android實(shí)現(xiàn)加載時(shí)提示“正在加載,請(qǐng)稍后”的方法
在現(xiàn)在的很多應(yīng)用中,當(dāng)在加載的時(shí)候,如果頁面動(dòng)態(tài)數(shù)據(jù)較多,會(huì)有很長一段時(shí)間的空白頁面,如果加上這個(gè)頁面正在加載的提示,使得應(yīng)用更加人性化。這篇文章就給大家分享了在 Android實(shí)現(xiàn)加載時(shí)提示“正在加載,請(qǐng)稍后”的方法,有需要的朋友們可以參考借鑒。2016-10-10