MDC-111 per Android: incorporare componenti materiali nel tuo codebase (Java)

1. Introduzione

logo_components_color_2x_web_96dp.png

Material Components (MDC) consente agli sviluppatori di implementare Material Design. Creato dal team di ingegneri e designer UX di Google, MDC è dotato di decine di componenti UI belli e funzionali ed è disponibile per Android, iOS, web e Flutter.material.io/develop

Material Components per Android (MDC Android) non è un nuovo sistema o framework che richiede un cambio di paradigma nella tua app. MDC Android si basa sulle stesse classi e API che già conosci in Android, come i pulsanti e i campi di testo di AppCompat. I componenti forniti da MDC Android possono essere utilizzati secondo necessità e apportare un miglioramento immediato al design della tua app esistente.

Cosa creerai

In questo codelab, sostituirai alcuni componenti esistenti in un modulo con altri nuovi di MDC.

Componenti MCD-Android in questo codelab

  • Campi di testo
  • Pulsanti
  • Menu

Che cosa ti serve

  • Conoscenza di base dello sviluppo di Android
  • Android Studio (scaricalo qui se non l'hai ancora fatto)
  • Un emulatore o un dispositivo Android (disponibile tramite Android Studio)
  • Il codice di esempio (vedi il passaggio successivo)

Come giudichi il tuo livello di esperienza nello sviluppo di app per Android?

Principiante Livello intermedio Eccellente

2. Configurazione dell'ambiente di sviluppo

Scarica l'app codelab iniziale

L'app iniziale si trova nella directory material-components-android-codelabs-111-starter/java. Assicurati di cd in quella directory prima di iniziare.

...o clonarlo da GitHub

Per clonare questo codelab da GitHub, esegui questi comandi:

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

Carica il codice di avvio in Android Studio

  1. Al termine della configurazione guidata e visualizzata la finestra Ti diamo il benvenuto in Android Studio, fai clic su Apri un progetto Android Studio esistente. Passa alla directory in cui hai installato il codice di esempio e seleziona java -> spedizione (o cerca shipping sul computer) per aprire il progetto Spedizione.
  2. Attendi un momento affinché Android Studio crei e sincronizzi il progetto, come mostrato dagli indicatori di attività nella parte inferiore della finestra di Android Studio.
  3. A questo punto, Android Studio potrebbe generare alcuni errori di generazione perché non disponi dell'SDK Android o degli strumenti di sviluppo, come quello mostrato di seguito. Segui le istruzioni in Android Studio per installarle/aggiornarle e sincronizzare il progetto.

gKYVUDrUs8bH1NfVV5DnikrjM7zJkP3j2rTbd0B66JVyySb54sS89vrTALAD6_AFp7p4CNA4OqOIAkyVjcR23CoUQwNtdsbEQ_sn5EooSqBQo9YBq9H_IsKctCTZBM8pci9WXlmlEw

Importa MDC-Android

Passa al file build.gradle del modulo app e assicurati che il blocco dependencies includa una dipendenza su MDC per Android:

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

Esegui l'app iniziale

  1. Assicurati che la configurazione della build a sinistra del pulsante Esegui / Riproduci sia app.
  2. Premi il pulsante Esegui / Riproduci verde per creare ed eseguire l'app.
  3. Se tra i dispositivi disponibili è già elencato un dispositivo Android, nella finestra Seleziona la destinazione del deployment vai al passaggio 8. In caso contrario, fai clic su Crea nuovo dispositivo virtuale.
  4. Nella schermata Seleziona hardware, seleziona uno smartphone, ad esempio Pixel 2, quindi fai clic su Avanti.
  5. Nella schermata Immagine di sistema, seleziona una versione di Android recente, preferibilmente il livello API più elevato. Se non è installata, fai clic sul link Scarica visualizzato e completa il download.
  6. Fai clic su Avanti.
  7. Nella schermata Dispositivo virtuale Android (AVD), lascia le impostazioni invariate e fai clic su Fine.
  8. Seleziona un dispositivo Android dalla finestra di dialogo della destinazione dell'implementazione.
  9. Fai clic su Ok.
  10. Android Studio crea l'app, la distribuisce e la apre automaticamente sul dispositivo di destinazione.

Operazione riuscita. Dovresti vedere l'app e il relativo modulo.

dba8e6132a12da58.png

3. Aggiorna i campi di testo

I campi di testo Material Design presentano un notevole miglioramento in termini di usabilità rispetto ai campi di testo normale. Se definisci l'area sensibile con un contorno o un riempimento dello sfondo, è più probabile che gli utenti interagiscano con il modulo o identifichino campi di testo all'interno di contenuti più complessi.

Sostituire gli stili dei campi di testo

In shipping_info_activity.xml, aggiungi il seguente stile a tutti i componenti XML di TextInputLayout:

shipping_info_activity.xml

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

Ogni TextInputLayout dovrebbe avere il seguente aspetto:

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>

Crea ed esegui:

824c2b33592b2c7e.png

Tutti i campi di testo vengono aggiornati in modo da utilizzare i design più recenti in MDC.

Aggiungere un errore

I campi di testo MDC hanno una presentazione degli errori integrata. MDC aggiunge testo rosso sotto il campo di testo e aggiorna le decorazioni in rosso.

In ShippingInfoActivity.java, aggiorna il metodo onCreate() in modo che abbia il seguente aspetto:

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

Crea ed esegui. Premi SALVA, ma lascia almeno un campo di testo vuoto:

ef2a846d08f2780d.png

I campi di testo vuoti sono rossi e presentano un testo di errore sotto.

4. Aggiorna il pulsante

MDC dispone di pulsanti con:

  • Increspature d'inchiostro
  • Angoli arrotondati
  • Supporto per i temi
  • Layout e tipografia perfetti per Pixel
  • Basato su AppCompatButton (la classe dei pulsanti Android standard), sai come utilizzarli nel tuo codice.

Se necessario, sostituisci la classe del pulsante

Per impostazione predefinita, la libreria Material gonfia automaticamente i pulsanti normali in pulsanti MDC. Tuttavia, puoi facoltativamente sostituire tutti i riferimenti a Pulsante con MaterialButton in modo da poter accedere a metodi aggiuntivi disponibili solo in un MaterialButton, come la modifica del raggio d'angolo. I pulsanti MDC sono un semplice componente plug-and-play. Devi solo sostituire il nome del componente XML Button con MaterialButton e applicare lo stile predefinito di MaterialButton a MaterialButton.

In shipping_info_activity.xml, modifica il pulsante da:

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

A:

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

Crea ed esegui:

824c2b33592b2c7e.png

5. Aggiungi scheda

MaterialCardView è un componente basato su CardView con:

  • Correggere l'elevazione e lo stile
  • Attributi di colore e larghezza tratto

Aggregare contenuti in una scheda

Aggrega LinearLayout che include i tuoi contenuti in shipping_info_activity.xml con un componente MaterialCardView, come segue:

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>

Crea ed esegui. L'intero modulo deve essere racchiusa in una scheda:

75c86ab9fa395e3c.png

Il componente Visualizzazione schede Material è un modo familiare ma innovativo per racchiudere facilmente i tuoi contenuti in una scheda.

6. Riepilogo

Hai sostituito alcuni componenti comuni per mostrare un valore immediato: campi di testo, pulsanti e schede, senza dover riprogettare completamente l'app. Anche altri componenti possono fare una grande differenza, come la barra delle app in alto e il Layout Tab.

Passaggi successivi

Puoi esplorare altri componenti di MDC-Android visitando il catalogo di widget Android.

Ho completato questo codelab con una quantità di tempo e di sforzi ragionevoli

Totalmente d'accordo D'accordo Né chiara, né confusa In disaccordo Totalmente in disaccordo

Vorrei continuare a utilizzare Material Components in futuro

Totalmente d'accordo D'accordo Né chiara, né confusa In disaccordo Totalmente in disaccordo