SlideShare une entreprise Scribd logo
M.Houssem LAHIANI 
Cours de programmation sous Android 
Responsable de matière : Monsieur Houssem Lahiani. 
Chapitre 2 : Les interfaces graphiques sous android 
Plan du chapitre 
Chapitre 2 : Les interfaces graphiques sous Android ......................................................................................................... 2 
I. LinearLayout ................................................................................................................................................................ 2 
1. Orientation du Layout ............................................................................................................................................. 2 
2. Taille des éléments .................................................................................................................................................. 2 
II. RelativeLayout ........................................................................................................................................................ 3 
1. Positionnement relatif au conteneur...................................................................................................................... 3 
2. Position relative aux autres éléments .................................................................................................................... 3 
III. AbsoluteLayout ........................................................................................................................................................ 4 
IV. TableLayout ............................................................................................................................................................. 4
M.Houssem LAHIANI 
Chapitre 2 : Les interfaces graphiques sous Android 
Les interfaces sont définies via des fichiers XML. Ce format permet d'avoir un éditeur graphique d'interface et d'avoir une vraie séparation entre votre code Java (comportement) et votre interface. Tout ce qui est fait en XML pourrait également être fait en Java, cependant le code serait beaucoup plus verbeux et complexe à maintenir. Les interfaces développées en Java sont principalement utilisé comme le visuel d'un écran doit être généré dynamiquement en fonction des données (un formulaire dynamique par exemple). 
Il existe plusieurs types de layouts parmi lesquels : 
I. LinearLayout 
Ce layout permet de placer les composants « les uns après les autres ». Il faut ensuite savoir de quelle manière (verticalement ou horizontalement). 
Plusieurs propriètés sont disponibles pour permettre aux développeurs de personnaliser ce Layout. 
1. Orientation du Layout 
C’est la première chose que vous précisez quand vous créez votre LinearLayout (android:orientation). Cette option spécifie la façon dont seront alignés les éléments contenus dans ce Layout. Deux options sont disponibles : 
 Verticale : Oriente les éléments sur une ligne verticale. 
 Horizontale : Oriente les éléments sur une ligne horizontale. 
2. Taille des éléments 
Le LinearLayout ainsi que tous les widgets qui le composent doivent fournir une taille (hauteur et largeur). Donc ils doivent définir les deux propriétés suivantes : 
 android:layout_width 
 android:layout_height 
Ces deux propriétés peuvent prendre 3 types de valeur : 
 Une taille fixe : par exemple 50px (pixels). Donc quel que soit la taille de l’écran, l’élément occupera exactement 50px. 
 fill_parent : Dans ce cas on demande au composant d’occuper tout l’espace disponible chez son conteneur parent (après le placement des autres widgets). 
 wrap_content : Lorsqu'un layout a cette propriété, sa taille dépend directement de la taille des composants qu'il contient. Pour demander au Widget d’occuper une taille naturelle (la taille de son contenu pour le texte par exemple). S’il est trop gros par rapport à la taille disponible. Android s’occupera par exemple de couper le texte s’il n’y a plus de place.
M.Houssem LAHIANI 
II. RelativeLayout 
Le principe du RelativeLayout est de placer les éléments selon d’autres éléments du conteneur. Voici les différents moyens qui sont à votre disposition pour le placement des éléments dans le cas d’un RelativeLayout : 
1. Positionnement relatif au conteneur 
Dans cette relation, vous pouvez lier un élément à son conteneur : 
 android:layout_alignParentTop (true / false) : Cette option permet de préciser si le haut de l’élément doit être aligné avec celui de son conteneur. 
 Même principe pour : android:layout_alignParentBottom, android:layout_alignParentLeft et android:layout_alignParentRight. 
 android:layout_centerHorizontal : Indique si l’élément doit être centré horizontalement dans son conteneur. 
 Même principe pour : android:layout_centerVertical. 
 android:layout_centerInParent : Vous permet d’indiquer que l’élément doit être centré horizontalement et verticalement dans le conteneur. 
2. Position relative aux autres éléments 
Afin de pouvoir référencer le positionnement d’un élément par rapport à un autre, vous disposez d’un moyen simple et efficace, il s’agit des identificateurs (ID). 
Donc voilà comment vous pouvez utiliser un ID : 
 A la déclaration d’un élément : android:id= “@+id/idElem” 
 A l’utilisation : @id/idElem 
Maintenant que les bases sont posées, voici les différentes options disponibles : 
 android:layout_above : Indique que l’élément sera placé au-dessus de celui indiqué par son id. 
 android:layout_below : Indique que l’élément sera placé en dessous de celui indiqué par son id. 
 android:layout_toLeftOf : Indique que l’élément sera placé à gauche de celui indiqué par son id. 
 android:layout_toRightOf : Indique que l’élément sera placé à droite de celui indiqué par son id. 
 android:layout_alignTop : Indique que le haut de notre élément est aligné avec le haut de l’élément indiqué. 
 android:layout_alignBottom : Indique que le bas de notre élément est aligné avec le bas de l’élément indiqué. 
 android:layout_alignLeft : Indique que le côté gauche de notre élément est aligné avec le côté gauche de l’élément indiqué. 
 android:layout_alignRight : Indique que le côté droit de notre élément est aligné avec le côté droit de l’élément indiqué. 
 android:layout_alignBaseLine : Indique que les lignes de base des 2 éléments sont alignées.
M.Houssem LAHIANI 
III. AbsoluteLayout 
Android fournit également le conteneur AbsoluteLayout, dont le contenu est disposé en fonction de coordonnées spécifiques – on lui indique où placer un fils en précisant ses coordonnées X, Y, et Android le positionne à cet endroit sans poser de question. Ceci a l’avantage de fournir un positionnement précis; en revanche, cela signifie également que les vues n’auront un aspect correct que sur des écrans d’une certaine dimension, à moins d’écrire beaucoup de code pour ajuster les coordonnées en fonction de la taille de l’écran. 
Les écrans Android pouvant avoir n’importe quelle taille et ces tailles évoluent continuellement, l’utilisation d’AbsoluteLayout risque de devenir assez problématique. 
IV. TableLayout 
Dernier layout de base, il permet d'organiser les éléments en tableau, comme en HTML, mais sans les bordures. Voici un exemple d'utilisation de ce layout : 
<?xml version="1.0" encoding="utf-8"?> 
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:id="@+id/tableLayout1" 
android:layout_width="fill_parent" 
android:layout_height="fill_parent" > 
<!-- 2 columns --> 
<TableRow 
android:id="@+id/tableRow1" 
android:layout_width="wrap_content" 
android:layout_height="wrap_content" 
android:padding="5dip" > 
<TextView 
android:id="@+id/textView1" 
android:text="Column 1" 
android:textAppearance="?android:attr/textAppearanceLarge" /> 
<Button 
android:id="@+id/button1" 
android:text="Column 2" /> 
</TableRow> 
<!-- edittext span 2 column --> 
<TableRow 
android:id="@+id/tableRow2" 
android:layout_width="wrap_content" 
android:layout_height="wrap_content" 
android:padding="5dip" > 
<EditText 
android:id="@+id/editText1" 
android:layout_span="2" 
android:text="Column 1 &amp; 2" /> 
</TableRow> 
</TableLayout>
M.Houssem LAHIANI

Contenu connexe

Tendances

P2 éléments graphiques android
P2 éléments graphiques androidP2 éléments graphiques android
P2 éléments graphiques android
Lilia Sfaxi
 
patron de conception
patron de conception patron de conception
patron de conception
Shili Mohamed
 
Design patterns
Design patternsDesign patterns
Design patterns
Eric Toguem
 
Chap5 diagramme d'etats-transitions
Chap5 diagramme d'etats-transitionsChap5 diagramme d'etats-transitions
Chap5 diagramme d'etats-transitions
Amir Souissi
 
Support de cours technologie et application m.youssfi
Support de cours technologie et application m.youssfiSupport de cours technologie et application m.youssfi
Support de cours technologie et application m.youssfi
ENSET, Université Hassan II Casablanca
 
Chapitre 4 heritage et polymorphisme
Chapitre 4 heritage et polymorphismeChapitre 4 heritage et polymorphisme
Chapitre 4 heritage et polymorphisme
Amir Souissi
 
Android-Tp2: liste et adaptateurs
Android-Tp2: liste et adaptateursAndroid-Tp2: liste et adaptateurs
Android-Tp2: liste et adaptateurs
Lilia Sfaxi
 
Examen principal- php - correction
Examen principal- php - correctionExamen principal- php - correction
Examen principal- php - correction
Ines Ouaz
 
Chp6 - Développement iOS
Chp6 - Développement iOSChp6 - Développement iOS
Chp6 - Développement iOS
Lilia Sfaxi
 
Support Java Avancé Troisième Partie
Support Java Avancé Troisième PartieSupport Java Avancé Troisième Partie
Support Java Avancé Troisième Partie
ENSET, Université Hassan II Casablanca
 
Chapitre 5 classes abstraites et interfaces
Chapitre 5  classes abstraites et interfacesChapitre 5  classes abstraites et interfaces
Chapitre 5 classes abstraites et interfaces
Amir Souissi
 
Corrige tp java
Corrige tp javaCorrige tp java
Corrige tp java
Maya Medjdoub
 
Cours design pattern m youssfi partie 3 decorateur
Cours design pattern m youssfi partie 3 decorateurCours design pattern m youssfi partie 3 decorateur
Cours design pattern m youssfi partie 3 decorateur
ENSET, Université Hassan II Casablanca
 
Chp2 - Cahier des Charges
Chp2 - Cahier des ChargesChp2 - Cahier des Charges
Chp2 - Cahier des Charges
Lilia Sfaxi
 
Spring Boot RestApi.pptx
Spring Boot RestApi.pptxSpring Boot RestApi.pptx
applications-reparties
applications-repartiesapplications-reparties
applications-reparties
mourad50
 
Manuel des TP : Atelier Web 2
Manuel des TP : Atelier Web 2Manuel des TP : Atelier Web 2
Manuel des TP : Atelier Web 2
Faycel Chaoua
 
Support du cours : Programmation Web 2
Support du cours : Programmation Web 2Support du cours : Programmation Web 2
Support du cours : Programmation Web 2
Faycel Chaoua
 
La programmation modulaire en Python
La programmation modulaire en PythonLa programmation modulaire en Python
La programmation modulaire en Python
ABDESSELAM ARROU
 
Tp n 3 linux
Tp n 3 linuxTp n 3 linux
Tp n 3 linux
Amir Souissi
 

Tendances (20)

P2 éléments graphiques android
P2 éléments graphiques androidP2 éléments graphiques android
P2 éléments graphiques android
 
patron de conception
patron de conception patron de conception
patron de conception
 
Design patterns
Design patternsDesign patterns
Design patterns
 
Chap5 diagramme d'etats-transitions
Chap5 diagramme d'etats-transitionsChap5 diagramme d'etats-transitions
Chap5 diagramme d'etats-transitions
 
Support de cours technologie et application m.youssfi
Support de cours technologie et application m.youssfiSupport de cours technologie et application m.youssfi
Support de cours technologie et application m.youssfi
 
Chapitre 4 heritage et polymorphisme
Chapitre 4 heritage et polymorphismeChapitre 4 heritage et polymorphisme
Chapitre 4 heritage et polymorphisme
 
Android-Tp2: liste et adaptateurs
Android-Tp2: liste et adaptateursAndroid-Tp2: liste et adaptateurs
Android-Tp2: liste et adaptateurs
 
Examen principal- php - correction
Examen principal- php - correctionExamen principal- php - correction
Examen principal- php - correction
 
Chp6 - Développement iOS
Chp6 - Développement iOSChp6 - Développement iOS
Chp6 - Développement iOS
 
Support Java Avancé Troisième Partie
Support Java Avancé Troisième PartieSupport Java Avancé Troisième Partie
Support Java Avancé Troisième Partie
 
Chapitre 5 classes abstraites et interfaces
Chapitre 5  classes abstraites et interfacesChapitre 5  classes abstraites et interfaces
Chapitre 5 classes abstraites et interfaces
 
Corrige tp java
Corrige tp javaCorrige tp java
Corrige tp java
 
Cours design pattern m youssfi partie 3 decorateur
Cours design pattern m youssfi partie 3 decorateurCours design pattern m youssfi partie 3 decorateur
Cours design pattern m youssfi partie 3 decorateur
 
Chp2 - Cahier des Charges
Chp2 - Cahier des ChargesChp2 - Cahier des Charges
Chp2 - Cahier des Charges
 
Spring Boot RestApi.pptx
Spring Boot RestApi.pptxSpring Boot RestApi.pptx
Spring Boot RestApi.pptx
 
applications-reparties
applications-repartiesapplications-reparties
applications-reparties
 
Manuel des TP : Atelier Web 2
Manuel des TP : Atelier Web 2Manuel des TP : Atelier Web 2
Manuel des TP : Atelier Web 2
 
Support du cours : Programmation Web 2
Support du cours : Programmation Web 2Support du cours : Programmation Web 2
Support du cours : Programmation Web 2
 
La programmation modulaire en Python
La programmation modulaire en PythonLa programmation modulaire en Python
La programmation modulaire en Python
 
Tp n 3 linux
Tp n 3 linuxTp n 3 linux
Tp n 3 linux
 

En vedette

Cycle de vie d'activité Android et les composant d'Android
Cycle de vie d'activité Android et les composant d'AndroidCycle de vie d'activité Android et les composant d'Android
Cycle de vie d'activité Android et les composant d'Android
Houssem Lahiani
 
Introduction à Android
Introduction à AndroidIntroduction à Android
Introduction à Android
Yoann Gotthilf
 
Formation Android (Initiation à la programmation sous Android)
Formation Android (Initiation à la programmation sous Android)Formation Android (Initiation à la programmation sous Android)
Formation Android (Initiation à la programmation sous Android)
G²FOSS ENIT
 
Les vues (views) sous android
Les vues (views) sous androidLes vues (views) sous android
Les vues (views) sous android
Houssem Lahiani
 
Android wear
Android wearAndroid wear
Android wear
Houssem Lahiani
 
Sensors Expo 2013: Condition Based Maintenance, Evigia Systems
Sensors Expo 2013: Condition Based Maintenance, Evigia SystemsSensors Expo 2013: Condition Based Maintenance, Evigia Systems
Sensors Expo 2013: Condition Based Maintenance, Evigia Systems
Evigia
 
Android pour les debutants
Android pour les debutantsAndroid pour les debutants
Android pour les debutants
Amira Hakim
 
NodeJs, une introduction
NodeJs, une introductionNodeJs, une introduction
NodeJs, une introduction
Toxicode
 
Android
AndroidAndroid
Tutorial android - créer des apps
Tutorial android - créer des appsTutorial android - créer des apps
Tutorial android - créer des apps
Noé Breiss
 
Android pour l'industrie
Android pour l'industrieAndroid pour l'industrie
Android pour l'industrie
Alexandre LAHAYE
 
01 programmation mobile - android - (introduction)
01 programmation mobile - android - (introduction)01 programmation mobile - android - (introduction)
01 programmation mobile - android - (introduction)TECOS
 
Food and Beverage solution map New
Food and Beverage solution map NewFood and Beverage solution map New
Food and Beverage solution map New
IFS
 
SAP BASED PLANT MAINTENANCE
SAP BASED PLANT MAINTENANCESAP BASED PLANT MAINTENANCE
SAP BASED PLANT MAINTENANCE
PANKAJ TIKEKAR
 
SAP CBM
SAP CBMSAP CBM
SAP CBM
vvnalla
 
Programmation sous Android
Programmation sous AndroidProgrammation sous Android
Programmation sous Android
Olivier Le Goaër
 
IFS Metrix Service Management: An Overview
IFS Metrix Service Management: An OverviewIFS Metrix Service Management: An Overview
IFS Metrix Service Management: An Overview
IFS
 
Mobility: The business case
Mobility: The business caseMobility: The business case
Mobility: The business case
IFS
 
Service & assets news and solutions
Service & assets news and solutionsService & assets news and solutions
Service & assets news and solutions
IFS
 

En vedette (20)

Cycle de vie d'activité Android et les composant d'Android
Cycle de vie d'activité Android et les composant d'AndroidCycle de vie d'activité Android et les composant d'Android
Cycle de vie d'activité Android et les composant d'Android
 
Introduction à Android
Introduction à AndroidIntroduction à Android
Introduction à Android
 
Formation Android (Initiation à la programmation sous Android)
Formation Android (Initiation à la programmation sous Android)Formation Android (Initiation à la programmation sous Android)
Formation Android (Initiation à la programmation sous Android)
 
Les vues (views) sous android
Les vues (views) sous androidLes vues (views) sous android
Les vues (views) sous android
 
Android wear
Android wearAndroid wear
Android wear
 
Sensors Expo 2013: Condition Based Maintenance, Evigia Systems
Sensors Expo 2013: Condition Based Maintenance, Evigia SystemsSensors Expo 2013: Condition Based Maintenance, Evigia Systems
Sensors Expo 2013: Condition Based Maintenance, Evigia Systems
 
Android pour les debutants
Android pour les debutantsAndroid pour les debutants
Android pour les debutants
 
Cours 1 Android
Cours 1 AndroidCours 1 Android
Cours 1 Android
 
NodeJs, une introduction
NodeJs, une introductionNodeJs, une introduction
NodeJs, une introduction
 
Android
AndroidAndroid
Android
 
Tutorial android - créer des apps
Tutorial android - créer des appsTutorial android - créer des apps
Tutorial android - créer des apps
 
Android pour l'industrie
Android pour l'industrieAndroid pour l'industrie
Android pour l'industrie
 
01 programmation mobile - android - (introduction)
01 programmation mobile - android - (introduction)01 programmation mobile - android - (introduction)
01 programmation mobile - android - (introduction)
 
Food and Beverage solution map New
Food and Beverage solution map NewFood and Beverage solution map New
Food and Beverage solution map New
 
SAP BASED PLANT MAINTENANCE
SAP BASED PLANT MAINTENANCESAP BASED PLANT MAINTENANCE
SAP BASED PLANT MAINTENANCE
 
SAP CBM
SAP CBMSAP CBM
SAP CBM
 
Programmation sous Android
Programmation sous AndroidProgrammation sous Android
Programmation sous Android
 
IFS Metrix Service Management: An Overview
IFS Metrix Service Management: An OverviewIFS Metrix Service Management: An Overview
IFS Metrix Service Management: An Overview
 
Mobility: The business case
Mobility: The business caseMobility: The business case
Mobility: The business case
 
Service & assets news and solutions
Service & assets news and solutionsService & assets news and solutions
Service & assets news and solutions
 

Similaire à Les interface graphiques sous android

Gestion des ui
Gestion des uiGestion des ui
Gestion des ui
younes ben tlili
 
2-android.pdf
2-android.pdf2-android.pdf
2-android.pdf
FethiBenYahia1
 
Les Layouts XML
Les Layouts XMLLes Layouts XML
Les Layouts XML
Mohamed BOURAOUI
 
Chapitre 4 android
Chapitre 4 androidChapitre 4 android
Android201710 avrilcours3
Android201710 avrilcours3Android201710 avrilcours3
Android201710 avrilcours3
Anne-Marie Pinna-Dery
 
chapitre-7-listviews.pdf
chapitre-7-listviews.pdfchapitre-7-listviews.pdf
chapitre-7-listviews.pdf
olfaharrabi2
 
TP_2.pdf
TP_2.pdfTP_2.pdf
TP_2.pdf
FethiBenYahia1
 
Sociallymap - Qualitative automation tool
Sociallymap - Qualitative automation toolSociallymap - Qualitative automation tool
Sociallymap - Qualitative automation tool
Florent Hernandez
 
DART.pptx
DART.pptxDART.pptx
DART.pptx
IdrissaDembl
 
Android2017 cours2
Android2017 cours2Android2017 cours2
Android2017 cours2
Anne-Marie Pinna-Dery
 
Interace Utilisateur.pdf
Interace Utilisateur.pdfInterace Utilisateur.pdf
Interace Utilisateur.pdf
RihabBENLAMINE
 
TP_1.pdf
TP_1.pdfTP_1.pdf
TP_1.pdf
FethiBenYahia1
 
Les ateliers android_1_vers2015
Les ateliers android_1_vers2015Les ateliers android_1_vers2015
Les ateliers android_1_vers2015
Saber LAJILI
 
Les ateliers android_1_vers2015
Les ateliers android_1_vers2015Les ateliers android_1_vers2015
Les ateliers android_1_vers2015
Sabeur LAJILI
 
Les ateliers android_1_vers2015
Les ateliers android_1_vers2015Les ateliers android_1_vers2015
Les ateliers android_1_vers2015
Sabeur LAJILI
 
Création d’applications et découverte d’Android
Création d’applications et découverte d’AndroidCréation d’applications et découverte d’Android
Création d’applications et découverte d’Android
ENSAM Casablanca
 
5.ateliers avancés
5.ateliers avancés5.ateliers avancés
5.ateliers avancés
Chaikhani Ibtissam
 
Flutter and ML Kit For Firebase
Flutter and ML Kit For FirebaseFlutter and ML Kit For Firebase
Flutter and ML Kit For Firebase
Hamidou Bah
 

Similaire à Les interface graphiques sous android (20)

Gestion des ui
Gestion des uiGestion des ui
Gestion des ui
 
2-android.pdf
2-android.pdf2-android.pdf
2-android.pdf
 
Les Layouts XML
Les Layouts XMLLes Layouts XML
Les Layouts XML
 
Chapitre 4 android
Chapitre 4 androidChapitre 4 android
Chapitre 4 android
 
Android201710 avrilcours3
Android201710 avrilcours3Android201710 avrilcours3
Android201710 avrilcours3
 
chapitre-7-listviews.pdf
chapitre-7-listviews.pdfchapitre-7-listviews.pdf
chapitre-7-listviews.pdf
 
TP_2.pdf
TP_2.pdfTP_2.pdf
TP_2.pdf
 
Sociallymap - Qualitative automation tool
Sociallymap - Qualitative automation toolSociallymap - Qualitative automation tool
Sociallymap - Qualitative automation tool
 
DART.pptx
DART.pptxDART.pptx
DART.pptx
 
Android2017 cours2
Android2017 cours2Android2017 cours2
Android2017 cours2
 
Interace Utilisateur.pdf
Interace Utilisateur.pdfInterace Utilisateur.pdf
Interace Utilisateur.pdf
 
TP_1.pdf
TP_1.pdfTP_1.pdf
TP_1.pdf
 
test
testtest
test
 
Tutorial android
Tutorial androidTutorial android
Tutorial android
 
Les ateliers android_1_vers2015
Les ateliers android_1_vers2015Les ateliers android_1_vers2015
Les ateliers android_1_vers2015
 
Les ateliers android_1_vers2015
Les ateliers android_1_vers2015Les ateliers android_1_vers2015
Les ateliers android_1_vers2015
 
Les ateliers android_1_vers2015
Les ateliers android_1_vers2015Les ateliers android_1_vers2015
Les ateliers android_1_vers2015
 
Création d’applications et découverte d’Android
Création d’applications et découverte d’AndroidCréation d’applications et découverte d’Android
Création d’applications et découverte d’Android
 
5.ateliers avancés
5.ateliers avancés5.ateliers avancés
5.ateliers avancés
 
Flutter and ML Kit For Firebase
Flutter and ML Kit For FirebaseFlutter and ML Kit For Firebase
Flutter and ML Kit For Firebase
 

Les interface graphiques sous android

  • 1. M.Houssem LAHIANI Cours de programmation sous Android Responsable de matière : Monsieur Houssem Lahiani. Chapitre 2 : Les interfaces graphiques sous android Plan du chapitre Chapitre 2 : Les interfaces graphiques sous Android ......................................................................................................... 2 I. LinearLayout ................................................................................................................................................................ 2 1. Orientation du Layout ............................................................................................................................................. 2 2. Taille des éléments .................................................................................................................................................. 2 II. RelativeLayout ........................................................................................................................................................ 3 1. Positionnement relatif au conteneur...................................................................................................................... 3 2. Position relative aux autres éléments .................................................................................................................... 3 III. AbsoluteLayout ........................................................................................................................................................ 4 IV. TableLayout ............................................................................................................................................................. 4
  • 2. M.Houssem LAHIANI Chapitre 2 : Les interfaces graphiques sous Android Les interfaces sont définies via des fichiers XML. Ce format permet d'avoir un éditeur graphique d'interface et d'avoir une vraie séparation entre votre code Java (comportement) et votre interface. Tout ce qui est fait en XML pourrait également être fait en Java, cependant le code serait beaucoup plus verbeux et complexe à maintenir. Les interfaces développées en Java sont principalement utilisé comme le visuel d'un écran doit être généré dynamiquement en fonction des données (un formulaire dynamique par exemple). Il existe plusieurs types de layouts parmi lesquels : I. LinearLayout Ce layout permet de placer les composants « les uns après les autres ». Il faut ensuite savoir de quelle manière (verticalement ou horizontalement). Plusieurs propriètés sont disponibles pour permettre aux développeurs de personnaliser ce Layout. 1. Orientation du Layout C’est la première chose que vous précisez quand vous créez votre LinearLayout (android:orientation). Cette option spécifie la façon dont seront alignés les éléments contenus dans ce Layout. Deux options sont disponibles :  Verticale : Oriente les éléments sur une ligne verticale.  Horizontale : Oriente les éléments sur une ligne horizontale. 2. Taille des éléments Le LinearLayout ainsi que tous les widgets qui le composent doivent fournir une taille (hauteur et largeur). Donc ils doivent définir les deux propriétés suivantes :  android:layout_width  android:layout_height Ces deux propriétés peuvent prendre 3 types de valeur :  Une taille fixe : par exemple 50px (pixels). Donc quel que soit la taille de l’écran, l’élément occupera exactement 50px.  fill_parent : Dans ce cas on demande au composant d’occuper tout l’espace disponible chez son conteneur parent (après le placement des autres widgets).  wrap_content : Lorsqu'un layout a cette propriété, sa taille dépend directement de la taille des composants qu'il contient. Pour demander au Widget d’occuper une taille naturelle (la taille de son contenu pour le texte par exemple). S’il est trop gros par rapport à la taille disponible. Android s’occupera par exemple de couper le texte s’il n’y a plus de place.
  • 3. M.Houssem LAHIANI II. RelativeLayout Le principe du RelativeLayout est de placer les éléments selon d’autres éléments du conteneur. Voici les différents moyens qui sont à votre disposition pour le placement des éléments dans le cas d’un RelativeLayout : 1. Positionnement relatif au conteneur Dans cette relation, vous pouvez lier un élément à son conteneur :  android:layout_alignParentTop (true / false) : Cette option permet de préciser si le haut de l’élément doit être aligné avec celui de son conteneur.  Même principe pour : android:layout_alignParentBottom, android:layout_alignParentLeft et android:layout_alignParentRight.  android:layout_centerHorizontal : Indique si l’élément doit être centré horizontalement dans son conteneur.  Même principe pour : android:layout_centerVertical.  android:layout_centerInParent : Vous permet d’indiquer que l’élément doit être centré horizontalement et verticalement dans le conteneur. 2. Position relative aux autres éléments Afin de pouvoir référencer le positionnement d’un élément par rapport à un autre, vous disposez d’un moyen simple et efficace, il s’agit des identificateurs (ID). Donc voilà comment vous pouvez utiliser un ID :  A la déclaration d’un élément : android:id= “@+id/idElem”  A l’utilisation : @id/idElem Maintenant que les bases sont posées, voici les différentes options disponibles :  android:layout_above : Indique que l’élément sera placé au-dessus de celui indiqué par son id.  android:layout_below : Indique que l’élément sera placé en dessous de celui indiqué par son id.  android:layout_toLeftOf : Indique que l’élément sera placé à gauche de celui indiqué par son id.  android:layout_toRightOf : Indique que l’élément sera placé à droite de celui indiqué par son id.  android:layout_alignTop : Indique que le haut de notre élément est aligné avec le haut de l’élément indiqué.  android:layout_alignBottom : Indique que le bas de notre élément est aligné avec le bas de l’élément indiqué.  android:layout_alignLeft : Indique que le côté gauche de notre élément est aligné avec le côté gauche de l’élément indiqué.  android:layout_alignRight : Indique que le côté droit de notre élément est aligné avec le côté droit de l’élément indiqué.  android:layout_alignBaseLine : Indique que les lignes de base des 2 éléments sont alignées.
  • 4. M.Houssem LAHIANI III. AbsoluteLayout Android fournit également le conteneur AbsoluteLayout, dont le contenu est disposé en fonction de coordonnées spécifiques – on lui indique où placer un fils en précisant ses coordonnées X, Y, et Android le positionne à cet endroit sans poser de question. Ceci a l’avantage de fournir un positionnement précis; en revanche, cela signifie également que les vues n’auront un aspect correct que sur des écrans d’une certaine dimension, à moins d’écrire beaucoup de code pour ajuster les coordonnées en fonction de la taille de l’écran. Les écrans Android pouvant avoir n’importe quelle taille et ces tailles évoluent continuellement, l’utilisation d’AbsoluteLayout risque de devenir assez problématique. IV. TableLayout Dernier layout de base, il permet d'organiser les éléments en tableau, comme en HTML, mais sans les bordures. Voici un exemple d'utilisation de ce layout : <?xml version="1.0" encoding="utf-8"?> <TableLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/tableLayout1" android:layout_width="fill_parent" android:layout_height="fill_parent" > <!-- 2 columns --> <TableRow android:id="@+id/tableRow1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:padding="5dip" > <TextView android:id="@+id/textView1" android:text="Column 1" android:textAppearance="?android:attr/textAppearanceLarge" /> <Button android:id="@+id/button1" android:text="Column 2" /> </TableRow> <!-- edittext span 2 column --> <TableRow android:id="@+id/tableRow2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:padding="5dip" > <EditText android:id="@+id/editText1" android:layout_span="2" android:text="Column 1 &amp; 2" /> </TableRow> </TableLayout>