MDC-111 Android: como incorporar componentes do Material Design à sua base de código (Java)

MDC-111 Android:
como incorporar componentes do Material Design à sua base de código (Java)

Sobre este codelab

subjectÚltimo out. 12, 2020 atualizado
account_circleEscrito por Gautham Sajith

1. Introdução

logo_components_color_2x_web_96dp.png

Os componentes do Material Design (MDC, na sigla em inglês) ajudam os desenvolvedores a implementar o Material Design. Criados por uma equipe de engenheiros e designers de UX do Google, os MDC apresentam dezenas de componentes de interface bonitos e funcionais e estão disponíveis para Android, iOS, Web e Flutter.material.io/develop

Os componentes do Material Design para Android (MDC Android) não são um novo sistema ou framework que exige uma mudança de paradigma no app. Os MDC Android foram criados com as mesmas classes e APIs que você já conhece do Android, como botões AppCompat e campos de texto. Os componentes fornecidos pelos MDC Android podem ser usados conforme necessário e fazer uma melhoria imediata no design do seu app existente.

O que você vai criar

Neste codelab, você vai substituir alguns componentes atuais de um formulário por novos do MDC.

Componentes MDC-Android neste codelab

  • Campos de texto
  • Botões
  • Menus

O que é necessário

  • Conhecimento básico de desenvolvimento para Android.
  • Android Studio (faça o download dele aqui, caso ainda não tenha feito)
  • Um dispositivo ou emulador Android (disponível no Android Studio)
  • O exemplo de código (confira a próxima etapa)

Como você classificaria seu nível de experiência na criação de apps Android?

2. Configurar o ambiente de desenvolvimento

Faça o download do app inicial do codelab

O app inicial está localizado no diretório material-components-android-codelabs-111-starter/java. Insira cd nesse diretório antes de começar.

... ou clone-o do GitHub

Para clonar este codelab do GitHub, execute estes comandos:

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

Carregar o código inicial no Android Studio

  1. Quando o assistente de configuração for concluído e a janela Welcome to Android Studio for exibida, clique em Open an existing Android Studio project. Navegue até o diretório em que você instalou o exemplo de código e selecione java -> frete (ou pesquise shipping no computador) para abrir o projeto.
  2. Aguarde um pouco enquanto o Android Studio cria e sincroniza o projeto, conforme mostrado nos indicadores de atividade na parte inferior da janela.
  3. Como o SDK do Android ou as ferramentas de compilação não estão presentes, o Android Studio poderá encontrar alguns erros de compilação. Veja um exemplo a seguir. Siga as instruções no Android Studio para instalar/atualizar essas ferramentas e sincronizar o projeto.

gKYVUDrUs8bH1NfVV5DnikrjM7zJkP3j2rTbd0B66JVyySb54sS89vrTALAD6_AFp7p4CNA4OqOIAkyVjcR23CoUQwNtdsbEQ_sn5EooSqBQo9YBq9H_IsKctCTZBM8pci9WXlmlEw

Importar o MDC-Android

Navegue até o arquivo build.gradle do módulo app e verifique se o bloco dependencies inclui uma dependência no MDC Android:

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

Executar o app inicial

  1. Confira se a configuração do build à esquerda do botão Run / Play é app.
  2. Pressione o botão verde Run / Play para criar e executar o app.
  3. Na janela Select Deployment Target, se você já tiver um dispositivo Android listado entre os dispositivos disponíveis, pule para a Etapa 8. Caso contrário, clique em Create New Virtual Device.
  4. Na tela Select Hardware, selecione um smartphone, como o Pixel 2, e clique em Next.
  5. Na tela System Image, selecione uma versão recente do Android, de preferência o nível da API mais alto. Se ele não estiver instalado, clique no link Download exibido e faça o download.
  6. Clique em Next.
  7. Na tela Android Virtual Device (AVD), deixe as configurações como estão e clique em Finish.
  8. Selecione um dispositivo Android na caixa de diálogo de destino da implantação.
  9. Clique em OK.
  10. O Android Studio cria o app, faz a implantação e o abre automaticamente no dispositivo de destino.

Pronto. Você vai encontrar o app e o formato dele.

dba8e6132a12da58.png

3. Atualizar os campos de texto

Os campos de texto do Material Design têm um grande ganho de usabilidade em relação aos campos de texto simples. Ao definir a zona de hits com um contorno ou preenchimento de plano de fundo, é mais provável que os usuários interajam com seu formulário ou identifiquem campos de texto em conteúdo mais complicado.

Substituir estilos de campos de texto

Em shipping_info_activity.xml, adicione o seguinte estilo a todos os componentes XML TextInputLayout:

shipping_info_activity.xml

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

Cada TextInputLayout vai ficar assim:

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>

Crie e execute:

824c2b33592b2c7e.png

Os campos de texto são todos atualizados para usar os designs mais recentes no MDC.

Adicionar um erro

Os campos de texto dos MDC têm apresentação de erros integrada. O MDC adiciona texto em vermelho abaixo do campo de texto e atualiza as decorações para que também fiquem vermelhas.

Em ShippingInfoActivity.java, atualize o método onCreate() para que tenha a seguinte aparência:

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

Crie e execute. Pressione "SALVAR", mas deixe pelo menos um campo de texto em branco:

ef2a846d08f2780d.png

Os campos de texto vazios são vermelhos e têm um texto de erro abaixo deles.

4. Atualizar o botão

Os MDC têm botões com:

  • Ondulações de tinta
  • Bordas arredondadas
  • Compatibilidade com temas
  • Layout e tipografia perfeitos
  • Criado com AppCompatButton, a classe de botão padrão do Android, para que você saiba como usá-lo no seu código.

Substituição da classe do botão (opcional)

Por padrão, a biblioteca do Material Design infla automaticamente os botões comuns para botões MDC. No entanto, você pode substituir todas as referências a Botão pelo MaterialButton para acessar outros métodos disponíveis apenas em um MaterialButton, como a mudança do raio do canto. Os botões MDC são um componente simples de plug-and-play. Basta substituir o nome do componente XML Button por MaterialButton e aplicar o estilo MaterialButton padrão à MaterialButton.

Em shipping_info_activity.xml, mude o botão de:

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

Para:

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

Crie e execute:

824c2b33592b2c7e.png

5. Adicionar card

O MaterialCardView é um componente criado no CardView com:

  • Elevação e estilo corretos
  • Atributos de largura do traço e cor

Unir conteúdo em um card

Una o LinearLayout que contém seu conteúdo em shipping_info_activity.xml com um componente MaterialCardView, da seguinte maneira:

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>

Crie e execute. O formulário inteiro será embrulhado em um cartão:

75c86ab9fa395e3c.png

O componente de visualização de card do Material Design é uma maneira conhecida, mas nova de agrupar seu conteúdo em um card.

6. Recapitulação

Você substituiu alguns componentes comuns para mostrar o valor imediato: campos de texto, botões e cards, e não precisou reformular totalmente seu app. Outros componentes também podem fazer uma grande diferença, como a barra de apps superior e o TabLayout.

Próximas etapas

Acesse o catálogo de widgets do Android para explorar ainda mais componentes no MDC-Android.

Este codelab exigiu esforço e tempo normais para ser concluído

Quero continuar usando componentes do Material Design no futuro