Présentation des différents composants d'une application Android - PDF
Document Details
Uploaded by GoodlyHarpGuitar
Filière Génie Informatique – EMI
Tags
Summary
This document provides an overview of Android application components. It covers topics like activities, the manifest file, and other elements of Android development.
Full Transcript
Présentation des différents composants d'une application Android Fichier de configuration Android (manifest) Présentation Une application Android est un assemblage de composants liées grâce à un fichier de configuration Décrit entre autres : ...
Présentation des différents composants d'une application Android Fichier de configuration Android (manifest) Présentation Une application Android est un assemblage de composants liées grâce à un fichier de configuration Décrit entre autres : Le point d'entrée de l'application : quel code doit être exécuté au démarrage de l'application Quels composants constituent ce programme : les activités, les services,... Les permissions nécessaires à l’exécution du programme Comment ? Fichier XML : AndroidManifest.xml Fichier de configuration Android Exemple......... Composants d'une application Android Les composants peuvent être classés en éléments applicatifs et éléments d’interaction Eléments applicatifs Activité Service Fournisseur de contenu Gadget (widget) Eléments d’interaction Objet Intent Récepteur d'Intents Notification Composants d'une application Android Activités de l'application Application Activité au premier plan Ressources Vue1 Vue2 Vue3 Vue n Manifeste : fichier de configuration Activité Présentation Elle correspond à la partie présentation de l'application : correspond à un écran Représente le bloc de base d'une application Fonctionne par le biais de vues qui affichent des interfaces graphiques et répondent aux actions utilisateur Elle est composée d'une hiérarchie de vues contenant elles-mêmes d'autres vues Un formulaire d'ajout de contacts ou encore un plan Google Maps sur le lequel on peut ajouter de l'information Une application comportant plusieurs écrans, possédera donc autant d'activités Activité Utilisation Une activité est composée de deux volets : Sa logique métier et la gestion de son cycle de vie Implémentés en Java dans une classe héritant de Activity Son interface utilisateur Deux façons alternatives pour sa définition: Programmative : dans le code de l'activité Déclarative : dans un fichier XML Activité Logique métier d'une activité : Squelette minimal import android.app.Activity; import android.os.Bundle; public class ActiviteBasic extends Activity { //méthode OnCreate appelée à la création de l'activité public void onCreate(Bundle etatSauvegarde){ super.onCreate(etatSauvegarde); } } Activité La balise déclare une activité Les paramètres généralement utilisés sont : name qui désigne la classe de l'activité label qui désigne le nom sous lequel elle apparaîtra sur le terminal icon qui désigne l'icône à afficher sur le terminal Structure Activité Cycle de vie d'une activité Les états principaux d'une activité sont les suivants : Active (active) Activité visible qui détient le focus utilisateur et attend les entrées utilisateur Appel à la méthode onResume() Suspendue (Paused) Activité au moins en partie visible à l'écran mais qui ne détient pas le focus Appel à la méthode onPause() pour entrer dans cet état Arrêté (stopped) Activité non visible Appel de la méthode onStop() Activité Cycle de vie d'une activité public class Main extends Activity { public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.acceuil); } protected void onDestroy() { super.onDestroy(); } protected void onPause() { super.onPause(); } protected void onResume() { super.onResume(); } protected void onStart() { super.onStart(); } protected void onStop() { super.onStop(); } } Activité Cycle de vie d'une activité Les interfaces d'applications :Les Vues Présentation Sont les briques de construction de l'interface graphique d'une activité Android Utilisation Les vues sont soient prédéfinies par la plateforme -textes, boutons, … ou créées comme des éléments personnalisés Chaque écran Android contient un arbre d'éléments de type View Les vues peuvent être disposées dans une activité (objet Activity) et donc à l'écran soit par une description XML, soit par un morceau de code Java Les interfaces d'applications Android Tous les composants graphiques (boutons, images, cases à cocher, etc.) d'Android héritent de la classe View Android permet de regrouper plusieurs vues dans une structure arborescente à l'aide de la classe ViewGroup - Cette structure peut regrouper d'autres éléments de la classe ViewGroup → un arborescence L'utilisation et le positionnement des vues dans une activité se fera via des gabarits de vues Les interfaces d'applications Android Positionnement des vues avec les gabarits Un gabarit, layout ou mise en page, est une extension de la classe ViewGroup Est un conteneur qui aide à positionner les objets (vues, gabarits, etc.) Les gabarits peuvent être imbriqués les uns dans les autres Quelques types de gabarits LinearLayout Permet d'aligner de gauche à droite ou de haut en bas les éléments qui y seront incorporés En modifiant la propriété ORIENTATION, il est possible de modifier le sens de d'affichage des éléments Horizontal : affichage de gauche à droite Vertical : affichage de haut en bas Les interfaces d'applications Android Quelques types de gabarits RelativeLayout Ses enfants sont positionnés les uns par rapport aux autres Le premier enfant servant de référence aux autres TableLayout Permet de positionner les vues en lignes et colonnes à l'instar d'un tableau Les interfaces d'applications Android Les propriétés communes à tous les types de gabarit layout_weight : comportement pour le remplissage en largeur layout_height : comportement pour le remplissage en hauteur Ces propriétés peuvent être exprimées en : Une unité de mesure spécifiant une taille précise ou relative Taille précise : le même nombre de pixels quelle que soit la taille de l'écran Taille relative en DIP ou en SP: permettent un ajustement automatique des éléments sont à privilégiées Elles permettent de s'adapter plus aisément à différentes tailles d'écran Rendent les applications plus portables Les interfaces d'applications Android Les propriétés communes à tous les types de gabarit layout_weight layout_height Ces propriétés peuvent être exprimées en : Une unité de mesures spécifiant une taille précise ou relative Valeurs prédéfinies Les valeurs prédéfinies fill_parent spécifie que le gabarit doit prendre toute la place disponible sur la largeur/hauteur wrap_content spécifie que le gabarit ne prendra que la place qui lui est nécessaire en largeur/hauteur Création d'une interface utilisateur Deux possibilités pour créer une interface Directement dans le code : instancier les vues dans le code La création en deux étapes en séparant la présentation de la logique fonctionnelle de l'application Définition de l'interface utilisateur (gabarit, etc.) de façon déclarative dans un fichier XML Définition de la logique utilisateur (comportement de l'interface) dans une classe d'activité Définition de l'interface en XML Les fichiers de définition d'interface en XML sont enregistrés dans le dossier res/layout du projet Chaque fichier XML définissant une interface graphique est associé à un identifiant unique généré automatiquement qui peut être référencé dans le code de l'application Exemple : R.layout.monLayout Association entre activité et interface Une interface est affichée par l'intermédiaire d'une activité Le chargement du contenu de l'interface s'effectue à l'instanciation de l'activité Redéfinition de la méthode OnCreate() de l'activité pour y spécifier la définition de l'interface à afficher via la méthode Affichage de l'interface par la méthode setContentView() Prend en paramètre un identifiant qui spécifie quelle ressource de type interface doit être chargée et affichée Association entre activité et interface Spécifier une vue pour l'activité Import android.app.Activity; import android.os.Bundle; public class Main extends Activity { @override public void onCreate(Bundle saveInstanceState){ super.onCreate(saveInstanceState); setContentView(R.layout.main); } } Création une interface dans le code source (sans définition XML) Exemple import android.app.Activity; import android.os.Bundle; import android.widget.TextView; public class Main extends Activity { @Override public void onCreate(Bundle saveInstanceState) { super.onCreate(saveInstanceState); TextView monTextView = new TextView(this); setContentView(monTextView); monTextView.setText(" Notre premier cours Android"); } } Utilisation des gabarits Pour intégrer plus d'une vue à une activité : réunir tous ces vues dans un gabarit de vues public class Main extends Activity { Détail technique : la @Override méthode public void onCreate(Bundle saveInstanceState) { SetContentView() super.onCreate(saveInstanceState); n'accepte qu'un seul LinearLayout monLinearLayout = new LinearLayout(this) objet graphique (une monLinearLayout.setOrientation(LinearLayout.VERTICAL); vue) comme paramètre TextView monTextView1 = new TextView(this); Directement dans le monTextView1.setText(" Notre premier cours Android"); TextView monTextView2 = new TextView(this); code monTextView2.setText(" vivement le premier TP"); monLinearLayout.addView(monTextView1); monLinearLayout.addView(monTextView2); setContentView(monLinearLayout); }} Utilisation des gabarits Pour intégrer plus d'une vue à une activité : réunir tous programatique : fichier XML Gestion des événements Sous Android, toutes les actions de l'utilisateur sont perçues comme un événement Les événements sont interceptés par les éléments d'une interface en utilisant des écouteurs (listeners) Association entre un événement et une méthode à appeler en cas d'apparition de cet événement Exemple : pour un événement OnClick, la méthode associée est OnClick() Un objet graphique Méthode associée O à l'événement E Événement E Gestion des événements Exemple Insertion d'un bouton dans l'interface Gestion des événements Exemple création d'un écouteur sur un bouton import android.app.Activity; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.Toast; public class Main extends Activity { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); ((Button) findViewById(R.id.monBouton)). setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { Toast.makeText(Main.this, "Bouton cliqué !", Toast.LENGTH_LONG).show(); } }); } } Les ressources Les ressources Présentation Sont des fichiers externes ne contenant pas d'instructions qui sont utilisés par le code Les fichiers images JPEG et PNG, les fichiers XML... Utilisation L'externalisation des ressources permet une meilleure gestion de ces ressources ainsi qu'une maintenance plus aisée Les ressources de l'application sont déposées dans le répertoire res du projet Android crée une classe nommée R utilisée pour référer aux ressources dans le code Toutes les ressources sont placées, converties ou non, dans un fichier de type APK qui constituera le programme distribuable de l'application Les ressources Type de ressources Répertoire associé Description Valeurs simples res/values définitions en XML de valeurs : chaînes, tableaux, valeurs numériques Drawables res/drawable Des ressources images Layouts res/layout description en XML des interfaces Animations res/anim description en XML d’animations Ressources XML res/xml Fichier XML qui peuvent être lus et convertis à l'exécution par la méthode ressources.getXML Ressources brutes res/raw tous les autres types de ressources : fichiers texte, vidéo, son.Fichiers à ajouter sous leurs formats d'origine. Les ressources Création de ressources Les ressources de type valeur (entiers, booléens, chaînes de caractères, etc. et des tableaux) peuvent être décrites dans des fichiers xml : #AA7B03 567 34100 … 30000 mon premier exemple Android Mercure... Venus true 55px Les ressources Utilisation des ressources Les ressources peuvent être utilisées dans les fichiers XML ou dans le code java Utilisation des ressources dans le code Java Les ressources peuvent être utilisées via leurs identifiants :utilisation de la classe statique R automatiquement générée android.R.type_ressource.nom_ressource Les ressources Utilisation des ressources public final class R { Utilisation de la ressource dans le code Java public static final class string { public static final int invitation = 0x7f040001; public static final int texte_titre_ecran = 0x7f040002; }; Android.R.string.invitation public static final class layout { public static final int ecrain_de_demarrage= 0x7f030001; public static final int ecran_principal= 0x7f030002; }; public static final class drawable { public static final int image_android = 0x7f020000; }; }; Les ressources Utilisation des ressources Les ressources peuvent être utilisées dans les fichiers XML ou dans le code java Utilisation des ressources dans le code Java Les ressources peuvent être utilisées via leurs identifiants :utilisation de la classe statique R automatiquement générée Les ressources peuvent être utilisées en récupérant l'instance de la ressource en utilisant la classe Resources Resources res = getResources(); String hw = res.getString(R.string.hello); ----- XXX o = res.getXXX(id); Une méthode spécifique pour les objets graphiques permet de les récupérer à partir de leur id: TextView texte = (TextView) findViewById(R.id.le_texte); texte.setText("Here we go !"); Les ressources Utilisation de ressources Référencement d’une ressource dans un fichier XML On référence une ressource dans un fichier XML par "@[paquetage:]type/identificateur" Exemple @string/nom_de_mon_application fait référence à une chaîne décrite dans un fichier XML placé dans le répertoire res/values mon premier exemple Android Les ressources Utilisation des ressources Ressources référencées par d'autres ressources Les ressources définies peuvent être utilisées comme valeurs d'attributs dans d'autres ressources sous forme XML d'une autre ressource Autres composants Service Est un composant qui fonctionne en tâche de fond, de manière invisible Ses principales utilisations sont la mise à jour de sources de données ainsi que d'activités visibles et le déclenchement de notifications Gadget Est un composant graphique qui s'installe sur le bureau Android Exemples : Le calendrier qui affiche de l'information Fournisseur de contenu Permet de gérer et de partager des informations Un même fournisseur permet d'accéder à des données au sein d'une application et entre applications Communication entre composants Composants d'interactions Permettent l'interaction : Entre les différents composants, entre les applications installées sur l'appareil, avec l'utilisateur Les composants L'objet Intent Permet à une application de demander l'exécution d'action Récepteur d'Intents Permet à une application d'être à l'écoute des objets Intent qui lui sont destinés Notification Signale une information à l'utilisateur sans interrompre ses actions en cours Intent-Filter Objets Intent La communication entre les composants d'applications Android se fait via l'expression d'intention Une intention d'action est une description abstraite d'une opération à effectuer Exprimer ce que l'opération demandée doit faire Les intentions (souhaits) peuvent être envoyé aux composants d'une même application (activité, service, etc.) ou aux autres applications Les intentions sont des objets instances de la classe Intent Objets Intent Composants applicatifs Description de l'opération que le composant cherche à exécuter ou applications Composant Intent applicatif Principe de fonctionnement Les objets Intent ont trois utilisations possibles Démarrer une activité au sein de l'application courante Utilisation Navigation entre écrans d'une interface graphique Démarrage explicite d'une activité : spécifier l'activité cible Solliciter d'autres applications Transmission de l'intention au système Le système se charge de trouver l'application ou le composant le plus approprié Le système démarre l'application ou le composant approprié en lui transmettant l'objet Intent en question Envoyer des informations Exemple : batterie défaillante Naviguer entre écran au sein d'une même application Une application = un ou plusieurs écrans Enchaînement des écrans en fonction du déroulement de l'application Un écran = activité définissant son interface et sa logique Un Intent permet d'assurer cet enchaînement en démarrant ces activités, une à la fois De manière générale chaque composant d'une application nécessite l'emploi d'un Intent pour être démarré Naviguer entre écrans Démarrer une activité sans attendre de retour Utilisation de la méthode starActivity() Avec comme paramètre une instance de la classe Intent spécifir le type de classe de l'activité à exécuter Intent intent = new Intent (this, ActiviteDemarrer.class); startActivity(intent); Le constructeur de la classe Intent prend les paramètres suivants : Context PackageContext : le contexte à partir duquel l'Intent est créé. Fait référence la plupart du temps à l'activité en cours → utilisation de this Class cls : un type de classe Java héritant de la classe Activity → l'activité enfant à démarrer Naviguer entre écrans Démarrer une activité et obtenir un retour Utilisation de la méthode startActivityForResult() … private static final int CODE_MON_ACTIVITE = 1; … Intent intent = new Intent(this, ClassSousActivite.class); //représente l'identifiant de la requête qui sera utilisé pour //identifier l'activité renvoyant la valeur de retour startActivityForResult(intent, CODE_MON_ACTIVITE); Naviguer entre écrans Démarrer une activité et obtenir un retour Utilisation de la méthode startActivityForResult() Renvoyer une valeur de retour Utilisation de la méthode setResult() de la classe Activity A comme paramètre le code de retour Valeurs par défaut : RESULT-OK, RESULT_CANCELED… Exemple : retour d'une activité enfant représentant un formulaire avec deux boutons : OUI, NON @Override public void onClick(View v) { switch(v.getId()){ case R.id.button1: setResult(RESULT_OK); finish(); break; case R.id.button2: setResult(RESULT_CANCELED); finish(); break; } } Naviguer entre écrans Démarrer une activité et obtenir un retour Utilisation de la méthode startActivityForResult() Renvoyer une valeur de retour Récupérer la valeur de retour Utilisation de la méthode OnActivityResult() de l'activité parent Ses paramètres Int requestCode : valeur identifiant quelle activité a appelé la méthode ; c'est la même valeur utilisée pour le paramètre de StartActivityForResult Int resultCode : valeur de retour envoyée par l'activité enfant pour signaler son état à la fin de la transaction Intent data : l'objet intent pemettant d'échanger des données Naviguer entre écrans Démarrer une activité et obtenir un retour Récupérer la valeur de retour @Override protected void onActivityResult(int requestCode, int resultCode, Intent data){ //le code de requête est utilisé pour identifier l'activité enfant switch (requestCode) { case CODE_MON_ACTIVITE: switch(resultCode){ case RESULT_OK: Toast.makeText(this, "Action validée", Toast.LENGTH_LONG).show(); return; case RESULT_CANCELED: Toast.makeText(this, "Action annulée", Toast.LENGTH_LONG).show(); return; default: //des instructions à faire return; } default: //instructions à faire return; }} Solliciter d'autres applications Utilisation d'Intent implicite Le destinataire de l'Intent n'est pas explicitement spécifié Le système doit trouver le destinataire approprié en se basant sur : Les filtres Les informations suivantes de l'Intent : Le type d'action ACTION_DIAL, ACTION_EDIT, ACTION_CALL, … Les données spécifiées dans l'Intent URI (Uniform Ressource Identifier) Son format dépend du type de l'action Format général : schéma://hote:port/chemin Exemples de schéma : tel, www, market le type de contenu MIME Action ACTION_ANSWER Solliciter d'autres applications Définition Prendre en charge un appel entrant. ACTION_CALL Appeler un numéro de téléphone. Cette action lance une activité affichant l’interface pour composer un numéro puis appelle le numéro contenu dans l’URI spécifiée en paramètre. ACTION_DELETE Démarrer une activité permettant de supprimer une donnée identifiée par l’URI spécifiée en paramètre. ACTION_DIAL Afficher l’interface de composition des numéros. Celle-ci peut être pré-remplie par les données contenues dans l’URI spécifiée en paramètre. ACTION_EDIT Éditer une donnée. ACTION_SEARCH Démarrer une activité de recherche. L’expression de recherche de la pourra être spécifier dans la valeur du paramètre SearchManager.QUERY envoyé en extra de l’action. ACTION_SEND Envoyer des données texte ou binaire par courriel ou SMS. Les paramètres dépendront du type d’envoi. ACTION_SENDTO Lancer une activité capable d’envoyer un message au contact défini par l’URI spécifiée en paramètre. ACTION_VIEW Démarrer une action permettant de visualiser l’élément identifié par l’URI spécifiée en paramètre. C’est l’action la plus commune. Par défaut les adresses commençant par http: lanceront un navigateur web, celles commençant par tel: lanceront l’interface de composation de numéro et celles débutant par geo: lanceront Google Map. ACTION_WEB_SEARCH Effectuer une recherche sur Internet avec l’URI spécifiée en paramètre comme requête. Solliciter d'autres applications Utilisation d'Intent implicite Exemple Lancer une action permettant de composer un numéro de téléphone Type d'action de l'Intent: ACTION_DIAL URI : le numéro à appeler Uri uri = Uri.parse("tel:0612345678"); Intent intent = new Intent(Intent.ACTION_DIAL, uri); startActivity(intent) Spécifier les permissions liées aux actions Pour certaines actions, il est nécessaire de spécifier dans le fichier de configuration les permissions nécessaires Appel téléphonique, accès réseau, etc. Exemple