MDC-111 Android: включение материальных компонентов в вашу кодовую базу (Java)

1. Введение

logo_comComponents_color_2x_web_96dp.png

Material Components (MDC) помогают разработчикам реализовать Material Design. MDC, созданный командой инженеров и UX-дизайнеров Google, включает в себя десятки красивых и функциональных компонентов пользовательского интерфейса и доступен для Android, iOS, Интернета и Flutter.material.io/develop.

Material Components для Android (MDC Android) — это не новая система или платформа, требующая изменения парадигмы вашего приложения. MDC Android построен на тех же классах и API, которые вы уже знаете в Android, таких как кнопки AppCompat и текстовые поля. Компоненты, предоставляемые MDC Android, можно использовать по мере необходимости и немедленно улучшить дизайн существующего приложения.

Что ты построишь

В этой лаборатории кода вы замените некоторые существующие компоненты в форме новыми от MDC.

Компоненты MDC-Android в этой лаборатории кода

  • Текстовые поля
  • Кнопки
  • Меню

Что вам понадобится

  • Базовые знания Android-разработки.
  • Android Studio (скачайте здесь , если у вас его еще нет)
  • Эмулятор Android или устройство (доступно через Android Studio).
  • Пример кода (см. следующий шаг)

Как бы вы оценили свой опыт создания приложений для Android?

Новичок Средний Опытный

2. Настройте среду разработки

Загрузите начальное приложение Codelab.

Стартовое приложение находится в каталоге material-components-android-codelabs-111-starter/java . Прежде чем начать, обязательно cd в этот каталог.

...или клонируйте его с GitHub

Чтобы клонировать эту кодовую лабораторию из GitHub, выполните следующие команды:

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

Загрузите стартовый код в Android Studio.

  1. После завершения работы мастера установки и отображения окна «Добро пожаловать в Android Studio» нажмите « Открыть существующий проект Android Studio» . Перейдите в каталог, в который вы установили пример кода, и выберите java -> доставка (или найдите на своем компьютере команду «Доставка» ), чтобы открыть проект «Доставка».
  2. Подождите, пока Android Studio создаст и синхронизирует проект, как показывают индикаторы активности в нижней части окна Android Studio.
  3. На этом этапе Android Studio может вызвать некоторые ошибки сборки, поскольку вам не хватает Android SDK или инструментов сборки, таких как показанный ниже. Следуйте инструкциям в Android Studio, чтобы установить/обновить их и синхронизировать проект.

gKYVUDrUs8bH1NfVV5DnikrjM7zJkP3j2rTbd0B66JVyySb54sS89vrTALAD6_AFp7p4CNA4OqOIAkyVjcR23CoUQwNtdsbEQ_sn5EooSqBQo9YBq9H_IsKctCTZBM8pci9WXlmlEw

Импорт MDC-Android

Перейдите к файлу build.gradle модуля app и убедитесь, что блок dependencies включает зависимость от MDC Android:

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

Запустите стартовое приложение

  1. Убедитесь, что конфигурация сборки слева от кнопки «Выполнить/Воспроизвести»app .
  2. Нажмите зеленую кнопку «Запустить/Воспроизвести», чтобы создать и запустить приложение.
  3. Если в окне «Выбор цели развертывания» у вас уже есть устройство Android в списке доступных устройств, перейдите к шагу 8 . В противном случае нажмите «Создать новое виртуальное устройство» .
  4. На экране «Выбор оборудования» выберите телефонное устройство, например Pixel 2 , и нажмите «Далее» .
  5. На экране «Образ системы» выберите последнюю версию Android , желательно самого высокого уровня API. Если он не установлен, щелкните появившуюся ссылку «Загрузить» и завершите загрузку.
  6. Нажмите Далее .
  7. На экране виртуального устройства Android (AVD) оставьте настройки без изменений и нажмите « Готово» .
  8. Выберите устройство Android в диалоговом окне цели развертывания.
  9. Нажмите «ОК» .
  10. Android Studio создает приложение, развертывает его и автоматически открывает на целевом устройстве.

Успех! Вы должны увидеть приложение и его форму.

dba8e6132a12da58.png

3. Обновите текстовые поля.

Текстовые поля Material Design имеют значительное преимущество в использовании по сравнению с обычными текстовыми полями. Определив зону попадания с помощью контура или фоновой заливки, пользователи с большей вероятностью будут взаимодействовать с вашей формой или идентифицировать текстовые поля в более сложном контенте.

Заменить стили текстового поля

В shipping_info_activity.xml добавьте следующий стиль ко всем XML-компонентам TextInputLayout :

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.png

Все текстовые поля обновлены для использования новых дизайнов в 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), поэтому вы знаете, как использовать их в своем коде.

Необязательно Заменить класс кнопки

По умолчанию библиотека материалов автоматически преобразует обычные кнопки в кнопки MDC. Однако при желании вы можете заменить все ссылки на Button на MaterialButton, чтобы получить доступ к дополнительным методам, доступным только в MaterialButton, например, к изменению углового радиуса. Кнопки MDC представляют собой простой компонент plug-and-play. Вы просто заменяете имя компонента 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.png

5. Добавить карту

MaterialCardView — это компонент, созданный на основе CardView с:

  • Правильная высота и стиль
  • Ширина обводки и атрибуты цвета

Упаковка содержимого в карточку

Оберните LinearLayout содержащий ваш контент в shipping_info_activity.xml , с помощью компонента MaterialCardView , как показано ниже:

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.png

Компонент Material Card View — это знакомый, но новый способ легко обернуть контент в карточку.

6. Подведение итогов

Вы заменили некоторые общие компоненты, чтобы сразу показать их ценность: текстовые поля, кнопки и карточки, и вам не пришлось полностью перепроектировать свое приложение. Другие компоненты также могут иметь большое значение, например, верхняя панель приложений и TabLayout.

Следующие шаги

Вы можете изучить еще больше компонентов MDC-Android, посетив Каталог виджетов Android .

Мне удалось завершить эту кодовую работу, потратив разумное количество времени и усилий.

Полностью согласен Соглашаться Нейтральный Не согласен Категорически не согласен

Я хотел бы продолжать использовать Material Components в будущем.

Полностью согласен Соглашаться Нейтральный Не согласен Категорически не согласен