Développement sur Android



Documents pareils
Programmation des applications mobiles avec Android. 1 Inspiré du cours de Olivier Le Goaer

TP SIN Programmation sur androïde Support : eclipse

TP au menu «UI ANDROID»

Android 4 Les fondamentaux du développement d'applications Java

Outils, langage et approche Android Une introduction. Nicolas Stouls lyon.fr

Les fondamentaux du développement d applications Java

1.3 Gestion d'une application

Warren PAULUS. Android SDK et Android x86

De Java à Android version 0.1

Table des matières. Partie I Concepts de base Préface... VII

SOMMAIRE

Encore plus de widgets et de conteneurs

Créer des applications Android

Chapitre 1 Retour en arrière

TP2 : Client d une BDD SqlServer

Installation et prise en main

Programmation mobile avec Android

Programmation Android L3 informatique

Tutorial pour une application simple

TD/TP 1 Introduction au SDK d Android

Programmation Mobile Android Master CCI

Android. Programmation. De la conception au déploiement avec le SDK Google Android 2. Damien Guignard Julien Chable Emmanuel Robles

Développement Android. J.-F. Couchot

Gestion des différentes tailles d écran

Développement d'applications pour Android. M. Dalmau IUT de Bayonne Pays Basque

Tutoriel Android. Pour démarrer la programmation d'applications Android

Plate formes mobiles. Utilisation. Contexte 9/29/2010 IFC 2. Deux utilisations assez distinctes :

- TP Programmation Android - NFA024 Conservatoire National des Arts et Métiers

Optimiser pour les appareils mobiles

Android 101. Rémi Forax

Introduction ANDROID

Tutoriel Android - TP de prise en main

Projet Android (LI260) Cours 2

Développement tablette Android. SophiaConf2011 Par Arnaud FARINE

Béatrice Bertrand CDDP de l Eure. Béatrice Bertrand CDDP de l'eure

Point sur les solutions de développement d apps pour les périphériques mobiles

Education Delivery Intelligent Tool

Bases Java - Eclipse / Netbeans

APPLICATIONS JAVA. 1. Android. Développement d'activités Java sous Android. Android Partie I. L'architecture du système Android. Application Android

TP1 : Initiation à Java et Eclipse

WINDEV MOBILE. ios SMARTPHONE SUPPORT: IOS, ANDROID, WINDOWS PHONE 8.

Module Architecture des systèmes mobiles : Android première partie Didier FERMENT - UPJV

Génie Logiciel et Interaction Homme-Machine PROJET UCAMPUS

Épisode 2 : Les outils de développement Alain Menu édition 2.1, septembre 2013

Android. Présentation d Android. Florent Garin

Développement sous Android

MANUEL UTILISATEUR. Application 4trip

Environnements de développement (intégrés)

BIRT (Business Intelligence and Reporting Tools)

République Algérienne Démocratique et Populaire Université Abou Bakr Belkaid Tlemcen Faculté des Sciences Département d Informatique

Développement sous Android

Introduction à Eclipse

BUREAU VIRTUEL. Utilisation de l application sur ipad. Guide utilisateur. Sciences Po Utilisation du bureau virtuel sur ipad 1 / 6

Eclipse atelier Java

Formation. Module WEB 4.1. Support de cours

Manuel logiciel client for Android

Android Publish/Subscribe, GCM, Google Cloud Messaging : une introduction

Édu-groupe - Version 4.3

Terminaux Mobiles Communicants

Votre premier projet Android

Synchroniser ses photos

Android en action. Abdelkader Lahmadi Université de Lorraine

Guide de l utilisateur Mikogo Version Windows

Java 7 Les fondamentaux du langage Java

[Projet S9] Rédacteurs & Contributeurs Entité Rédacteurs Contributeurs Imededdine HOSNI Olivier MARTY. Validation du document Nom Date Visa

Serveur d'application Client HTML/JS. Apache Thrift Bootcamp

Freeway 7. Nouvelles fonctionnalités

< Atelier 1 /> Démarrer une application web

Table des matières Introduction Démarrage Les composants graphiques... 26

Design adaptatif. Guide de l utilisateur VIENNA LONDON MUNICH BERLIN PARIS HONG KONG MOSCOW ISTANBUL BEIJING ZURICH

ContactForm et ContactFormLight - Gestionnaires de formulaire pour Prestashop Edité par ARETMIC S.A.

LES TABLETTES : GÉNÉRALITÉS

Manuel d utilisation pour la plateforme BeExcellent MANUEL D UTILISATION POUR LA PLATEFORME BEEXCELLENT

Guide de l utilisateur. Faites connaissance avec la nouvelle plateforme interactive de

Manuel de System Monitor

Guide d utilisation. Version 1.1

Iphone vs. Android. Mardi 17 Novembre 2009 Paris, la Défense. Xavier PARADON, Directeur Technique Valtech Training

Tutoriel code::blocks

ECLIPSE ET PDT (Php development tools)

Documentation Liste des changements apportés

Table des matières ENVIRONNEMENT

Utiliser Dev-C++ .1Installation de Dev-C++ Table des matières

TP redondance DHCP. Gillard Frédéric Page 1/17. Vue d ensemble du basculement DHCP

Guide de prise en main Windows 8

CTIconnect PRO. Guide Rapide

Présentation du Framework BootstrapTwitter


Manuel d utilisation du site web de l ONRN

Table des matières. Module tablette

Développement d applications professionnelles avec Android 2

Cours Plugin Eclipse. Université Paris VI / Parcours STL / Master I Pierre-Arnaud Marcelot - Iktek - pamarcelot@iktek.com

Utilisation de l éditeur.

Contenu Microsoft Windows 8.1

Access 2007 FF Access FR FR Base

ZOTERO Un outil gratuit de gestion de bibliographies

Google Drive, le cloud de Google

Application de messagerie simple sur Android : Rapport de projet de VAP RSM

Avant-propos FICHES PRATIQUES EXERCICES DE PRISE EN MAIN CAS PRATIQUES

Transcription:

Développement sur Android V. Barichard LERIA - Département Informatique Université d Angers L3 - Info L3 - Info Développement sur Android 1

Une histoire très récente La naissance du smartphone 1994 : Le Simon IBM 1996 : Les Nokia sous Symbian 1997 : Les smartphones Ericsson 2001 : L environnement Palm OS 2002 : Le Pocket PC de Microsoft 2002 : Les smartphones BlackBerry 2007 : L Iphone avec l ios d Apple 2008 : Le HTC Dream sous l Android de Google L3 - Info Développement sur Android 4

Une histoire très récente Le développement sur smartphones L émergence de ios ios est le premier système d exploitation démocratisant l utilisation des smartphones Simple d utilisation et pourvu d un grand nombre d applications il plait au plus grand nombre Il est associé à un «SDK» et un «store» d applications accessibles aux développeurs BlackBerry est plus orienté vers les professionnels Windows axe son système vers l amusement Android dans ses premières versions était moins simple que ios mais plus complet et paramétrable Il centre ses développements vers la géolocalisation et les réseaux sociaux Il offre comme ios un «SDK» (Open Source) et un «store» d applications L3 - Info Développement sur Android 5

Une histoire très récente Google Slogan : «Don t be evil» Fondé le 27 septembre 1998 par Larry Page et Sergey Brin Chiffre d affaires en 2012 : 50, 2 milliards de $ Effectif (le 20 Juillet 2012) : 54604 Développe des produits connus et répandus : Moteur de recherche, YouTube, Chrome, AdSense, GoogleEarth, Android Google a bâti sa renommée grâce à l utilisation de produits «Open Source» En retour Google soutient l Open Source en employant certains de ses grands acteurs C est en appliquant cette idée qu il développe Android, un système d exploitation libre pour smartphones L3 - Info Développement sur Android 6

Une histoire très récente Android Android est un système d exploitation Open Source basé sur un noyau Linux Il fonctionne sur smartphones, tablettes, montres, lunettes,... Initialement développé par une startup du même nom, rachetée par Google en 2005 En 2008, le gphone est lancé aux États-Unis dans un parteneriat entre Google et T-mobile La mascotte BugDroid est un personnage du jeu Gauntlet : The Third Encounter sorti sur Atari dans les années 1990 L3 - Info Développement sur Android 7

Une histoire très récente Enjeux pour Google Avènement de l Open Handset Alliance Google est dépendant d acteurs tiers du marché Sa politique actuelle est d étendre aux smartphones ses services existants (recherche, publicité, réseaux sociaux,... ) En 2007, Google initie la création de l Open Handset Alliance Composée en 2013 de 84 industriels A pour objectif de développer des normes ouvertes pour les appareils mobiles Google devient acteur dans la partie matérielle avec le rachat de Motorola Mobility Diversification des appareils utilisant Android (téléviseurs, appareils photos, montres, lunettes,... ) L3 - Info Développement sur Android 8

Une histoire très récente Stratégie et rentabilité d Android Revenus basés sur la vente d applications et l intégration de la publicité Android est rentable depuis octobre 2010 et génère plus de revenus qu ios depuis novembre 2010 Stratégie de développement : Basée sur l Open Source Un «store» de plusieurs milliers d applications Des mises à jours régulières et faciles d installation Un système ouvert pour facilité sa diffusion et son adaptation sur différents matériels L3 - Info Développement sur Android 9

Le SDK d Android et Éclipse Qu est-ce qu un programme Android? Android offre un framework riche mais suffisamment rigide et étanche : Du XML pour les interfaces Les activités : briques de base d une application Les services : conçus pour durer Les fournisseurs de contenus : abstraction de données Les intentions (intents) : interagir avec le système Android permet d accéder aux fonctionnalités avancées de l appareil : Stockage (base de données, support externe) Réseau (Wifi, Bluetooth, 3G,... ) Multimédia (lecture audio, photo, caméra) GPS (géolocation des applications par différents moyens) Services de téléphonie (appels, SMS) L3 - Info Développement sur Android 11

Le SDK d Android et Éclipse Le SDK d Android Langage Java Sauf cas particuliers, une application Android est écrite en Java Le code Java est compilé pour pouvoir s exécuter sur la machine virtuelle Dalvik embarquée sur Android L application est empaquetée dans un fichier APK (Android PacKage) puis installée sur l appareil Le JDK (Java Development Kit) est un prérequis à la réalisation d un programme Android Il est conseillé d installer le SDK Java de Sun/Oracle L3 - Info Développement sur Android 12

Le SDK d Android et Éclipse Le SDK d Android Installation Les outils de développement d Android : http://developer.android.com/sdk/index.html Installation «des» SDK et des greffons : Dans le répertoire tools/, lancer l Android SDK and AVD Manager (exécuter le script android ou le programme setup.exe) Sélectionner puis installer les versions du SDK voulues ainsi que les greffons tiers requis (API Google Maps) L3 - Info Développement sur Android 13

Le SDK d Android et Éclipse Le SDK d Android La jungle des matériels et des versions Plusieurs versions d Android coexistent À chaque version du système est associé un niveau d API Une «cible» est la combinaison d un niveau d API et d un indicateur précisant si l on inclut les API Google : 10 : Android 2.3.4 GINGERBREAD 13 : Android 3.2 HONEYCOMB 15 : Android 4.0.4 ICE CREAM SANDWICH 16/17/18 : Android 4.1.x 4.2.x 4.3 JELLY BEAN 19 : Android 4.4 KITKAT L3 - Info Développement sur Android 14

Le SDK d Android et Éclipse L émulateur, un outil indispensable L émulateur Android permet de simuler plusieurs terminaux Informations nécessaires à la configuration d un AVD : Une version cible du SDK Des informations sur le stockage (mémoire, carte SD) Résolution de l appareil choisi L3 - Info Développement sur Android 15

Le SDK d Android et Éclipse Monitor, le couteau Suisse Monitor permet de : Parcourir les logs de l émulateur Modifier la position GPS Simuler la réception de SMS ou d appels Prendre une capture d écran de l émulateur Accéder au gestionnaire du SDK et des émulateurs... L3 - Info Développement sur Android 16

Le SDK d Android et Éclipse Éclipse et Android Éclipse est un IDE adapté pour le développement Java Combiné au Plugin ADT il permet de créer et gérer des applications Android Création de projet Gestion des émulateurs Compilation, déboggage et exécution dans un émulateur Éclipse n est toutefois pas indispensable : Apache Ant (version 1.8.1 ou supérieure) permet de compiler un projet Android Il faut ensuite utiliser android et adb pour exécuter des actions spécifiques Android (création de projet, déploiement,... ) L3 - Info Développement sur Android 17

Ma première application Android Création d un projet En ligne de commande Un squelette complet pour un projet Android peut-être créé par la commande suivante : android create project --target "android-18" \ --path ProjetTest \ --activity Debut \ --package com.univangers.l3info.projettest Liste des cibles disponibles : android list targets Compilation, installation : ant clean debug install Un fichier apk a été créé Le programme est disponible sur l émulateur dans le launcher L3 - Info Développement sur Android 19

Ma première application Android Organisation d un projet En ligne de commande Un projet Android est constitué d une arborescence de répertoires et de fichiers : AndroidManifest.xml, build.xml, *.properties, proguard-project.txt bin/, libs/, res/, src/, assets/, gen/ Le répertoire src/ contient la hiérarchie des activités La première compilation produira le fichier R.java contenant l activité principale bin/nomapp-*.apk est la véritable application Android nomapp-debug-aligned.apk correspond à l application optimisée et compilée en mode debug L3 - Info Développement sur Android 20

Ma première application Android Organisation d un projet Le fichier AndroidManifest.xml AndroidManifest.xml déclare les activités, services ainsi que la façon dont il s intègre au système <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.univangers.l3info.projettest"> <application android:label="@string/app_name" android:icon="@drawable/ic_launcher"> <activity android:name="debut" android:label="@string/app_name"> <intent-filter> <action android:name="android.intent.action.main" /> <category android:name="android.intent.category.launcher" /> </intent-filter> </activity> </application> </manifest> Le nom du paquet Java est la «base» de l application et de l espace de nom Il sert également d identifiant unique L3 - Info Développement sur Android 21

Ma première application Android Création d un projet Sous Éclipse/ADT Le SDK Android met à disposition le plugin Éclipse ADT : Assistants pour la création d un projet Boutons et raccourcis pour la compilation et l exécution des applications Une ébauche de conception de l interface à la souris Création et gestion des émulateurs Il est possible d importer un projet Android ainsi que d en créer un de zéro Intégration de monitor pour parcourir les fichiers journaux, modifier la position GPS, simuler des appels ou SMS Lors de l exécution du projet, il faut avoir un fichier java dans l onglet actif. Si l éditeur contient un fichier xml, l exécution provoquera une erreur L3 - Info Développement sur Android 22

Ma première application Un bouton et clic la date se met à jour... package com.univangers.l3info.projettest; import android.app.activity; import android.os.bundle; import android.view.view; import android.widget.button; import java.util.date; public class Debut extends Activity implements View.OnClickListener { Button btn; /** Called when the activity is first created. */ @Override public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); btn = new Button(this); btn.setonclicklistener(this); updatetime(); setcontentview(btn); } public void onclick(view view) { updatetime(); } private void updatetime() { btn.settext(new Date().toString()); } } L3 - Info Développement sur Android 24

Description de l interface graphique Le choix des ressources en XML Séparer la description de l interface de son comportement Les layouts XML sont stockés dans res/layout aapt est appelé automatiquement à la compilation pour intégrer les layouts Chaque fichier XML décrit une View, il contient une arborescence d éléments dont les attributs peuvent : Décrire l aspect d un widget Décrire le comportement d un conteneur Les widgets sont accessibles depuis le code Java Le nom du fichier XML est celui de la classe du widget de la vue L3 - Info Développement sur Android 25

Description de l interface graphique res/layout/main.xml <?xml version="1.0" encoding="utf-8"?> <Button xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/button" android:text="" android:layout_width="match_parent" android:layout_height="match_parent" /> fill_parent a été renommé en match_parent depuis Android 2.2, version 8 de l API Code Java @Override public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.main); btn = (Button)findViewById(R.id.button); btn.setonclicklistener(this); updatetime(); } Convention de format : @+id/nom_unique Seule la première occurrence de l id fait apparaitre le «+» L3 - Info Développement sur Android 26

Les «widgets» Introduction Les principaux widgets héritent de la classe View Ils ont une taille minimale qui s adapte en fonction de leur contenu Le padding permet de contrôler l espacement avec les widgets adjacents Un widget peut changer d état (actif/inactif) avec setenabled() requestfocus() donne le focus à un widget particulier getparent() retourne le widget ou le conteneur parent findviewbyid() renvoie un widget d après son identifiant getrootview() renvoie la racine de l arborescence (fournie à l activité via l appel à setcontentview()) L3 - Info Développement sur Android 28

Les «widgets» Les «labels» et les «boutons» Le widget label est obtenu avec une instance de TextView Un élément TextView possède de nombreux attributs : android:text, android:typeface,... Le widget Button (sous-classe de TextView) a déjà été vu plus tôt Depuis Android 1.6, un écouteur de clic peut être ajouté à la ressource : Une méthode publique de l activité (prenant un argument View et renvoyant void) doit être définie L attribut android:onclick du Button doit être renseigné L3 - Info Développement sur Android 29

Les «widgets» Les «labels» et les «boutons» exemple <?xml version="1.0" encoding="utf-8"?> <Button xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/button" android:text="" android:onclick="clicreaction" android:layout_width="match_parent" android:layout_height="match_parent" />... public class Debut extends Activity { @Override public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.main); updatetime(); } public void clicreaction(view view) { updatetime(); } private void updatetime() { Button btn; btn = (Button)findViewById(R.id.button); btn.settext(new Date().toString()); } } L3 - Info Développement sur Android 30

Les «widgets» Les images Les widgets ImageView et ImageButton permettent d intégrer des images ImageButton (sous-classe de ImageView) ajoute les comportements d un Button à ImageView L attribut android:src précise la ressource graphique à utiliser L3 - Info Développement sur Android 31

Les «widgets» Les champs de saisie Le widget EditText permet d éditer et de capturer du texte saisi par l utilisateur Il hérite de TextView mais possède des propriétés supplémentaires : android:autotext, android:inputtype, android:singleline,... L3 - Info Développement sur Android 32

Les «widgets» Les champs de saisie exemple <?xml version="1.0" encoding="utf-8"?> <EditText xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/champs" android:layout_width="match_parent" android:layout_height="match_parent" android:singleline="false" /> package com.univangers.l3info.projettest; import android.app.activity; import android.os.bundle; import android.widget.edittext; public class Debut extends Activity { /** Called when the activity is first created. */ @Override public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.main); EditText txt = (EditText)findViewById(R.id.champs); txt.settext("un exemple de saisie..."); } } L3 - Info Développement sur Android 33

Les «widgets» Les cases à cocher Le widget CheckBox correspond à la boite à cocher Il hérite de CompoundButton qui dérive elle-même de TextView Les méthodes ischecked(), setchecked et toggle permette d interagir avec le widget depuis le code Java Pour servir d écouteur, l activité doit implémenter l interface OnCheckedChangeListener L3 - Info Développement sur Android 34

Les «widgets» Les cases à cocher exemple <?xml version="1.0" encoding="utf-8"?> <CheckBox xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/casecoche" android:layout_width="match_parent" android:layout_height="match_parent" android:text="case décochée" />... import android.widget.checkbox; import android.widget.compoundbutton; import android.widget.compoundbutton.oncheckedchangelistener; public class Debut extends Activity implements CompoundButton.OnCheckedChangeListener { CheckBox cb; @Override public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.main); } cb = (CheckBox)findViewById(R.id.caseCoche); cb.setoncheckedchangelistener(this); } public void oncheckedchanged(compoundbutton buttonview, boolean ischecked) { if (ischecked) cb.settext("case cochée"); else cb.settext("case décochée"); } L3 - Info Développement sur Android 35

Les «widgets» Les boutons radios Le widget RadioButton implémente le comportement du bouton radio Comme CheckBox, il hérite de CompoundButton et permet d utiliser ischecked(), toggle(),... Les RadioButton sont groupés dans un RadioGroup afin de les lier En y affectant un id, le groupe devient accessible depuis le code Java L3 - Info Développement sur Android 36

Les «widgets» Les boutons radios exemple <?xml version="1.0" encoding="utf-8"?> <RadioGroup xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent" > <RadioButton android:id="@+id/radiobleu" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="bleu" /> <RadioButton android:id="@+id/radiorouge" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="rouge" /> <RadioButton android:id="@+id/radiovert" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="vert" /> </RadioGroup> L3 - Info Développement sur Android 37

Les «conteneurs» Introduction Le «layout manager» Dans quasiment toutes les bibliothèques graphiques, un «layout manager» place les widgets Pour donner les indications de placement, des «conteneurs» sont utilisés La plupart du temps, ils permettent de ranger les widgets en ligne ou dans une grille Android fournit plusieurs conteneurs dont les principaux : LinearLayout : pour le placement séquentiel RelativeLayout : pour le placement relatif TableLayout : pour le placement en grille ScrollView : pour le placement dans une zone avec barres de défilement Comme les widgets, ils peuvent être implémentés dans des ressources XML L3 - Info Développement sur Android 39

Les «conteneurs» Le «LinearLayout» Le «LinearLayout» permet de disposer les widgets les uns derrières les autres dans une boite Il faut pour cela indiquer l orientation de la boite (verticale ou horizontale) ex : android:orientation="horizontal" La disposition des widgets dépend de la place occupée par le conteneur Les propriétés android:layout_width (et layout_height) modifient le comportement du widget : wrap_content indique que le widget occupe la place minimale nécessaire match_parent indique que le widget occupe tout l espace disponible de son conteneur Il est possible d indiquer des marges grâce aux propriétés android:layout_margin,... L3 - Info Développement sur Android 40

Les «conteneurs» Le «LinearLayout» Poids et alignement Lorsque plusieurs widgets utilisent match_parent des poids peuvent être renseignés dans android:layout_weight Si les poids sont identiques, l espace sera réparti équitablement entre les widgets Si le poids d un widget est deux fois plus important qu un autre, il occupera deux fois plus de place à l écran L alignement des widgets dans un LinearLayout est défini par la propriété android:layout_gravity setgravity() permet de modifier la propriété depuis le code Java Les gravités les plus courantes sont : left, right, center_horizontal et center_vertical L3 - Info Développement sur Android 41

Les «conteneurs» Le «LinearLayout» Exemple Il est possible de combiner les LinearLayout Il est possible d utiliser des pourcentages au lieu des poids si : La propriété layout (layout_width ou layout_height) de la dimension libre est à 0dip La somme des pourcentages est égale à 100 L3 - Info Développement sur Android 42

Les «conteneurs» <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="match_parent" > <LinearLayout android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_weight="1" > <Button android:text="un" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_weight="1" /> <Button android:text="deux" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_weight="1" /> </LinearLayout> </LinearLayout> L3 - Info Développement sur Android 43

Les «conteneurs» <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="match_parent" > <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:orientation="vertical" android:layout_height="match_parent" android:layout_width="match_parent" android:layout_weight="1" > android:layout_height="match_parent" <Button android:text="un" android:layout_weight="1" > android:layout_width="match_parent" <Button android:text="un" android:layout_height="match_parent" android:layout_width="match_parent" android:layout_weight="1" /> android:layout_height="match_parent" <Button android:text="deux" android:layout_weight="1" /> android:layout_width="match_parent" <Button android:text="deux" android:layout_height="match_parent" android:layout_width="match_parent" android:layout_weight="1" /> android:layout_height="match_parent" </LinearLayout> android:layout_weight="2" /> </LinearLayout> </LinearLayout> </LinearLayout> L3 - Info Développement sur Android 44

Les «conteneurs» <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="match_parent" > <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:orientation="vertical" <LinearLayout android:layout_height="match_parent" xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_weight="1" android:orientation="vertical" > android:layout_height="match_parent" <Button android:layout_width="match_parent" android:text="un" android:layout_weight="1" > android:layout_width="match_parent" android:layout_height="match_parent" <Button android:text="un" android:layout_height="match_parent" android:layout_weight="1" > android:layout_width="match_parent" <Button android:layout_weight="1" android:text="un" /> android:layout_height="match_parent" <Button android:layout_width="wrap_content" android:text="deux" android:layout_weight="1" /> android:layout_width="match_parent" android:layout_height="match_parent" <Button android:text="deux" android:layout_height="match_parent" android:layout_gravity="left" android:layout_width="match_parent" android:layout_weight="1" /> android:layout_height="match_parent" </LinearLayout> <Button android:text="deux" android:layout_weight="2" /> </LinearLayout> android:layout_width="wrap_content" </LinearLayout> android:layout_height="match_parent" </LinearLayout> android:layout_gravity="center" android:layout_weight="1" /> <Button android:text="trois" android:layout_width="wrap_content" android:layout_height="match_parent" android:layout_gravity="right" android:layout_weight="1" /> </LinearLayout> </LinearLayout> L3 - Info Développement sur Android 45

Les «conteneurs» Le «RelativeLayout» Le placement relatif des widgets Le RelativeLayout permet : De placer un widget relativement au conteneur De placer un widget à gauche, en dessous,... d un autre D aligner des widgets les uns par rapport aux autres Placement relatif au conteneur : android: (layout_alignparenttop, layout_alignparentbottom, layout_alignparentleft et layout_alignparentright) permettent d aligner le haut (resp. bas, gauche et droite) du widget avec celui du conteneur android: (layout_centerhorizontal, layout_centervertical et layout_centerinparent) permettent de centrer horizontalement (resp. verticalement et les deux) le widget dans le conteneur L3 - Info Développement sur Android 46

Les «conteneurs» Le «RelativeLayout» Le placement relatif des widgets Placement relatif aux widgets : android: (layout_above, layout_below, layout_toleftof et layout_torightof) permettent de placer un widget au-dessus (resp. en-dessous, à gauche ou à droite) d un autre widget android: (layout_aligntop, layout_alignbottom, layout_alignleft et layout_alignright) permettent d aligner le haut (resp. bas, gauche et droite) du widget avec un autre (indiqué) Il est aussi possible de recouvrir un widget par un autre en utilisant habilement ces propriétés L3 - Info Développement sur Android 47

Les «conteneurs» Le «RelativeLayout» Faire référence à d autres widgets Lors du placement relatif, il faut faire référence à d autres widgets dans la ressource XML Comme nous l avons vu, les widgets peuvent avoir des id (les rendants accessibles depuis le code Java) Leur syntaxe est la suivante : android:id="@+id/nomunique" Le symbole "+" est ajouté uniquement la première fois où l id est utilisé <Button android:id="@+id/btnok" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="ok" /> <Button android:id="@+id/btncancel" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_toleftof="@id/btnok" android:layout_aligntop="@id/btnok" android:text="annuler" /> L3 - Info Développement sur Android 48

Les «conteneurs» Le «RelativeLayout» Exemple 1 L3 - Info Développement sur Android 49

Les «conteneurs» Le «RelativeLayout» Exemple 1, ressource XML <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" > <TextView android:id="@+id/labelurl" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="url :" android:layout_alignbaseline="@+id/champsaisie" android:layout_alignparentleft="true" /> <EditText android:id="@id/champsaisie" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_torightof="@id/labelurl" android:layout_alignparenttop="true" /> <Button android:id="@+id/btnok" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@id/champsaisie" android:layout_alignright="@id/champsaisie" android:text="ok" /> <Button android:id="@+id/btncancel" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_toleftof="@id/btnok" android:layout_aligntop="@id/btnok" android:text="annuler" /> </RelativeLayout> L3 - Info Développement sur Android 50

Les «conteneurs» Le «RelativeLayout» Exemple 2 L3 - Info Développement sur Android 51

Les «conteneurs» Le «RelativeLayout» Exemple 2, ressource XML <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" > <TextView android:id="@+id/label" android:layout_width="match_parent" android:layout_height="match_parent" android:text="le texte est derrière" android:textsize="80dip" /> <Button android:id="@+id/btn" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="bouton devant" android:layout_centerinparent="true" /> </RelativeLayout> L3 - Info Développement sur Android 52

Les «conteneurs» Le «TableLayout» Le placement dans une grille Le TableLayout permet de placer les widgets dans les cellules d un tableau Il est forcément associé au conteneur TableRow symbolisant les lignes du tableau Le nombre de colonnes est calculé en fonction de la ligne qui contient le plus de widgets La propriété android:layout_span permet de fusionner des cellules horizontalement La propriété android:layout_column force le widget à être dans la cellule indiquée L3 - Info Développement sur Android 53

Les «conteneurs» Le «TableLayout» Influencer le comportement des colonnes Habituellement TableLayout ne contient que des TableRow Il est possible de glisser des widgets entre les lignes déconseillé La propriété android:stretchcolumns permet d étirer la ou les colonnes indiquées dans l espace libre La propriété android:shrinkcolumns permet de réduire la taille des colonnes indiquées en découpant les widgets sur plusieurs lignes La propriété android:collapsecolumns contient la liste des colonnes refermées initialement L3 - Info Développement sur Android 54

Les «conteneurs» Le «TableLayout» Exemple <?xml version="1.0" encoding="utf-8"?> <TableLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:stretchcolumns="1" > <TableRow> <TextView android:id="@+id/labelurl" android:text="url :" /> <EditText android:id="@+id/champsaisie" android:layout_span="3" /> </TableRow> <View android:layout_height="2dip" android:background="#ff0000" /> <TableRow> <Button android:id="@+id/btncancel" android:layout_column="2" android:text="annuler" /> <Button android:id="@+id/btnok" android:text="ok" /> </TableRow> </TableLayout> L3 - Info Développement sur Android 55

Les «conteneurs» Le «ScrollView» Le défilement des widgets Scroller sur une activité est indispensable sur petit écran ScrollView est conteneur permettant à un contenu de défiler Il permet d encapsuler un autre conteneur ne pouvant être affiché intégralement Des bars de défilement apparaissent Depuis Android 1.5, le conteneur HorizontalScrollView permet de faire défiler horizontalement les widgets contenus L3 - Info Développement sur Android 56

Les «conteneurs» Le «ScrollView» Exemple <?xml version="1.0" encoding="utf-8"?> <ScrollView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" > <LinearLayout android:orientation="vertical" android:layout_width="match_parent" android:layout_height="wrap_content" > <TextView android:text="haut" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" /> <View android:layout_width="match_parent" android:layout_height="1000dip" android:background="#ff0000" /> <TextView android:text="bas" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" /> </LinearLayout> </ScrollView> L3 - Info Développement sur Android 57

Poser une question à l utilisateur Claviers physiques et logiciels Le framework des méthodes de saisie Depuis Android 1.5 le framework IMF 1 a été introduit IMF permet, par exemple, d abstraire la notion de clavier : Si il n y a pas de clavier physique un IME 2 apparaît Il permet aussi de contrôler l IME (contrôle du recouvrement, nature des données... ) La propriété android:inputtype indique la nature des données attendues lors d une saisie : text, number, phone, datetime, date, time Il est aussi possible de contrôler la touche accessoire en bas à droite du clavier La propriété android:imeoptions contrôle la touche accessoire (ex : actionsend, actiondone) 1. Input Method Framework 2. Input Method Editor L3 - Info Développement sur Android 60

Poser une question à l utilisateur Contôle du mode de saisie Le framework des méthodes de saisie <?xml version="1.0" encoding="utf-8"?> <ScrollView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" > <TableLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:stretchcolumns="1" > <TableRow> <TextView android:text="sans paramètre" /> <EditText /> </TableRow> <TableRow> <TextView android:text="adresse e-mail :" /> <EditText android:inputtype="text textemailaddress" android:imeoptions="actionsend" /> </TableRow> <TableRow> <TextView android:text="nombre :" /> <EditText android:inputtype="number numbersigned" /> </TableRow> <TableRow> <TextView android:text="multi-lignes :" /> <EditText android:inputtype="text textmultiline textautocorrect" android:minlines="3" android:gravity="top" /> </TableRow> </TableLayout> </ScrollView> L3 - Info Développement sur Android 61

Poser une question à l utilisateur Le framework des méthodes de saisie Aller plus loin avec IMF Il possible de modifier le mode d apparition du clavier en fonction des circonstances : L activité entière peut glisser vers le haut La taille de l activité peut-être modifiée L activité entière peut-être masquée (en mode paysage par exemple) Android choisit par défaut le mode le plus adapté à l activité, mais il peut-être fixé dans le manifest par la propriété android:windowsoftinputmode Il est aussi possible de masquer le clavier depuis le code Java : InputMethodManager mgr=(inputmethodmanager)getsystemservice(input_method_service); mgr.hidesoftinputfromwindow(fld.getwindowtoken(), 0); ou mgr.hidesoftinputfromwindow(fld.getwindowtoken(), InputMethodManager.HIDE_IMPLICIT_ONLY); L3 - Info Développement sur Android 62

Poser une question à l utilisateur Widgets de sélection Introduction La saisie d informations sur un smartphone est toujours problématique Les erreurs de frappes peuvent se multiplier... Contrôler l IME est une première étape pour limiter les erreurs La solution la plus adéquate reste de limiter le nombre de réponses possibles Les listes de choix sont donc des widgets indispensables Android permet de lier directement un widget liste à un type abstrait de données adapté Ce sont les adapteurs L3 - Info Développement sur Android 64

Poser une question à l utilisateur L adapteur «ArrayAdapter» Widgets de sélection ArrayAdapter permet de lier un tableau à un widget adapté String[] items = { "rouge", "vert", "bleu", "jaune" }; new ArrayAdapter<String>(this, android.r.layout.simple_list_item1, items); ArrayAdapter prend trois paramètres : Un contexte, généralement l activité L identifiant de ressource de la vue à utiliser La liste des éléments Par défaut, ArrayAdapter appelle la méthode tostring() des objets de la liste Il instanciera ensuite la vue avec le résultat Le second paramètre de ArrayAdapter renseigne la vue La valeur android.r.layout.simple_list_item_1 correspond à une vue prédéfinie simple L3 - Info Développement sur Android 65

Poser une question à l utilisateur Widgets de sélection La «ListActivity» Utilisation de «ArrayAdapter» Le widget d Android pour les listes est le ListView Toutefois, utiliser une ListActivity est préconisé quand l activité se réduit à une liste La propriété android:choicemode="multiplechoice" permet d obtenir une liste à choix multiples <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="wrap_content" > <TextView android:id="@+id/selection" android:layout_width="match_parent" android:layout_height="wrap_content" /> <ListView android:id="@android:id/list" android:layout_width="match_parent" android:layout_height="match_parent" android:drawselectorontop="false" /> </LinearLayout> L3 - Info Développement sur Android 66

Poser une question à l utilisateur La «ListActivity» Utilisation de «ArrayAdapter» Widgets de sélection package com.univangers.l3info.projettest; import android.app.listactivity; import android.os.bundle; import android.view.view; import android.widget.listview; import android.widget.arrayadapter; import android.widget.textview; public class Debut extends ListActivity { private TextView selection; private static final String[] items = { "rouge", "bleu", "vert", "jaune", "rose" }; @Override public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.main); setlistadapter(new ArrayAdapter<String>(this, android.r.layout.simple_list_item_1, items)); selection=(textview)findviewbyid(r.id.selection); } public void onlistitemclick(listview parent, View v, int pos, long id) { selection.settext(items[pos]); } } L3 - Info Développement sur Android 67

Poser une question à l utilisateur Widgets de sélection Les listes déroulantes Les listes déroulantes sont implémentées avec le widget Spinner La méthode setadapteur() renseigne l adaptateur à utiliser La méthode setonitemselectedlistener() fournit l écouteur en cas de clic L3 - Info Développement sur Android 68

Poser une question à l utilisateur Widgets de sélection <Spinner android:id="@+id/boitederoulante" android:layout_width="match_parent" android:layout_height="wrap_content" android:drawselectorontop="true" /> public class Debut extends Activity implements AdapterView.OnItemSelectedListener { private TextView selection; private static final String[] items = { "rouge", "bleu", "vert", "jaune", "rose" }; @Override public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.main); selection=(textview)findviewbyid(r.id.selection); Spinner spin = (Spinner)findViewById(R.id.boitederoulante); spin.setonitemselectedlistener(this); ArrayAdapter<String> aa = new ArrayAdapter<String>(this, android.r.layout.simple_spinner_item, items); aa.setdropdownviewresource(android.r.layout.simple_spinner_dropdown_item); spin.setadapter(aa); } public void onitemselected(adapterview<?> parent, View v, int pos, long id) { selection.settext(items[pos]); } public void onnothingselected(adapterview<?> parent) { selection.settext(""); } } L3 - Info Développement sur Android 69

Poser une question à l utilisateur Widgets de sélection L autocomplétion Économie de temps et gain de fiabilité! Le widget AutoCompleteTextView est un mélange de EditText et de Spinner Il hérite de EditText Le texte saisi est utilisé pour présenter les choix possibles restants Un TextWatcher permet de réaliser des actions quand le texte change L3 - Info Développement sur Android 70

Poser une question à l utilisateur L autocomplétion Widgets de sélection <AutoCompleteTextView android:id="@+id/editauto" android:layout_width="match_parent" android:layout_height="wrap_content" android:completionthreshold="3" /> public class Debut extends Activity implements TextWatcher { private TextView selection; private AutoCompleteTextView editauto; private static final String[] items = { "rouge", "bleu", "vert", "jaune", "rose" }; @Override public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.main); selection=(textview)findviewbyid(r.id.selection); editauto = (AutoCompleteTextView)findViewById(R.id.editAuto); editauto.addtextchangedlistener(this); editauto.setadapter(new ArrayAdapter<String>(this, android.r.layout.simple_dropdown_item_1line, items)); } public void ontextchanged(charsequence s, int start, int before, int count) { selection.settext(editauto.gettext()); } public void beforetextchanged(charsequence s, int start, int count, int after) { } public void aftertextchanged(editable s) { } } L3 - Info Développement sur Android 71

Pour aller plus loin... Autres widgets et conteneurs Encore plus de widgets En plus des widgets déjà vus, Android fournit un grand nombre de widgets et conteneurs : saisie des dates, des temps, sélecteurs de fichiers, positionnement absolu... Les listes, vues avant peuvent avoir un rendu complètement personnalisé il est aussi possible d utiliser des onglets grâce au conteneur TabHost et l activité TabActivity Toutefois, la philosophie d Android est de limiter au maximum leur utilisation Il est aussi possible d utiliser des bases de données SQL, de faire apparaître des pop-ups et même d intégrer un navigateur web. L3 - Info Développement sur Android 74

Pour aller plus loin... Autres widgets et conteneurs Les tiroirs : «SlidingDrawer» Le SlidingDrawer peut passer d ouvert à fermé Comme il se superpose à l affichage, il ne peut se trouver que dans un RelativeLayout ou un FrameLayout Un FrameLayout est dédié à la supperposition de widgets Il est possible depuis le code Java, de l ouvrir, le fermer, le bloquer,... L3 - Info Développement sur Android 75

Pour aller plus loin... Les tiroirs Exemple Autres widgets et conteneurs <?xml version="1.0" encoding="utf-8"?> <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent" > <SlidingDrawer android:id="@+id/tiroir" android:layout_width="match_parent" android:layout_height="match_parent" android:handle="@+id/poignee" android:content="@+id/contenu" > <ImageView android:id="@id/poignee" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/tray_handle_normal" /> <Button android:id="@id/contenu" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="ouvert!" /> </SlidingDrawer> </FrameLayout> La ressource affichée dans le ImageView doit être fournie L3 - Info Développement sur Android 76

Pour aller plus loin... Autres widgets et conteneurs Intégrer le navigateur «webkit» Le widget WebView permet d intégrer un navigateur web dans l activité Il faut modifier les permissions de sécurité en conséquence Il dispose d un grand nombre de fonctionnalités (JavaScript, navigation arrière/avant,... ) Il possible de charger des URLs mais également du code HTML par l appel à loaddata() L3 - Info Développement sur Android 77

Pour aller plus loin... Intégrer le navigateur «webkit» Exemple Autres widgets et conteneurs AndroidManifest.xml <uses-permission android:name="android.permission.internet" /> <?xml version="1.0" encoding="utf-8"?> <WebView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/navigateur" android:layout_width="match_parent" android:layout_height="match_parent" /> package com.univangers.l3info.projettest; import android.app.activity; import android.os.bundle; import android.webkit.webview; public class Debut extends Activity { public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.main); WebView ww=(webview)findviewbyid(r.id.navigateur); ww.loadurl("http://www.google.fr"); } } L3 - Info Développement sur Android 78

Pour aller plus loin... Menus et «pop-ups» Les menus Comme dans tout type d application, il est possible d ajouter des menus Il peuvent s ouvrir soit : Lors de l appui sur la touche menu (menu d options) Lors d un appui long sur un widget (menu contextuel) Ils peuvent apparaître en mode icône... Seuls quelques éléments sont visibles, le texte Plus peut apparaitre... ou en mode étendu Il se constituent/remplissent depuis le code Java L3 - Info Développement sur Android 80

Pour aller plus loin... Les menus Les menus d options Menus et «pop-ups» La méthode oncreateoptionsmenu() de l activité concernée doit être redéfinie Les items du menu sont rajoutés par l appel à méthode add() du menu Il prend en compte les paramètres suivants : Un identifiant de groupe (NONE normalement) Possibilité de créer des items exclusifs (radio) Un identifiant de choix pour identifier le choix lors du rappel La méthode onoptionsitemselected() effectue le rappel Un identifiant d ordre (NONE le plus souvent) Le libellé de l item Il est possible de rendre des options «checkable» par l appel à MenuItem#SetCheckable Il est possible de créer des sous-menus en appelant addsubmenu() L3 - Info Développement sur Android 81

Pour aller plus loin... Menus et «pop-ups» Les menus Les menus contextuels Les menus contextuels fonctionnent comme les menus d options La méthode registerforcontextmenu() associe un widget à un menu contextuel La méthode oncreatecontextmenu() doit être redéfinie pour construire le menu oncreatecontextmenu() est appelé à chaque affichage du menu contextuel getmenuinfo() est utilisé pour obtenir le widget qui a déclenché le menu L3 - Info Développement sur Android 82

Pour aller plus loin... Les menus Exemple Menus et «pop-ups» public class Debut extends ListActivity { public static final int MENU_ADD = Menu.FIRST+1; public static final int MENU_RESET = Menu.FIRST+2; @Override public void oncreate(bundle icicle) { super.oncreate(icicle); /* Initialisation de la liste d éléments */ } @Override public boolean oncreateoptionsmenu(menu menu) { menu.add(menu.none, MENU_ADD, Menu.NONE, "Ajouter").setIcon(R.drawable.ic_menu_add); menu.add(menu.none, MENU_RESET, Menu.NONE, "Réinitialiser").setIcon(R.drawable.ic_menu_refresh); return(super.oncreateoptionsmenu(menu)); } @Override public boolean onoptionsitemselected(menuitem item) { switch (item.getitemid()) { case MENU_ADD: return(true); case MENU_RESET: initadapter(); return(true); } return(super.onoptionsitemselected(item)); } L3 - Info Développement sur Android 83

Pour aller plus loin... Les menus Exemple Menus et «pop-ups» @Override public void oncreate(bundle icicle) { super.oncreate(icicle); /* Initialisation de la liste d éléments */ registerforcontextmenu(getlistview()); } @Override public void oncreatecontextmenu(contextmenu menu, View v, ContextMenu.ContextMenuInfo menuinfo) { menu.add(menu.none, MENU_CAP, Menu.NONE, "Capitaliser"); menu.add(menu.none, MENU_REMOVE, Menu.NONE, "Supprimer"); } @Override public boolean oncontextitemselected(menuitem item) { AdapterView.AdapterContextMenuInfo info= (AdapterView.AdapterContextMenuInfo)item.getMenuInfo(); ArrayAdapter<String> aa= (ArrayAdapter<String>)getListAdapter(); switch (item.getitemid()) { case MENU_CAP: String item=items.get(info.position);... return(true); case MENU_REMOVE: aa.remove(items.get(info.position)); return(true); } return(super.oncontextitemselected(item)); L3 - Info Développement sur Android 84

Pour aller plus loin... Menus et «pop-ups» Les «pop-ups» Les «toasts» et les «alertes»! Pour informer l utilisateur, il est nécessaire de lui afficher des messages Le «toast» est un message qui ne reste affiché que pendant un certain laps de temps Il ne modifie pas le focus de l activité Pas moyen de savoir si l utilisateur l a lu Un toast est émis en appelant la méthode statique maketext() de la classe Toast Les «alertes» sont déclenchées en instanciant une boîte de dialogue modale affichée à l écran Elle prend le focus L utilisateur doit valider (donner une réponse) pour la fermer Une alerte est créée par instanciation de la classe AlertDialog L3 - Info Développement sur Android 85

Pour aller plus loin... Les «pop-ups» Exemple Menus et «pop-ups» public class Debut extends Activity { @Override public void oncreate(bundle icicle) { super.oncreate(icicle); setcontentview(r.layout.main); Toast.makeText(Debut.this, "Ça va démarrer!", Toast.LENGTH_SHORT).show(); } } new AlertDialog.Builder(this).setTitle("Une boite!").setmessage("bla bla bla.").setcancelable(false).setpositivebutton("quitter", new DialogInterface.OnClickListener() { public void onclick(dialoginterface dialog,int id) { Debut.this.finish(); } }).setnegativebutton("rester", new DialogInterface.OnClickListener() { public void onclick(dialoginterface dialog,int id) { dialog.cancel(); } }).show(); L3 - Info Développement sur Android 86

Le système reste le seul maître à bord! Ça s en va et ça revient... Une gestion spécifique à un matériel aux ressources limités Sur un PC l OS 3 peut tuer des processus Toutefois, on considère qu une tâche ne peut se terminer de manière inopinée Sur un smartphone, les ressources et notamment la mémoire sont plus limitées Des activités peuvent être tuées pour permettre à d autres de s exécuter Certaines doivent mourir pour que d autres vivent Sur Android il ne faut pas supposer que l application ira jusqu à son terme! 3. Operating System L3 - Info Développement sur Android 90

Le système reste le seul maître à bord! Ça s en va et ça revient... États d une activité Une activité est toujours dans l un des quatre états suivants : Active : elle s execute au premier plan En pause : l activité est visible mais inacessible (une notification ou un message apparaît devant) Stoppée : elle est cachée par une autre activité Morte : elle n a pas été lancée ou a été tuée Android fournit des méthodes appelées lors de la transition d un état à un autre Elles sont implémentées dans la classe Activity et sont à redéfinir dans les sous-classes Certaines transitions font appel successivement à plusieurs de ces méthodes, la documentation doit être lue attentivement! L3 - Info Développement sur Android 91

Le système reste le seul maître à bord! Ça s en va et ça revient... États d une activité Cycle de vie Pour chaque méthode de transition redéfinie, il faut rappeler la méthode de la superclasse! OnCreate() Appelée : Lors du lancement de l activité (avec NULL comme paramètre) Lors du redémarrage de l activité (après un «kill»), avec un «Bundle» comme argument Également après une rotation L3 - Info Développement sur Android 92

Le système reste le seul maître à bord! Ça s en va et ça revient... États d une activité Cycle de vie OnDestroy() Libérations des ressources : Lors de l appel à finish() Lorsque qu elle est tuée OnStart(),OnRestart() et OnStop() onstart() est appelé lors du passage au premier plan onrestart() est appelé uniquement lorsque l activité a été stoppée et redémarre onstop() est appelé lorsque l activité va être stoppée L3 - Info Développement sur Android 93

Le système reste le seul maître à bord! Ça s en va et ça revient... États d une activité Cycle de vie OnResume() Est appelé juste avant que l activité passe au premier plan Lors de son lancement Lors de son retour après avoir été rendue inaccessible Après la fermeture d une notification ouverte par le système C est le bon endroit pour reconstruire l interface! L3 - Info Développement sur Android 94

Le système reste le seul maître à bord! Ça s en va et ça revient... États d une activité Cycle de vie OnPause() Est appelé juste avant que l activité quitte le premier plan Elle permet de libérer les ressources exclusives (threads, appareil photo) et ce qui a été fait dans OnResume() Lorsqu une activité est en pause, Android peut la tuer à tout moment L3 - Info Développement sur Android 95

Le système reste le seul maître à bord! Ça s en va et ça revient... États d une activité Sauvegarde de l état d une instance Pour rendre transparente toute cette gestion, Android permet de sauvegarder et restaurer l état d une instance La méthode onsaveinstancestate() fournit un Bundle dans lequel une activité peut sauver des données onrestoreinstancestate() et oncreate() permettent de récupérer le Bundle réalisé onsaveinstancestate() est appelé régulièrement par Android : Il faut donc que son exécution soit rapide et efficace onsaveinstancestate() possède une version prédéfinie basée sur les ID des widgets Il est possible de la personnalisée complètement L3 - Info Développement sur Android 96

Le système reste le seul maître à bord! La rotation des écrans Fonctionnement de la rotation La majorité des smartphones peuvent passer du mode portrait au mode paysage Lors de l ouverture d un clavier physique Lors de la détection d un mouvement défini (grâce à des accéléromètres) Lors d un changement d orientation, Android supprime et recrée toutes les activités Il est possible d adapter les activités pour bien réagir face à la rotation L3 - Info Développement sur Android 98

Le système reste le seul maître à bord! La rotation des écrans Mise en œuvre de la rotation Par défaut, il n y a rien à faire, l activité gère elle même la rotation L émulateur peut effectuer une rotation en pressant la combinaison «Ctrl+F11» Un layout différent pour le mode paysage peut être défini en utilisant : res/layout/ et res/layout-land/ Il est possible de bloquer la rotation d une activité en modifiant le manifest : <activity android:name="debut" android:label="@string/app_name" android:screenorientation="portrait" > L3 - Info Développement sur Android 99

Le système reste le seul maître à bord! Contrôler la rotation La rotation des écrans Lors d une rotation, l activité est détruite puis recrée La méthode onsaveinstancestate() est appelée avant le retournement L objet Bundle permet de stocker des paramètres supplémentaires Les valeurs sont restorées depuis onrestoreinstancestate() ou oncreate() L3 - Info Développement sur Android 100

Le système reste le seul maître à bord! Contrôler la rotation Exemple La rotation des écrans <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"... > <LinearLayout...> <TextView android:id="@+id/labelnom" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="nom :" /> <EditText android:id="@+id/txtnom" android:layout_width="match_parent" android:layout_height="wrap_content" /> </LinearLayout> <LinearLayout... > <Button android:id="@+id/btnsave" android:text="sauve" android:onclick="sauvetxt" android:layout_width="wrap_content" android:layout_height="wrap_content" /> <Button android:id="@+id/btnshow" android:text="montre" android:onclick="montretxt" android:layout_width="wrap_content" android:layout_height="wrap_content" /> </LinearLayout> </LinearLayout> L3 - Info Développement sur Android 101

Le système reste le seul maître à bord! Contrôler la rotation Exemple : code Java La rotation des écrans public class Debut extends Activity { String strnom=""; @Override public void oncreate(bundle state) { super.oncreate(state); setcontentview(r.layout.main); if (state!= null) strnom = state.getstring("savedstrnom"); } public void sauvetxt(view v) { TextView tv=(textview)findviewbyid(r.id.txtnom); strnom=tv.gettext().tostring(); } public void montretxt(view v) { Toast.makeText(Debut.this, strnom, Toast.LENGTH_SHORT).show(); } @Override public void onsaveinstancestate(bundle outstate) { super.onsaveinstancestate(outstate); outstate.putstring("savedstrnom", strnom); } } L3 - Info Développement sur Android 102

Le système reste le seul maître à bord! Gérer totalement la rotation Une mauvaise idée... La rotation des écrans Il est possible de gérer totalement la rotation en : Utilisant l attribut android:configchanges de l activité dans le manifest Redéfinissant la méthode onconfigurationchanged() de la classe de l activité C est déconseillé par Google : Risque d oublier des ressources (chaîne, disposition,... ) L approche gérée par Android peut ne pas être appropriée dans certains cas : Fluidité lors d un jeu en réseau Lecture vidéo d un flux perte du tampon L3 - Info Développement sur Android 103

Utiliser d autres activités Introduction La philosophie d Android demande au développeur de découper son application en activités autonomes Il est alors possible de lancer une activité (ou sous-activité) depuis une autre activité : Soit en connaissant le nom de l activité à lancer Soit par le biais d une URI résolue par Android Le cas le plus courant est l ouverture d un fichier attaché par une autre activité Question? L activité initiale doit-elle être informée de la fin de l activité fille? Si oui, l activité fille est lancée comme sous-activité Si non, l activité est lancée comme «pair» de l activité initiale L3 - Info Développement sur Android 105

Utiliser d autres activités Les intentions «intents» d Android Les intents sont des messages qui permettent à des composants de demander une fonctionnalité spécifique Ils peuvent aussi être utilisés pour informer le système d un nouvel évènement Les intents sont envoyés à Android qui se chargera de trouver un récepteur adéquat Les intents peuvent être de deux catégories : Explicites : le composant à lancer est donné explicitement Implicites : le composant à lancer n est pas connu, une URI peut être construite permettant à Android de chercher parmi les composants enregistrés, le plus adéquat Il est possible de créer des récepteurs d intention en modifiant le fichier manifest de son activité L3 - Info Développement sur Android 106

Utiliser d autres activités Les intentions «intents» d Android Exemple avec startactivity startactivity() lance une intention depuis une URI ou une classe connue L3 - Info Développement sur Android 107

Utiliser d autres activités Les intentions «intents» d Android Exemple avec startactivity : ressource XML <?xml version="1.0" encoding="utf-8"?> <TableLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="wrap_content" android:stretchcolumns="1" > <TableRow> <TextView android:text="url :" android:layout_width="wrap_content" android:layout_height="wrap_content" /> <EditText android:id="@+id/url" android:text="http://" android:inputtype="texturi" android:imeoptions="actiongo" android:layout_width="fill_parent" android:layout_height="wrap_content" /> <Button android:id="@+id/btngo" android:text="go" android:onclick="gourl" android:layout_width="wrap_content" android:layout_height="wrap_content" /> </TableRow> </TableLayout> L3 - Info Développement sur Android 108

Utiliser d autres activités Les intentions «intents» d Android Exemple avec startactivity : le code Java public class Debut extends Activity { private EditText txturl; @Override public void oncreate(bundle state) { super.oncreate(state); setcontentview(r.layout.main); txturl=(edittext)findviewbyid(r.id.url); // Pour connecter le bouton Go txturl.setonkeylistener(new OnKeyListener() { public boolean onkey(view view, int keycode, KeyEvent event) { if (keycode == KeyEvent.KEYCODE_ENTER) { gourl(view); return true; } else { return false; } } }); } public void gourl(view v) { Toast.makeText(Debut.this, txturl.gettext().tostring(), Toast.LENGTH_SHORT).show(); Uri uri=uri.parse(txturl.gettext().tostring()); startactivity(new Intent(Intent.ACTION_VIEW, uri)); } }; L3 - Info Développement sur Android 109

Utiliser d autres activités Le plus important reste à faire : la pratique! L3 - Info Développement sur Android 110