1. Introduction
Material Components (MDC) help developers implement Material Design. Created by a team of engineers and UX designers at Google, MDC features dozens of beautiful and functional UI components and is available for Android, iOS, web and Flutter.material.io/develop |
Material Components for Android (MDC Android) isn't a new system or framework that requires a paradigm shift in your app. MDC Android is built on the same classes and APIs you already know in Android, such as AppCompat buttons and text fields. Components provided by MDC Android can be used as needed and make an immediate design improvement to your existing app.
What you'll build
In this codelab, you'll replace some existing components in a form with new ones by MDC.
MDC-Android components in this codelab
- Text fields
- Buttons
- Menus
What you'll need
- Basic knowledge of Android development
- Android Studio (download it here if you don't already have it)
- An Android emulator or device (available through Android Studio)
- The sample code (see next step)
How would you rate your level of experience building Android apps?
2. Set up your development environment
Download the starter codelab app
The starter app is located in the material-components-android-codelabs-111-starter/java
directory. Be sure to cd
into that directory before beginning.
...or clone it from GitHub
To clone this codelab from GitHub, run the following commands:
git clone https://github.com/material-components/material-components-android-codelabs cd material-components-android-codelabs/ git checkout 111-starter
Load the starter code in Android Studio
- Once the setup wizard finishes and the Welcome to Android Studio window is shown, click Open an existing Android Studio project. Navigate to the directory where you had installed the sample code, and select java -> shipping (or search your computer for shipping) to open the Shipping project.
- Wait a moment for Android Studio to build and sync the project, as shown by activity indicators along the bottom of the Android Studio window.
- At this point, Android Studio might raise some build errors because you are missing the Android SDK or build tools, such as the one shown below. Follow the instructions in Android Studio to install/update these and sync your project.
Import MDC-Android
Navigate to the app
module's build.gradle
file and make sure that the dependencies
block includes a dependency on MDC Android:
api 'com.google.android.material:material:1.1.0-alpha06'
Run the starter app
|
Success! You should see the app and its form.
3. Update the text fields
Material Design text fields have a major usability gain over plain text fields. By defining the hit zone with an outline or a background fill, users are more likely to interact with your form or identify text fields within more complicated content.
Replace text field styles
In shipping_info_activity.xml
, add the following style to all TextInputLayout
XML components:
shipping_info_activity.xml
style="@style/Widget.MaterialComponents.TextInputLayout.OutlinedBox"
Each TextInputLayout
should look as follows:
shipping_info_activity.xml
<com.google.android.material.textfield.TextInputLayout
android:id="@+id/name_text_input"
style="@style/Widget.MaterialComponents.TextInputLayout.OutlinedBox"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:errorEnabled="true">
<com.google.android.material.textfield.TextInputLayout
android:id="@+id/name_edit_text"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="@string/label_name" />
</com.google.android.material.textfield.TextInputLayout>
Build and run:
The text fields are all updated to use the newer designs in MDC.
Add an error
MDC text fields have built-in error presentation. MDC adds red text beneath your text field and updates decorations to be red too.
In ShippingInfoActivity.java
, update the onCreate()
method to look as follows:
ShippingInfoActivity.java
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.shipping_info_activity);
View rootView = findViewById(android.R.id.content);
final List<TextInputLayout> textInputLayouts = Utils.findViewsWithType(
rootView, TextInputLayout.class);
Button button = findViewById(R.id.save_button);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
boolean noErrors = true;
for (TextInputLayout textInputLayout : textInputLayouts) {
String editTextString = textInputLayout.getEditText().getText().toString();
if (editTextString.isEmpty()) {
textInputLayout.setError(getResources().getString(R.string.error_string));
noErrors = false;
} else {
textInputLayout.setError(null);
}
}
if (noErrors) {
// All fields are valid!
}
}
});
}
Build and run. Press SAVE, but leave at least one text field empty:
The text fields that are empty are red and have error text beneath them.
4. Update the button
MDC has buttons with:
- Ink ripples
- Rounded corners
- Theming support
- Pixel-perfect layout and typography
- Built on AppCompatButton (the standard Android button class), so you know how to use them in your code.
Optionally Replace button class
By default the Material library automatically inflates regular Buttons to MDC Buttons. However, you may optionally replace all references to Button with MaterialButton so that you can access additional methods that are available only in a MaterialButton such changing the corner radius. MDC Buttons are a simple plug-and-play component. You just replace the XML component name Button
with MaterialButton
, and apply the default MaterialButton
style to the MaterialButton
.
In shipping_info_activity.xml
, change your button from:
shipping_info_activity.xml
<Button
android:id="@+id/save_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="end"
android:layout_marginTop="16dp"
android:text="@string/label_save" />
To:
shipping_info_activity.xml
<com.google.android.material.button.MaterialButton
android:id="@+id/save_button"
style="@style/Widget.MaterialComponents.Button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="end"
android:layout_marginTop="16dp"
android:text="@string/label_save" />
Build and run:
5. Add card
MaterialCardView
is a component built on CardView
with:
- Correct elevation and styling
- Stroke width and color attributes
Wrapping content in a card
Wrap your LinearLayout
containing your content in shipping_info_activity.xml
with a MaterialCardView
component, as follows:
shipping_info_activity.xml
<com.google.android.material.card.MaterialCardView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="16dp"
app:contentPadding="16dp">
<!-- LinearLayout goes here -->
</com.google.android.material.card.MaterialCardView>
Build and run. The entire form should be wrapped in a card:
The Material Card View component is a familiar but fresh way to easily wrap your content in a card.
6. Recap
You've replaced some common components to show immediate value: text fields, buttons, and cards and you didn't have to do a whole redesign of your app. Other components can make a big difference too, like Top App Bar and TabLayout.
Next steps
You can explore even more components in MDC-Android by visiting the Android Widgets Catalog.