How to listen for an intent using a Broadcast Receiver in an Activity
data:image/s3,"s3://crabby-images/b6283/b6283d6dab3a9d5fd6ceacdf08c7e1602be03f81" alt="Oscar de la Hera Gomez"
data:image/s3,"s3://crabby-images/b0ff9/b0ff9649e16c18064a0f92092f9ed7317a8aba24" alt="Three flowers that represent Kotlin, Android and Android Studio side by side. Beneath them sits the text “Receive Broadcasts in Activities.”"
A step by step guide on listening for an intent, that may or may not have extras, using a Broadcast Receiver in an Activity in Kotlin and Android Studio.
This post is a part of a mini series on sending and receiving functional intents in an Android app. The rest of the tutorials are available at the end.
Please note that we have chosen to use the term "Notifications" to standardize naming conventions across iOS and Android. If you wish to exchange Notifications for Intents, we welcome you too.
This particular posts demonstrates how to listen for a language content update notification. This tutorial can be found in the main branch of our Open Source repository
Step One: Setup the Notifications Coordinator
data:image/s3,"s3://crabby-images/9e879/9e8797ff1a4c70fc05a9204ff69fda3aa4fcc8cf" alt="A screenshot of Android Studio showing the NotificationCoordinator.kt file. Code available below."
For intents to be registered across an app it must be sent from a central manager, which we call a NotificationsCoordinator.
Step Two: Broadcast the Intent
data:image/s3,"s3://crabby-images/f6088/f6088cd8d6706f41fd88878b9b1474247fc84928" alt="A screenshot of Android Studio showing how we created the sendOnLanguageUpdateIntent function in the NotificationCoordinator and sent it from the Language Coordinator."
Follow the tutorial below to learn how to structure a project to manage and broadcast intents.
Step Three: Declare the Broadcast Receiver
data:image/s3,"s3://crabby-images/b36be/b36bed8c3eaa3a4da5696f0ee186445a1e8766b9" alt="A screenshot of Android Studio showing you how to declare a Broadcast receiver in an activity. Code available below."
At the top of your MainActivity.kt declare your broadcast receiver using code similar to that below.
The example of the reciever below routes the intents to functions declared in the next step.
Step Four: Create the Notifications Extension
data:image/s3,"s3://crabby-images/fb4db/fb4db621ff58fa91ec78e47cd393ca81cb94cfb0" alt="A screenshot of the Notification Extension of the MainActivity. Code available below."
Create a new file called MainActivity+Notifications.kt and paste in the code below.
This is where you will declare:
- What Intents your receiver will listen for, whether they are internal or external.
- All the functionality to respond to intents being received.
Please note that this functionality should be called from the receiver declared in previous step.
Step Five: Setup Notifications
data:image/s3,"s3://crabby-images/3ba39/3ba39aedb4925fd1d73bb4d847495a548a2930b3" alt="A screenshot of Android Studio showing the setupNotifications function being called in the onCreate lifecycle in the MainActivty.kt file."
In the MainActivity.kt onCreate function, call setupNotifications() to make sure that the broadcast receiver is registered.
setupNotifications()
Step Five: Unregister the Receiver
data:image/s3,"s3://crabby-images/5671a/5671ac44181d768fdeb23cc97858cee3c09c9cf1" alt="A screenshot of Android Studio showing how to unregister a receiver in the onDestroy lifecycle function."
In the onDestroy lifecycle function of the MainActivity, unregister the broadcast receiver using the code below.
unregisterReceiver(broadcastReceiver)
Step Six: Test
data:image/s3,"s3://crabby-images/700b0/700b0078d9a731f0d477cd22b2a1871ce7e0ee44" alt="A screenshot of Android Studio showing the logs that confirm that the notifications were sent and received."
Run the app in Android Studio and confirm that the notification is sent and received.
Looking to learn more about Intents in Android ?
Consult the tutorials linked below to learn more about sending and receiving Intents in Android and Kotlin.