網站首頁 編程語言 正文
基礎廣播
兩大類廣播
標準廣播:異步執行,廣播發出后所有 receiver 同時接收,無先后順序,無法被截斷;
有序廣播:同步執行,類似于中間件,每個 receiver 攔截廣播后有權將其下放到下一個 receiver 或者直接截斷;
廣播的動態和靜態注冊
動態注冊:寫在代碼里面的監聽事件;
靜態注冊:寫在 manifest.xml 里面的監聽;
目前,由于安卓為了維護用戶系統安全,故所有的隱式廣播均不允許靜態注冊
監聽時間變化
在主 activity 里面編寫如下代碼,實現每隔一分鐘監聽一次時間變化并 toast 彈出信息;
package com.zhiyiyi.listviewdemo import android.content.BroadcastReceiver import android.content.Context import android.content.Intent import android.content.IntentFilter import androidx.appcompat.app.AppCompatActivity import android.os.Bundle import android.widget.Toast import androidx.recyclerview.widget.LinearLayoutManager import androidx.recyclerview.widget.RecyclerView import androidx.recyclerview.widget.StaggeredGridLayoutManager import com.zhiyiyi.listviewdemo.R import com.zhiyiyi.listviewdemo.RecyclerAdapter import kotlinx.android.synthetic.main.activity_main.* import java.util.* import kotlin.collections.ArrayList class MainActivity : AppCompatActivity() { // 延遲初始化監聽器 lateinit var timeChangeReceiver: TimeChangeReceiver override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) // 設置過濾器 val intentFilter = IntentFilter() // 過濾的廣播類型為TIME_TICK intentFilter.addAction("android.intent.action.TIME_TICK") // 實例化監聽器 timeChangeReceiver = TimeChangeReceiver() // 注冊廣播監聽器 registerReceiver(timeChangeReceiver, intentFilter) } override fun onDestroy() { super.onDestroy() // 銷毀activity的時候別忘了注銷廣播監聽器 unregisterReceiver(timeChangeReceiver) } // 使用內部類動態注冊廣播監聽器 inner class TimeChangeReceiver : BroadcastReceiver() { override fun onReceive(context: Context?, intent: Intent?) { Toast.makeText(context, "time changed", Toast.LENGTH_SHORT).show() } } }
監聽系統啟動案例
創建 receiver
我們可以右鍵點擊項目,來使用官方提供的模板創建 broadcastreceiver;
這種方式創建后,會自動在 manifest 文件內注冊該外部 receiver,否則會需要我們手動來進行注冊,十分不方便;
我們據此創建 BootReceiver.kt
編寫代碼如下,依舊是接收到廣播彈出 toast
package com.zhiyiyi.listviewdemo import android.content.BroadcastReceiver import android.content.Context import android.content.Intent import android.widget.Toast class BootReceiver : BroadcastReceiver() { override fun onReceive(context: Context, intent: Intent) { Toast.makeText(context, "boot start", Toast.LENGTH_SHORT).show() } }
設置權限
為了監聽系統啟動廣播,我們需要靜態注冊(該廣播事實上是一個隱式廣播,但因為安全隱患小,安卓并沒有禁止其靜態注冊!)
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools"> <!-- 在這里注冊權限 --> <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/> <application android:allowBackup="true" android:dataExtractionRules="@xml/data_extraction_rules" android:fullBackupContent="@xml/backup_rules" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:roundIcon="@mipmap/ic_launcher_round" android:supportsRtl="true" android:theme="@style/Theme.ListViewDemo" tools:targetApi="31"> <receiver android:name=".BootReceiver" android:enabled="true" android:exported="true"> <!-- 設置過濾器 --> <intent-filter> <action android:name="android.intent.action.BOOT_COMPLETED"/> </intent-filter> </receiver> ... </application> </manifest>
發送自定義廣播
如何發送與接收
新建廣播監聽器文件:CustomReceiver.kt
編寫監聽到后反應
class CustomReceiver : BroadcastReceiver() { override fun onReceive(context: Context, intent: Intent) { Toast.makeText(context, "custom receiver", Toast.LENGTH_SHORT).show() } }
在 manifest 中在對應監聽器下設置過濾器
<receiver android:name=".BootReceiver" android:enabled="true" android:exported="true"> <intent-filter> <action android:name="android.intent.action.BOOT_COMPLETED" /> </intent-filter> </receiver>
主 activity 中設置點擊按鈕發送廣播,此時自定義監聽器監聽到信息,彈出 toast
class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) broad_btn.setOnClickListener { val intent = Intent("receiver.MYCUSTOM") Log.d(TAG, "onClick: fuck") intent.setPackage(packageName) sendBroadcast(intent) } } }
解釋一下 setPackage
因為所有隱式廣播都無法使用靜態注冊,而我們使用的自定義廣播全部都是隱式廣播;
我們只有使用 setPackage 將自身變成顯示廣播,才能推送到隱式廣播接收器;
有序廣播
監聽器在 manifest 中注冊時,在過濾器后加上出現設置權限值;
權限越高的越早能截獲信息;
<intent-filter android:priority="100">
主 activity 使用 sendOrderedBroadcast 來發送有序列的廣播;
第一個參數是 intent,第二個參數我們一般都填 null
sendOrderedBroadcast(intent,null)
自定義廣播的末尾可以加上 abortBroadcast 可以銷毀該廣播,即廣播終止位置到此為止,后面的優先級較低的都無監聽器法接受到了
class CustomReceiver : BroadcastReceiver() { override fun onReceive(context: Context, intent: Intent) { ... // 攔截并銷毀該廣播 abortBroadcast() } }
原文鏈接:https://blog.csdn.net/delete_you/article/details/127186791
相關推薦
- 2023-07-04 ES聚合查詢+條件搜索的實現
- 2023-10-14 uniapp 將base64字符串保存為圖片、Word、Excel、音頻、視頻等文件
- 2023-03-30 官網項目Jetpack?Startup庫學習_Android
- 2023-05-06 react中定義變量并使用方式_React
- 2022-12-11 Dos判斷文件夾是否存在,如果存在刪除,不存在創建_DOS/BAT
- 2022-03-26 c++?KMP字符串匹配算法_C 語言
- 2022-12-08 C語言中-a++和-++a運算順序實例解析_C 語言
- 2022-09-28 SQLServer常見數學函數梳理總結_MsSql
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支