dev-resources.site
for different kinds of informations.
Displaying Animated In Android Alerts with alerter.
Alerter 🔔
Alerter is an open-source Android alerting library developed by Tapadoo source: https://github.com/Tapadoo/Alerter. that provides a flexible and customizable way to create alerts in your Android applications. It offers a wide range of features, such as custom layouts, animations, durations, and more.
I just discovered it and now i am creating this guide that will also take you a step-by-step tutorial on how to use the Alerter library to create engaging and informative alerts for your users.
Step 1: Adding the Dependency
To use the Alerter library in your Android project, you need to add the dependency to your app-level build.gradle file. Here's how you can do it:
- Open your app-level build.gradle file. (Module:app)
- In the dependencies block, add the following line:
implementation "com.tapadoo.android:alerter:3.0.0"
This will add the latest version of the Alerter library to your project. Make sure to sync your project with the Gradle files after adding the dependency.
Step 2: Initializing Alerter
Nothing fancy just straight up class use
Alerter.< ... >
That is the basic template that you will use.
Step 3: Creating Basic Alerts
Now, let's create some basic alerts using Alerter. You can create alerts with or without a title, customize the duration, and add text to the alert. Here are some examples:
Without Title:
Alerter.create(this@YourActivity)
.setText("This is an alert without a title!")
.show()
With Title:
Alerter.create(this@YourActivity)
.setTitle("Alert Title")
.setText("This alert has a title and some text.")
.show()
Custom Duration:
You can set the duration for which the alert should be displayed using the setDuration
method:
Alerter.create(this@YourActivity)
.setTitle("Alert Title")
.setText("This alert will be shown for 5 seconds.")
.setDuration(5000) // Duration in milliseconds
.show()
Step 4: Adding Click Listeners
You can add click listeners to your alerts to perform actions when the alert is clicked. Here's how you can do it:
Alerter.create(this@YourActivity)
.setTitle("Alert Title")
.setText("Click me!")
.setOnClickListener {
Toast.makeText(this@YourActivity, "Alert clicked!", Toast.LENGTH_SHORT).show()
}
.show()
In this example, a toast message will be displayed when the alert is clicked.
Step 5: Customizing Alert Appearance
Alerter provides a variety of options to customize the appearance of your alerts, including custom fonts, text appearance, and background color. Here are some examples:
Custom Fonts:
You can set custom fonts for the title and text of the alert:
Alerter.create(this@YourActivity)
.setTitle("Custom Font Title")
.setTitleTypeface(Typeface.createFromAsset(assets, "your_font.ttf"))
.setText("Custom font text.")
.setTextTypeface(Typeface.createFromAsset(assets, "your_font.ttf"))
.show()
Custom Text Appearance:
You can customize the appearance of the title and text using text appearance styles:
Alerter.create(this@YourActivity)
.setTitle("Styled Title")
.setTitleAppearance(R.style.YourTitleStyle)
.setText("Styled text.")
.setTextAppearance(R.style.YourTextStyle)
.show()
Custom Background Color:
You can set a custom background color for the alert:
Alerter.create(this@YourActivity)
.setTitle("Colored Alert")
.setBackgroundColorRes(R.color.your_color)
.show()
Step 6: Using Custom Layouts
Alerter allows you to use custom layouts for your alerts. This gives you complete control over the appearance and content of the alert. Here's how you can use a custom layout:
- Create a new layout file for your custom alert (e.g., custom_alert_layout.xml).
- Design your layout as per your requirements.
- Use the custom layout when creating the alert:
Alerter.create(this@YourActivity, R.layout.custom_alert_layout)
.show()
You can access views within your custom layout using the getLayoutContainer()
method:
val textView = alerter.getLayoutContainer()?.findViewById<TextView>(R.id.textView)
textView?.text = "Custom text"
Step 7: Adding Buttons to Alerts
You can add buttons to your alerts to provide users with options or actions. Here's how you can add buttons:
Alerter.create(this@YourActivity)
.setTitle("Alert with Buttons")
.setText("Click a button.")
.addButton("Okay", R.style.ButtonStyle) {
Toast.makeText(this@YourActivity, "Okay clicked!", Toast.LENGTH_SHORT).show()
}
.addButton("Cancel", R.style.ButtonStyle) {
Toast.makeText(this@YourActivity, "Cancel clicked!", Toast.LENGTH_SHORT).show()
}
.show()
In this example, two buttons ("Okay" and "Cancel") are added to the alert, and click listeners are set for each button to display a toast message.
Step 8: Using Progress Bar
You can display a progress bar within your alerts to indicate ongoing processes. Here's how you can enable the progress bar:
Alerter.create(this@YourActivity)
.setTitle("Progress Alert")
.setText("Please wait...")
.enableProgress(true)
.setProgressColorRes(R.color.progress_bar_color)
.show()
You can customize the progress bar color using the setProgressColorRes
method.
Step 9: Custom Enter/Exit Animations
Alerter allows you to set custom enter and exit animations for your alerts. You can use built-in animations or create your own. Here's how you can set custom animations:
Alerter.create(this@YourActivity)
.setTitle("Animated Alert")
.setText("This alert has custom animations.")
.setEnterAnimation(R.anim.your_enter_animation)
.setExitAnimation(R.anim.your_exit_animation)
.show()
Replace your_enter_animation
and your_exit_animation
with your custom animation resources.
Step 10: Visibility Callbacks
You can receive callbacks when the alert is shown or hidden using the setOnShowListener
and setOnHideListener
methods:
Alerter.create(this@YourActivity)
.setTitle("Visibility Callbacks")
.setText("I will notify when shown or hidden.")
.setOnShowListener {
Toast.makeText(this@YourActivity, "Alert shown!", Toast.LENGTH_SHORT).show()
}
.setOnHideListener {
Toast.makeText(this@YourActivity, "Alert hidden!", Toast.LENGTH_SHORT).show()
}
.show()
Hope this is helpful. Read more about alerter from github source
https://github.com/Tapadoo/Alerter
Featured ones: