Passa ai contenuti principali

Android Studio - Layout: Relative Layout

In Android Studio la prima cosa che dobbiamo fare per  creare l'app è definire il layout che deve assumere.
In questo Android ha la possibilità di creare diversi layout, cioè come vengono disposti gli oggetti all'interno dell'app:
Il Relative Layout è il layout più versatile rispetto al Linear Layout perché permette di disporre gli oggetti in riferimento ad altri oggetti.

ESEMPIO 1:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:id="@+id/RLayout"
tools:context=".MainActivity">
<TextView
android:id="@+id/lblMessaggio"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:text="Messaggio"
tools:ignore="HardcodedText" />
<EditText
android:id="@+id/txtMessaggio"
android:layout_width="match_parent"
android:layout_height="170px"
android:layout_alignLeft="@+id/lblMessaggio"
android:layout_below="@+id/lblMessaggio"
android:layout_centerHorizontal="true"
android:textSize="18sp" />
<Button
android:id="@+id/btnInvia"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignRight="@+id/txtMessaggio"
android:layout_below="@+id/txtMessaggio"
android:text="Invia"
tools:ignore="HardcodedText"/>
<Button
android:id="@+id/btnCancella"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/txtMessaggio"
android:layout_below="@+id/txtMessaggio"
android:text="Cancella"
tools:ignore="HardcodedText"/>
</RelativeLayout>

In questo tipo di layout per ogni vista possono essere valorizzati attributi che specificano la propria posizione rispetto alle altre viste. Questi attributi sono i seguenti:
  • layout_alignParentTop - allineamento in alto true o false
  • layout_alignParentLeft - allineamento a sinistra true o false
  • layout_alignLeft - allineamento a sinistra rispetto alla View con id....
  • layout_alignRight - allineamento a destra rispetto alla View con id....
  • layout_below - allineamento sotto rispetto alla View con id....
  • layout_CenterHorizontal - allineamento centrato nel layout true o false


ESEMPIO 2:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:id="@+id/RLayout"
tools:context=".MainActivity">
<TextView
android:id="@+id/lblMessaggio"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:text="Messaggio"
tools:ignore="HardcodedText" />
<EditText
android:id="@+id/txtMessaggio"
android:layout_width="match_parent"
android:layout_height="170px"
android:layout_alignLeft="@+id/lblMessaggio"
android:layout_below="@+id/lblMessaggio"
android:layout_centerHorizontal="true"
android:textSize="18sp" />
<Button
android:id="@+id/btnInvia"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignRight="@+id/txtMessaggio"
android:layout_below="@+id/txtMessaggio"
android:text="Invia"
tools:ignore="HardcodedText"/>
<Button
android:id="@+id/btnCancella"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/txtMessaggio"
android:layout_below="@+id/txtMessaggio"
android:text="Cancella"
tools:ignore="HardcodedText"/>
<TextView
android:id="@+id/txtMessaggio2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/btnCancella"
android:layout_below="@+id/btnCancella"
android:layout_centerHorizontal="true"
android:textSize="18sp"
android:text="Inserire un messaggio all'interno della casella di testo"/>
</RelativeLayout>
In questo esempio è stato aggiunto un TextView allineata a sinistra e posizionata sotto al pulsante Cancella tramite gli attributi layout_alignLeft e layout_below inoltre è stato aggiunto l'attributo layout_CenterHorizontal="true" per fare in modo che il testo sia largo come lo schermo.

Download Project
Download file APK



ESEMPIO 3:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:id="@+id/RLayout"
tools:context=".MainActivity">
<TextView
android:id="@+id/lblMessaggio"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:text="Messaggio"
tools:ignore="HardcodedText" />
<EditText
android:id="@+id/txtMessaggio"
android:layout_width="match_parent"
android:layout_height="170px"
android:layout_alignLeft="@+id/lblMessaggio"
android:layout_below="@+id/lblMessaggio"
android:layout_centerHorizontal="true"
android:textSize="18sp" />
<Button
android:id="@+id/btnInvia"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignRight="@+id/txtMessaggio"
android:layout_below="@+id/txtMessaggio"
android:text="Invia"
tools:ignore="HardcodedText"/>
<Button
android:id="@+id/btnCancella"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/txtMessaggio"
android:layout_below="@+id/txtMessaggio"
android:text="Cancella"
tools:ignore="HardcodedText"/>
<TextView
android:id="@+id/txtMessaggio2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignRight="@+id/btnCancella"
android:layout_below="@+id/btnCancella"
android:textSize="18sp"
android:text="Inserire un messaggio all'interno della casella di testo"/>
</RelativeLayout>
In questo esempio è stato tolto l'attributo layout_CenterHorizontal="true" ed il risultato è quello mostrato nell'immagine


ESEMPIO 4:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:id="@+id/RLayout"
tools:context=".MainActivity">
<TextView
android:id="@+id/lblMessaggio"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:text="Messaggio"
tools:ignore="HardcodedText" />
<EditText
android:id="@+id/txtMessaggio"
android:layout_width="match_parent"
android:layout_height="170px"
android:layout_alignLeft="@+id/lblMessaggio"
android:layout_below="@+id/lblMessaggio"
android:layout_centerHorizontal="true"
android:textSize="18sp" />
<Button
android:id="@+id/btnInvia"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignRight="@+id/txtMessaggio"
android:layout_below="@+id/txtMessaggio"
android:text="Invia"
tools:ignore="HardcodedText"/>
<Button
android:id="@+id/btnCancella"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/txtMessaggio"
android:layout_below="@+id/txtMessaggio"
android:text="Cancella"
tools:ignore="HardcodedText"/>
<TextView
android:id="@+id/txtMessaggio2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/btnInvia"
android:layout_below="@+id/btnInvia"
android:textSize="18sp"
android:text="Inserire un messaggio all'interno della casella di testo"/>
</RelativeLayout>
In questo esempio è stato modificato l'allineamento a sinistra, facendo riferimento al pulsante Invia e non al pulsante Cancella.

Commenti

Post popolari in questo blog

Android Studio - Impostare lingua app

In questo articolo vedremo come poter selezionare la lingua all'interno della nostra app. Nel precedente articolo in cui si parlava del file string.xml , la lingua dell'app veniva selezionata automaticamente in base alle impostazioni del dispositivo, mentre qui vedremo come poter selezionare a proprio piacimento la lingua che dovrà avere la nostra app indipendentemente dall'impostazione del dispositivo. Per prima cosa creare il layout Ecco un esempio do come può essere il file activity_main.xml Ora creare le stringhe di testo all'interno del file string.xml Ora creare la traduzione del file string.xml nelle varie lingua come descritto in questo articolo Il risultato sarà una serie di file string.xml delle varie lingue impostate. Ora queste di seguito sono tre funzioni che servono per: selezione della lingua salvataggio della selezione nelle preferenze dell'app caricamento della lingua quando si avvia l'app Ecco come si presenta il file Main...

Android Studio - Rinominare il progetto

Rinominare il progetto Android Studio ATTENZIONE!: non eseguire questa procedura se l'app è stata pubblicata su Google Play Store Quando si vuole cambiare nome al progetto: nome cartella in cui è contenuto il progetto package name bisogna eseguire questi passaggi: Andare nella cartella dove è contenuto il progetto Creare una copia del progetto in questione Rinominare la cartella copiata con il nome dell'app (non usare spazi tra le parole) Ora è necessario dire ad Android Studio il nome del nuovo progetto  Aprire Android Studio Aprire il progetto creato in precedenza Una volta caricato il progetto cliccare Build Cliccare Clean Project Attendere che venga eseguito il processo di "pulitura" Cliccare ancora su Build Cliccare su Rebuild Project Attendere che venga ricostruito il progetto Ora aprire la cartella app fino a visualizzare la cartella java Cliccare sull'ingranaggio  Deselezionare la voce Compact Middle Packa...

Arduino - Lettura tensione potenziometro e display LCD

Leggere il valore di un poteziometro (parte 2) Oggi vedremo come leggere il valore in tensione di un potenziometro collegato al pin Analogico A0 di Arduino.