MDC-111 Android:将 Material 组件整合到代码库中 (Java)

1. 简介

logo_components_color_2x_web_96dp.png

Material Components (MDC) 有助于开发者实现 Material Design。MDC 是由一组 Google 工程师和用户体验设计人员倾心打造的,提供数十种精美实用的界面组件,可用于 Android、iOS、Web 和 Flutter.material.io/develop

适用于 Android 的 Material 组件 (MDC Android) 不是需要在您的应用中转变范式的新系统或框架。MDC Android 基于您在 Android 中已知的相同类和 API 构建,例如 AppCompat 按钮和文本字段。MDC Android 提供的组件可根据需要使用,并立即对现有应用进行设计改进。

构建内容

在此 Codelab 中,您将通过 MDC 将表单中的一些现有组件替换为新组件。

本 Codelab 中用到的 MDC-Android 组件

  • 文本字段
  • 按钮
  • 菜单

所需条件

  • 已掌握 Android 开发方面的基础知识
  • Android Studio(如果尚未安装,请在此处下载)
  • Android 模拟器或设备(可通过 Android Studio 获取)
  • 示例代码(参见下一步)

您如何评价自己在构建 Android 应用方面的经验水平?

<ph type="x-smartling-placeholder"></ph> 新手 中级 熟练

2. 设置您的开发环境

下载起始 Codelab 应用

起始应用位于 material-components-android-codelabs-111-starter/java 目录中。请务必先通过 cd 命令转到该目录,然后再开始操作。

…或从 GitHub 克隆

如需从 GitHub 克隆此 Codelab,请运行以下命令:

git clone https://github.com/material-components/material-components-android-codelabs
cd material-components-android-codelabs/
git checkout 111-starter

在 Android Studio 中加载起始代码

  1. 在设置向导已完成且系统显示 Welcome to Android Studio 窗口后,点击 Open an existing Android Studio project。导航到安装了示例代码的目录,然后选择 java ->shipping [运费](或在计算机中搜索 shipping [运费])以打开配送项目。
  2. 等待 Android Studio 构建和同步项目,如 Android Studio 窗口底部的 activity 指示器所示。
  3. 此时,由于缺少 Android SDK 或构建工具,因此 Android Studio 可能会显示一些构建错误(如下所示)。按照 Android Studio 中的说明安装/更新这些内容,并同步您的项目。

gKYVUDrUs8bH1NfVV5DnikrjM7zJkP3j2rTbd0B66JVyySb54sS89vrTALAD6_AFp7p4CNA4OqOIAkyVjcR23CoUQwNtdsbEQ_sn5EooSqBQo9YBq9H_IsKctCTZBM8pci9WXlmlEw

导入 MDC-Android

转到 app 模块的 build.gradle 文件,并确保 dependencies 代码块包含 MDC Android 的依赖项:

api 'com.google.android.material:material:1.1.0-alpha06'

运行起始应用

  1. 确保“Run / Play”按钮左侧的 build 配置是 app
  2. 按绿色的“Run / Play”按钮,以构建并运行该应用。
  3. Select Deployment Target 窗口中,如果已有 Android 设备列在可用设备列表中,请跳至第 8 步。否则,请点击 Create New Virtual Device
  4. Select Hardware 屏幕中,选择一个手机设备(如 Pixel 2),然后点击 Next
  5. System Image 屏幕中,选择较新的 Android 版本,最好选择最高的 API 级别。如果相应版本尚未安装,请点击随即显示的 Download 链接,然后完成下载。
  6. 点击 Next
  7. Android Virtual Device (AVD) 屏幕上,让各项设置保持不变,然后点击 Finish
  8. 从部署目标对话框中选择一个 Android 设备
  9. 点击 Ok
  10. Android Studio 会构建并部署该应用,然后自动在目标设备上将其打开。

大功告成!您应该会看到应用及其形式。

dba8e6132a12da58.png

3. 更新文本字段

与纯文本字段相比,Material Design 文本字段大大提高了易用性。通过轮廓或背景填充来界定命中区域,用户更有可能与您的表单互动,或识别出更复杂的内容中的文本字段。

替换文本字段样式

shipping_info_activity.xml 中,将以下样式添加到所有 TextInputLayout XML 组件中:

shipping_info_activity.xml

style="@style/Widget.MaterialComponents.TextInputLayout.OutlinedBox"

每个 TextInputLayout 应如下所示:

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>

构建并运行:

824c2b33592b2c7e

文本字段均已更新,以使用 MDC 中的新设计。

添加错误

MDC 文本字段具有内置的错误呈现功能。MDC 会在文本字段下方添加红色文本,并将装饰元素也更新为红色。

ShippingInfoActivity.java 中,更新 onCreate() 方法,如下所示:

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!
           }
       }
   });
}

构建并运行。按“保存”,但至少将一个文本字段留空:

ef2a846d08f2780d.png

空文本字段显示为红色,且下方为错误文本。

4. 更新按钮

MDC 具有具有以下特点的按钮:

  • 墨水涟漪
  • 圆角
  • 主题支持
  • 完美像素的布局和排版
  • 基于 AppCompatButton(标准 Android 按钮类),因此您将了解如何在代码中使用它们。

(可选)替换按钮类

默认情况下,Material 库会自动将常规 Button 膨胀为 MDC 按钮。不过,您可以选择将所有对 Button 的引用替换为 MaterialButton,以便访问仅在 MaterialButton 中可用的其他方法,例如更改圆角半径。MDC 按钮是一种简单的即插即用组件。只需将 XML 组件名称 Button 替换为 MaterialButton,并将默认的 MaterialButton 样式应用于 MaterialButton 即可。

shipping_info_activity.xml 中,将按钮从:

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" />

迁移后:

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" />

构建并运行:

824c2b33592b2c7e

5. 添加卡

MaterialCardView 是一个基于 CardView 构建的组件,其中包含:

  • 更正高度和样式
  • 描边宽度和颜色属性

将内容封装在卡片中

使用 MaterialCardView 组件将包含内容的 LinearLayout 封装在 shipping_info_activity.xml 中,如下所示:

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>

构建并运行。应将整个表单封装在卡片中:

75c86ab9fa395e3c

Material Card View 组件是一种熟悉但又新颖的方式,可让您轻松将内容封装在卡片中。

6. 要点回顾

您已替换了显示即时价值的一些常见组件:文本字段、按钮和卡片,而无需对应用进行彻底的重新设计。其他组件也可以发挥很大的作用,例如顶部应用栏和 TabLayout。

后续步骤

您可以访问 Android 微件目录,探索 MDC-Android 中的更多组件。

我能够用合理的时间和精力完成此 Codelab

非常赞同 赞同 中立 不赞同 非常不赞同

我希望日后继续使用 Material Components

<ph type="x-smartling-placeholder"></ph> 非常赞同 赞同 一般 不赞同 非常不赞同