Introduction Au Développement D'application Android: Amosse EDOUARD, Doctorant
Introduction Au Développement D'application Android: Amosse EDOUARD, Doctorant
Introduction Au Développement D'application Android: Amosse EDOUARD, Doctorant
d’Application Android
Amosse EDOUARD,
Doctorant
2 OBJECTIF DU COURS
Introduction à Android
3 Référence
L’art du développement Android par Mark L. Murphy
Professional NFC application development for android by Vedat
Coskun
Android developer : http://developer.android.com/index.html
Introduction à Android
4 Pré requis
Introduction à Android
5 Enjeux du développement mobile
Introduction à Android
Introduction & Définition
Introduction à Android 6
Introduction / Définition
7
Conçu à la base par une startup (Android) rachetée par Google en 2005
Introduction à Android
Versions de l’OS
8
Introduction à Android
9 Plateforme Android
Le système d’exploitation Android est basé sur Linux. Au plus bas niveau de ce
système se trouve un noyau Linux destiné à la gestion du matériel comme :
Introduction à Android
10
Plateforme / Architecture
Introduction à Android
11 Android pour tous
Développeurs
Pas besoin de licence
Simple et intuitifs
Modulables
Constructeurs
Tous les constructeurs peuvent utiliser Android
Un ensemble de services sont déjà disponibles dans le core
API disponible pour les accès de bas niveau
Introduction à Android
12 Android et les langages de
programmation
Android n’est pas un langage de programmation
Introduction à Android
13 Android & Java
Introduction à Android
14 Android & C/C++
Introduction à Android
15 Android vs Développement
Hybride
Android supporte le développement hybride
Titanium
Phonegap
Neomad
Introduction à Android
16 Pour ce cours….
Framework et langage
Android SDK
Java
XML
Outils
Eclipse (Intellij ou Netbeans)
Le plugin ADT
Introduction à Android
17 Production de logiciel
Introduction à Android
http://developer.android.com/tools/building/index.html
18 Android SDK
Disponible en téléchargement sur : developper.android.com/sdk
Propose le SDKManager qui
¨Permet de télécharger les plateformes et outils :
– Android versions xx
– Google API versions xx
– Outils (tools et platform-tools)
Introduction à Android
19 Outils du SDK
adb Accessibles à partir d’une ligne de commande (fenêtre DOS) adb
permet la connexion au terminal (smartphone ou simulateur) pour :
Transférer des fichiers (push / pull)
Installer une application (install)
Paramétrer le réseau (forward)
dx Transforme le bytecode java en code Dalvik
apkbuilder Compiler les sources d’une application Android pour
constituer une archieve (.apk) directement installable sous un terminal
Android
DDMS / Monitor Monitoring sur les activités du terminale
Introduction à Android
20 Structure d’une application
Nom de l’application
Fichier de configuration de
l’application
Référence : http://developer.android.com/tools/projects/index.html
Introduction à Android
21 Composantes d’une application
Activité (android.app.Activity ) Programme qui gère une
interface graphique
Service (android.app.Service) Programme qui fonctionne en
tâche de fond sans interface
Fournisseur de contenu (android.content.ContentProvider)
Partage d’informations entre applications
Intentions : Communication inter et intra-application
Ecouteur d’intention (android.content.BroadcastReceiver)
Permet à une application de récupérer des informations générales
(réception d’un SMS, batterie faible, …)
Widgets : Ensemble de composantes visuelles d’une application
Introduction à Android
22 Type d’applications Android
Introduction à Android
23
Android Manifest
<?xml version="1.0" encoding="utf-8"?>
Définit le nom de package de
<manifest
l’application; xmlns:android="http://schemas.android.co
m/apk/res/android"
Décrit les composantes de package="ht.solutions.android.whereami"
android:versionCode="1"
l’application: activités, services, android:versionName="1.0">
fournisseurs de contenus…., il <uses-permission
nomme les classes implémentant android:name="android.permission.ACCESS_
FINE_LOCATION"/>
chacun de ces composants et
<uses-permission
propage leur capacité sur le android:name="android.permission.INTERNE
système; T"/>
<application
Détermine quel processus répond à android:label="@string/app_name"
android:icon="@drawable/ic_launcher">
une action donnée; <activity android:name="Home"
android:label="@string/app_name">
Déclare les permissions de <intent-filter> <action
l’application; android:name="android.intent.action.MAIN
" />
Déclare également les permissions <category
android:name="android.intent.category.LA
que doivent avoir d’autres UNCHER" /> </intent-filter> </activity>
applications qui veulent interagir </application>
avec l’application qu’elle décrit; </manifest>
Introduction à Android
24 Editer le manifeste
Introduction à Android
25 Activité (Activity)
Gère les interfaces présentés à l’utilisateur. Dans un modèle MVC il
joue le rôle de contrôleur
Hérite (toujours) de la classe Activity d’Android
Doit être déclarée dans le Manifest pour être visible par le système
Ne peut être instanciée directement, cette tache est effectuée par le
système
Introduction à Android
26 Activité /cycle de vie
Introduction à Android
27
Activité / Création
public class ExampleActivity extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// The activity is being created.
}
@Override
protected void onStart() {
super.onStart();
// The activity is about to become visible.
}
@Override
protected void onResume() {
super.onResume();
// The activity has become visible (it is now "resumed").
}
@Override
protected void onPause() {
super.onPause();
// Another activity is taking focus (this activity is about to be
"paused").
}
Introduction à Android
28 Exercices
Introduction à Android
29 Contexte (Context)
Interface fournissant des informations globales sur l’environnement de
l’application:
C’est une classe abstraite implémentée par le système Android
Il permet d’accéder aux principales ressources de l’application
Obtenir le contexte courant d’une application
Context c = getApplicationContext(): Contexte global de l’application
Context c = Activity.this, getContext(): Contexte d’une activité ou un
service
Introduction à Android
30 Les Intentions (Intent)
Description abstraite d’une action à exécuter:
Action : Action à exécuter
Data : Données sur lesquelles l’action va opérer
Exemple : Action_DIAL tel:0641xxxx
Autres attributs :
Category : Précise la catégorie de l’activité demandée
Type: Préciser le type de contenus des données de l’intention
Extras : Informations additionnelles envoyées à l’action (envoie d’un
email, par exemple)
Introduction à Android
31 Résolution d’intention
Il existe deux principaux types d’intentions :
Explicite : Spécifie les composants qui précisent la classe exacte qui
doit être exécutée (setComponant (nom) ou setClass(context, class))
Implicite : Ne spécifie pas le composant mais fournit assez
d’informations permettant au système de determiner les composants
nécessaires correspondant à cette action.
Introduction à Android
32 Méthodes de la classe Intent
Construction Paramètres
– Intent(String) : avec – putExtra(nom, valeur) ajoute
action un paramètre associé à un nom
– Intent(String, Uri) :avec – getxxxExtra(nom) renvoie le
action et Uri paramètres correspondant au
Ajout de catégorie nom (xxx dépend du
– setDataAndType(Uri,
String) définit l’Uri et le
type mime des données
Introduction à Android
33 Quelques valeurs prédéfinies
Actions
– android.intent.action.CALL appel téléphonique
– android.intent.action.EDIT affichage de données pour édition par
l’utilisateur
– android.intent.action.MAIN activité principale d’une application
– android.intent.action.VIEW affichage de données
– android.intent.action.WEB_SEARCH recherche sur le WEB
Catégories
– android.intent.category.DEFAULT activité pouvant être lancée
explicitement
– android.intent.category.BROWSABLE peut afficher une information
désignée par un lien
– android.intent.category.LAUNCHER activité proposée au lancement par
Android
– android.intent.category.TAB activité associée dans un onglet d’interface
(TabHost)
Introduction à Android
34 Démarrer une activité
Lancer explicitement une activité
Intent demarre = new Intent(context,
NomDeLaClasseDeLActiviteALancer.class);
startActivity(demarre);
Introduction à Android
35 Démarrer une activité
La classe Intent permet de passer des paramètres à l’activité appelée et d’en
récupérer les valeurs en retour
Introduction à Android
36 Activités / Paramètres (Bundle)
L’activité lancée récupère l’objet de classe Bundle contenant les paramètres
par :
Bundle params = getIntent().getExtras()
Exemple :
String myId = getIntent().getStringExtra(« id»);
Introduction à Android
37 Ressources (Resource)
Une application Android n’est pas seulement fait de codes mais aussi de
ressources statiques (images, sons, text statique,….)
Tout projet Android a un dossier de ressources (res/) contenant les
ressources du projet (bitmap, xml,…)
/res/drawable images (R.drawable.nom_de_la_ressources)
/res/layout Design des vues (R.layout.nom_de_la_vue)
/res/values/strings Chaînes de caractères, tableaux, valeurs numériques …
(R.string.nom_chaine, R.array.nom)
/res/anim description d’animations (R.anim.nom_animation_)
/res/menus Menus pour l’application (R.menu.nom_menu)
/res/values/color Code de couleurs (R.color.nom_couleur)
…
Introduction à Android
38 Ressources & valeurs
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="app_name">Mon application</string>
<string name="server_url">http://mon.serveur.com</string>
<integer-array name=“codes_postaux“>
<item>64100</item>
<item>33000</item>
</integer-array>
<string-array name= “planetes“>
<item>Mercure</item>
<item>Venus</item>
</string-array>
<dimen name “taille“>55px</dimen>
</resources>
Introduction à Android
39 Référencer les ressources
L’ensemble ressources sont modélisés par la classe « R.java » et les sous
dossiers par des classes internes à R
Chaque ressource est un attribut de la classe représentant le sous dossier
dans lequel il est déclaré
R.layout.accueil
Introduction à Android
40 Référencer les ressources
Référencement d’une ressource dans une autre ressource. La forme générale
est : "@type/identificateur"
<TextView
android:id="@+id/lblUsername"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_weight="0.00"
android:text="@string/lblUsername"
android:textColor="@android:color/holo_blue_dark"
android:textAppearance="?android:attr/textAppearanceMedium"
/>
Introduction à Android
41 Référencer les ressources
Dans le code (java), on obtient une instance de cette classe par getResources()
Principales méthodes de la classe Resources (le paramètre est un identifiant défini dans R de
la forme R.type.nom) :
boolean getBoolean(int)
int getInteger(int)
int[] getArray(int)
String getString(int)
String[] getStringArray(int)
int getColor(int)
float getDimension(int)
Drawable getDrawable(int)
Exemple : String titre = context.getResources().getString(R.string.ma_chaine);
Mais dans une activité on peut faire plus simplement :
String titre = getString(R.string.ma_chaine);
Introduction à Android
42 Référencer les ressources
Accéder aux vues : getResources().getLayout(R.layout.nom_layout);
Accéder aux valeurs :
String chaine = getResources().getString (R.string.nom_string);
String[] tableau= getResources(). getStringArray(R.string.nom_array);
Accéder aux images :
Drawable monImage = getResources().getDrawable(R.drawable.nom_image)
Introduction à Android
43 Interfaces (Layout)
Les interfaces (Layout) permettent de dessiner la vue tel qu’elle
doit s’afficher à l’utilisateur.
Il existe deux possibilités de développer des interfaces :
Code java
Fichier XML
Android recommande l’utilisation des fichiers XML pour définir les
interfaces.
La méthode setContentView permet d’associer un layout à une
activité
Exemple :
setContentView(R.layout.login);
Introduction à Android
44 Interfaces (Layout) / Vues
Les interfaces sont composées de vues :
Les vues ne peuvent être modifiées que par le thread principal
« UIThread » .
Tous les autres threads créés par un utilisateur ne peuvent pas
modifier les vues.
Introduction à Android
45 Vues Propriétés communes
Identifiant :
android:id="@+id/mon_ident"
Dimension:
layout_height, android:layout_width : fill_parent / match_parent /
wrap_content
fill_parent : Remplit toute la place
wrap_content : remplit la place que necessite le contenu
match_parent : remplit la place qui reste dans le parent
Fond
android: background
Visibilité
android:visibility : visible / invisisble/gone
Introduction à Android
46 Vues Propriétés communes
Marges internes
android:layout_paddingBottom , android:layout_paddingLeft ,
android:layout_paddingRight , android:layout_paddingTop
Marges externes
android:layout_marginBottom , android:layout_marginLeft ,
android:layout_marginRight , android:layout_marginTop
Introduction à Android
47 Vues
Les vues déclarées dans les fichiers xml peuvent sont automatiquement
instanciées par Android.
Pour récupérer l’instance d’une vue associée à une interface, Android propose la
méthode findViewById() prenant en paramètre l’identifiant de la vue dans le
fichier xml.
La méthode findViewById utilise le conteneur principal de l’interface de
l’activité courante.
Exemple :
View v = findViewById(R.id.myView);
Connaissant le type de la vue
Button b = (Button)findViewById(R.id.btnCancel);
Les vues peuvent être créés dynamiquement :
Button b = new Button(this);
b.setId(1245);
Introduction à Android
48 Vues / Evènements
Les évènements permettent de gérer les actions utilisateurs sur les vues:
Pour gérer les évènements sur les vues, il suffit d’ajouter un écouteur
button.setOnClickListener(new View.OnClickListener()
@Override
public void onClick(DialogInterface dialog, int which) {
// Du code ici
}
});
button.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
}
});
Introduction à Android
49 Les conteneurs (ViewGroups)
Permettent de positionner des widgets dans une interface :
FrameLayout
AbsoluteLayout
LinearLayout
TableLayout
RelativeLayout
ScrollView
HorizontalScrollView
Introduction à Android
50 LinearLayout
Définit le positionnement linéaire (horizontall ou vertical) des vues filles
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/label_nom"
android:textAppearance="?android:attr/textAppearanceLarge" />
<EditText
android:id="@+id/editText1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:ems="10"
android:inputType="textPersonName" >
<requestFocus />
</EditText>
</LinearLayout>
Introduction à Android
51 LinearLayout
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation=« horizontal" >
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/label_nom"
android:textAppearance="?android:attr/textAppearanceLarge" />
<EditText
android:id="@+id/editText1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:ems="10"
android:inputType="textPersonName" >
<requestFocus />
</EditText>
</LinearLayout>
Introduction à Android
52 RelativeLayout
Positionner les éléments de l’interface les uns par rapport aux autres
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation=« horizontal" >
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/label_nom"
android:textAppearance="?android:attr/textAppearanceLarge" />
<EditText
android:id="@+id/editText1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:ems="10«
android:layout_toRightOf="@+id/textView1"
android:inputType="textPersonName" >
<requestFocus />
</EditText>
</RelativeLayout>
Introduction à Android
53 TableLayout
Tableau de positionnement des vues en ligne de
TableRow (similaire au <table> <tr> <td> de HTML)
Propriétés de TableRow.LayoutParams
layout_column: indice de départ de la colonne (à partir
de 0)
layout_span: nombre de colonnes occupées
Introduction à Android
54 Widgets
Les widgets représentent les blocs élémentaires visibles dans
l’interface utilisateurs. Une vie occupe une portion rectangulaire et
répond aux évènements d’interaction entre l’utilisateur final et
l’application
On distingue :
TextView
Button
EditText
CheckBox
RadioButton
ImageView
…
Introduction à Android
55 Widgets
<TextView android:id="@+id/my_text"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_weight="0.00"
android:text="@string/lblUsername"
android:textColor="@android:color/holo_blue_dark"
android:textAppearance="?
android:attr/textAppearanceMedium" />
<Button android:id="@+id/my_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/my_button_text"/>
<ImageView android:id="@+id/imageView1"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:contentDescription="@string/image_description"
android:src="@drawable/login" />
Introduction à Android
56 Les groupes
Les groupes permettent d’afficher une collection d’éléments à un
utilisateur:
ListView
Gridview
RadioGroupe
Galery
Spinner
Introduction à Android
57 Les adaptateurs
Pour ajouter des éléments à un groupe (ListView,
Spinner…), on utilise des adaptateurs.
Adaptateur: Classe qui définit une structure d’affichage
pour les groupes.
Android propose des adapter génériques que le
développeur peut utiliser pour afficher des informations
dans un élément de groupe
Le développeur peut définir son propre adapter pour
personnaliser l’affichage dans les groupes
Introduction à Android
58 Adaptateurs
<string-array name="country_arrays"> Spinner sp = (Spinner)
<item>Malaysia</item> <item>United findViewById(R.id.spinner1);
States</item> <item>Indonesia</item>
<item>France</item> <item>Italy</item> ArrayAdapter<String>
<item>Singapore</item> <item>New
Zealand</item> <item>India</item>
dataAdapter = new
ArrayAdapter<String>(this,
</string-array>
android.R.layout.simple_spinner_i
</resources> tem, R.array-string.
<Spinner android:id="@+id/spinner1" country_arrays);
android:layout_width="match_parent"
android:layout_height="wrap_content" dataAdapter.setDropDownViewR
android:entries="@array/country_arrays" esource(android.R.layout.simple_
android:prompt="@string/country_prompt" spinner_dropdown_item);
/>
sp.setAdapter(dataAdapter );
Introduction à Android
59 Adaptateurs
Adapter personnalisé
@Override
public View getView(int position, View convertView, ViewGroup parent) {
LayoutInflater inflater = (LayoutInflater) context
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
View rowView = inflater.inflate(R.layout.rowlayout, parent, false);
TextView textView = (TextView) rowView.findViewById(R.id.label);
ImageView imageView = (ImageView) rowView.findViewById(R.id.icon);
textView.setText(values[position]);
// Change the icon for Windows and iPhone
String s = values[position];
if (s.startsWith("iPhone")) {
imageView.setImageResource(R.drawable.no);
} else {
imageView.setImageResource(R.drawable.ok);
}
return rowView;
}
}
mySpinner.setAdapter (adapter);
Introduction à Android
60 Permission
Moyen de sécurité proposé par Android pour gérer l’accès aux
ressources du terminal
Elles apparaissent dans le fichier Android Manifest et sont visibles
par l’utilisateur au moment de l’installation de l’application
Elles concernent :
– La géolocalisation (GPS)
– Les accès aux contacts et à l'agenda du téléphone
– Les modifications de paramètres (orientation, fond d’écran …)
– Les appels téléphoniques
– L’envoi et réception de SMS/MMS
– L’audio
– Le réseau (dont l’accès à Internet)
– Le matériel (bluetooth, appareil photo, …)
Introduction à Android
61 Permission
La déclaration des permissions doit se faire explicitement dans le fichier
manifest.
Si une permission a été omise et vous essayez d’utiliser la ressource
correspondante, vous aurez une erreur à l’exécution!
<uses-permission android:name="android.permission.CALL_PHONE" />
<uses-permission android:name="android.permission.INTERNET " />
Introduction à Android
Connectivité
Android fournit des mécanismes permettant aux applications
d’utiliser la connectivité pour accomplir certaines taches :
Internet (WIFI, 3G,…)
Bluetooth
NFC
Pour accéder à ces ressources, il est obligatoire de demander
explicitement la permission associée
<uses-permission
android:name="android.permission.INTERNET"/>
Introduction à Android
Internet
Une application Android peut utiliser la connexion réseau du
téléphone pour échanger par HTTP des informations avec une
application distante (web service, web application,..)
Permission pour utiliser internet :
<uses-permission
android:name="android.permission.INTERNET"/>
Android utilise la bibliothèque Apache Components pour les
communications par http
HttpClient client =new DefaultHttpClient();
HttpGet request =new HttpGet(url);
HttpResponse response = client.execute(request);
…
Introduction à Android
Taches Asynchrones
La UIThread est le thread principal de gestion de l’interface
utilisateur. L’exécution des processus longs dans ce thread comme
l’accès au réseau doit se faire dans un thread à part.
A partir de la version 4, Android génère une exception pour tout
opération longue s’exécutant dans le thread principal.
L’exécution des taches asynchrones peut se faire de deux manières:
L’utilisateur crée explicitement un thread auquel il délègue l’exécution
des processus longs
Utiliser la classe AsyncTask du SDK qui se chargera de la création du
thread secondaire
Introduction à Android
Taches Asynchrones
protected class LongTask extends AsyncTask<String, Void, Void> {
@Override
super.onPreExecute();
@Override
super.onPostExecute(resp);
@Override
return null;
Introduction à Android
Bien plus encore!
Persistance : SQLite, Préférences
Géolocalisation
Multimédia : Vidéo, Musique,…
Connectivité : Bluetooth, NFC, QR Code
Services
Notifications, BroadCast
Introduction à Android