Redesign dialogs: MaterialAlertDialog for Android

With the release of Material Design 2.0, Android developers have exciting new options for crafting dialogs that grab user attention and enhance app interactivity. In this guide, we’ll explore how to implement and customize dialogs using the Material Theme in your Android applications.

Understanding Material Components: Dialogs

Dialogs play a crucial role in applications by highlighting essential information or requiring user decisions. Thanks to the advancements in Material Design 2.0, dialogs are now more dynamic and versatile. To get started, include the Material Components library in your project by adding the following dependency:

implementation 'com.google.android.material:material:1.1.0-alpha09'

Additionally, ensure that your activity inherits from a MaterialComponent theme or one of its descendants to leverage the full range of features.

Building a Basic MaterialAlertDialog

Let’s start by creating a basic MaterialAlertDialog using the Builder pattern:

new MaterialAlertDialogBuilder(MainActivity.this)
    .setTitle("Title")
    .setMessage("Your message goes here. Keep it short but clear.")
    .setPositiveButton("GOT IT", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialogInterface, int i) {
            // Positive button action
        }
    })
    .setNegativeButton("CANCEL", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialogInterface, int i) {
            // Negative button action
        }
    })
    .show();

This dialog provides a simple interface for users to acknowledge or cancel an action.

Customizing Button Styles

The buttons in a MaterialAlertDialog can be styled to suit your application’s design theme. Here’s an example of how you can customize button styles:

 

 

 


 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 


 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 


 

 

 

 

 

 

 

 

 

 

 

 

 

Apply these styles in the dialog builder:

new MaterialAlertDialogBuilder(MainActivity.this, R.style.AlertDialogTheme)
    .setTitle("Title")
    .setMessage("Your message goes here. Keep it short but clear.")
    .setPositiveButton("GOT IT", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialogInterface, int i) {
            // Positive button action
        }
    })
    .setNeutralButton("LATER", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialogInterface, int i) {
            // Neutral button action
        }
    })
    .show();

Exploring Dialog Shapes

Material Design allows dialogs to be styled with various shapes, such as cut or rounded corners, to enhance visual appeal.

Cut-Shaped Dialog

 

 

 


 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 


 

 

 

 

 

 

 

 

 

 

 

 

 

Apply the cut shape style:

new MaterialAlertDialogBuilder(MainActivity.this, R.style.CutShapeTheme)
    .setTitle("Title")
    .setMessage("Your message goes here. Keep it short but clear.")
    .setPositiveButton("GOT IT", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialogInterface, int i) {
            // Positive button action
        }
    })
    .setNeutralButton("LATER", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialogInterface, int i) {
            // Neutral button action
        }
    })
    .show();

Rounded-Shaped Dialog

 

 

 


 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 


 

 

 

 

 

 

 

 

 

 

 

 

 

Integrate the rounded shape in the builder:

new MaterialAlertDialogBuilder(MainActivity.this, R.style.RoundShapeTheme)
    .setTitle("Title")
    .setMessage("Your message goes here. Keep it short but clear.")
    .setPositiveButton("GOT IT", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialogInterface, int i) {
            // Positive button action
        }
    })
    .setNeutralButton("LATER", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialogInterface, int i) {
            // Neutral button action
        }
    })
    .show();

Adding Custom Typography

Custom fonts can further personalize your dialog’s appearance:

 

 

 


 

 

 

 

 

 

 

 

 

 

 

 

 

Utilize the custom font style to give your dialog a unique touch.

By following these steps, you can create engaging, modern dialogs that adhere to the Material Design principles and enhance the user experience within your Android applications. Experiment with different styles and shapes to find the best fit for your app’s theme!

Create a Free Account

Register now and get access to our Cloud Services.

Posts you might be interested in: