Programmation des systèmes mobiles & sans fil
|
|
|
- Yves Carbonneau
- il y a 10 ans
- Total affichages :
Transcription
1 Organisation du module Programmation des systèmes mobiles & sans fil CM/TD/TP Ο Cours magistraux : 5 heures Ο Travaux pratiques : 37,5 heures Evaluation Ο Contrôle continue : 1 séance (1h30) [70%] Olivier Le Goaer M2 TI Année Ο Note de TP : projet MobileApp (~6h) [30%] Ressources pédagogiques Ο Tout au format électronique (PDF) sur WebCampus Pré-requis du module Plan du module Langages de développement Ο HTML, CSS, Javascript, Java SE, PHP Formats d'échange Ο XML, JSON Outils de développement Ο IDE Eclipse Ο phpmyadmin Base de données Avant-propos Ο Comprendre les tendances et les enjeux du développement d'applications pour terminaux mobiles Développer une WebApp Ο Apprendre à développer une application web compatible mobile à l'aide du framework jquery Mobile Développer une MobileApp Ο Apprendre à développer une application native sur la plateforme mobile Android Ο SQL Un marché en explosion Avant-propos Vente de "terminaux mobiles" évolués Ο Un téléphone mobile sur trois vendu dans le monde est un smartphone Ο L'explosion des ventes doit beaucoup à l'énorme succès de l'iphone d'apple. Ο L'arrivée en force des tablettes (ardoises numériques) Ο Des utilisateurs de plus en plus accros (les "nomophobes") Vente d'applications associées Ο On prévoit 20 milliards d applications téléchargées par an en 2014 contre 2,3 en 2009 Ο C'est la nouvelle ruée vers l'or!
2 De nouvelles opportunités SmartPhone Demande croissante des entreprises Ο Définition et mise en œuvre de leur stratégie Web et/ou mobile Ο Postes de «Développeur Applications Mobiles H/F» Ο Niveau Bac+5 (école d'ingénieur ou universitaire) exigé Une offre de formation qui s'adapte Ο Les écoles et universités intègrent peu à peu la programmation mobile dans leurs plaquettes de formation Ο L'université de Pau a lancé ce module dès 2008, en ciblant alors J2ME (Java 2 Micro Edition) Écrans Ο QVGA, WVGA... Ο Mono/multi-touch Capteurs Ο GPS, Boussoles, Accéléromètres... Connectivité Ο GSM (voix + données), Wifi, BlueTooth, NFC Réseaux sans fil Téléphonie mobile Les quatre catégories de réseaux sans fil 2 ème génération : passage au numérique Ο 1990 : GSM (Global System for Mobile Communication) Ο Fréquences 900 et 1800 MHz, débit 9,6 Kb/s GSM, GPRS, EDGE, UMTS (3G) 2,5 génération Ο 2001 : GPRS (General Packet Radio Service) Ο Débit 250 Kb/s mais la voix continue de transiter sur le réseau GSM 3 ème génération Réseaux personnels sans fil (WPAN) Réseaux locaux sans fil (WLAN) Zone de couverture Réseaux métropolitains sans fil (WMAN) Réseaux étendus sans fil (WWAN) Ο 2004 : UMTS (Universal Mobile Telecommunications System) Ο Fréquences MHz, débit 2 Mb/s OS Mobile : l'offre actuelle OS mobile : développements Plateforme Programmation Outillage conseillé Windows Phone VB.Net, C# Visual studio.net ios/iphone Objective-C X-CODE Blackberry OS Java MDS Studio Java ME Java EclipseME (CLDC, MIDP) Android Java, code natif C++ Eclipse + ADT Symbian OS C++ Performance Bada C++ badaide Mozilla OS HTML/CSS/Javascript Xemacs? ;-)
3 Modèles de développement MobileApp versus WebApp Modèle hybride Application mobile (native) Application web Portabilité Développement spécifique à chaque plateforme Navigateur Web Développement/coût Mises à jour Nécessite un SDK + connaissance d un langage spécifique Soumission à un magasin d applications et éventuelle validation + re-téléchargement par le client Langage du Web (HTML / JS / CSS / PHP...) Mise à jour rapide en mettant à jour tout simplement les fichiers sur le serveur Web Disponibilité Mode online et offline Nécessite obligatoirement une connexion internet. Fonctionnalités Utilise toutes les fonctionnalités du mobile (GPS, voix, notifications, contacts...) Limitées aux possibilités du navigateur Ο Encapsulation d'une WebApp dans une MobileApp Ο Ce modèle, qui est un compromis, est amené à se développer de plus en plus Le défi du cross-plateforme Il existe des solutions pour du développement natif cross-plateformes Ο PhoneGap : installation d'un socle web pour chaque plateforme cible, puis developpement HTML/CSS/Javascript Ο Canappi : DSL (Domain Specific Langage) de haut-niveau traduit en code natif pour chaque plateforme cible Ο Titanium Mobile : codage (javascript-like) interprété par un composant pré-installé sur chaque plateforme cible. Ο Neomades : codage (android-like, donc java) basé sur une API propriétaire. Puis transformation vers chaque plateforme cible Ο... Développer une WebApp [avec jquery Mobile] Le browsing sur mobile Le browsing sur mobile est déjà une réalité Ο Il est aujourd'hui possible de reproduire une expérience utilisateur similaire à celle d'une application native Ο Un site mobile sera toujours moins cher qu'une application développée dans un environnement propriétaire. Les browsers mobile et le support des standards W3C sont au coeur des enjeux Ο Apple Safari : moteur WebKit Ο Google Chrome : moteur WebKit Ο Microsoft IE : moteur Trident Ο Mozilla Firefox : moteur Gecko WebApp mobile-friendly Frameworks actuels Customisation pour terminal mobile Ο Renvoyer au terminal mobile une page adaptée à ses spécificités (mobile-friendly) Ο Taille écran limitée, débit limité, pointage tactile... Deux solutions sont envisageables 1) Handheld stylesheets Fournir une feuille de style CSS spécifique aux périphériques mobiles (media="handheld") 2) Mobile-optimized site En plus d'une feuille de style spécifique, fournir à l'utilisateur un niveau global d'interactivité imitant les applications natives auquel il est habitué Voir ''Media Query'' du W3C jqtouch Sencha Touch Dojo mobile jquery Mobile... iui
4 Principes de bases Vous allez créer des documents Ο Conforme au doctype HTML 5 Puis, jquery Mobile modifie le DOM des documents au chargement Ο en ajoutant des éléments et des attributs de style Ο en exploitant de façon transparente la technologie Ajax Au final on obtiens automatiquement Ο Une apparence graphique très "ios-like" Ο Des effets de transitions entre les pages jquery Mobile en images... Etape 1 : importation Des librairies sont requises Ο Soit stockées en local sur votre serveur Ο Soit directement sur le serveur publique à haute disponibilité de jquery.com Importation dans le document courant Ο Une feuille de style spécifique mobile (.css) Ο La librairie javascript jquery (.js) Ο La librairie javascript jquery Mobile (.js) Versions compactées <link rel="stylesheet" href=" /> <script type="text/javascript" src=" <script type="text/javascript" src=" Etape 2 : structure Template d'un document Exploitez l'attribut data-* dans votre document, où * est la fonctionnalité désirée Ο data-role précise la nature du bloc (page header content footer) Ο data-position spécifie où l'élément doit être positionné (top bottom right left) Ο data-inset spécifie si l'élément doit être contenu dans les marges ou à l'extérieur de celles-ci (true false) Ο data-transition spécifie quelle transition utiliser lors du chargement de nouvelles pages (slide slideup slidedown pop flip fade) Ο data-theme spécifie le thème graphique à utiliser pour les éléments d'un conteneur (a b c d e) <!DOCTYPE html> <html> <head> <title>page Title</title> <link rel="stylesheet" href=" /> /> <script type="text/javascript" src=" <script type="text/javascript" src=" </head> <body> <div data-role="page" id=''foo''> <div data-role="header"> <h1>page Title</h1> </div><!-- /header --> <div data-role="content"> <p>page content goes here.</p> </div><!-- /content --> <div data-role="footer"> <h4>page Footer</h4> </div><!-- /footer --> </div><!-- /page --> </body> </html>
5 Mono-page Deux approches possibles Ο 1 document = 1 page HTML Page HTML Page lien inter-document Multi-pages lien intra-document Ο 1 document = n page HTML Page Page Page Permet le pré-fetch des pages Modèle de navigation Lien intra-document Ο Utilisez l'id de la page cible : <a href="#foo">next</a> Ο Le contenu de la page est déjà dans le DOM courant et une transition opère (cf. attribut data-transition) Lien inter-document Ο Utilisez l'url du document cible: <a href="./bar.html">next</a> Ο Une requête Ajax est forgée, le contenu de la page est ajoutée au DOM courant et une transition opère Ο Si le document cible est multi-pages, ajoutez rel="external" au lien, ou bien data-ajax="false" Barre d'outils Quelques composants Ο header, footer, navbar... Formatage Ο Layout, blocs rétractables & effet accordéons... Boutons Ο simples, icônes, inline, groupes... Listes Ο Simples, numérotés, imbriquées, séparateurs... Formulaires (voir diapo suivante) Balise classique Formulaires Ο <form action="form.php" method="post">...</form> Puis, inclusion des éléments de HTML 5 Ο Slider, case à cocher, bouton radio, menu déroulant... Pour une mise en forme soignée Ο Utilisez des blocs dont le rôle est "fieldcontain" <div data-role="fieldcontain"> <label for="name">numéro client :</label> <input type="text" name="name" id="name" value="" required /> </div> Dialogues Une page peut être stylisée en tant que boite de dialogue modale Ο Accapare l'écran jusqu'à quelle soit fermée Ο Utile pour : confirmation, message informatif, etc. <div data-role="page" id="foo"> <div data-role="header" data-position="inline"> <h1>attention</h1> </div> <div data-role="content"> <h1>connectivité limitée</h1> <p>vérifiez vos branchements...</p> <a href="#" data-role="button" data-rel="back">ok</a> </div> </div> Tout se joue ensuite sur le lien vers la page Ο <a href="./foo.html" data-rel="dialog">voir</a> Catégories d'évènements Liés au pointage/touché Ο tap, taphold, swipe, swipeleft/swiperight Liés au changement d'orientation de l'écran Ο orientationchange Liés au défilement de l'écran Ο scrollstart, scrollstop Liés à l'affichage des pages Ο pagebeforeshow, pagebeforehide, pageshow, pagehide Liés à l'initialisation des pages Ο pagebeforecreate, pagecreate
6 Gestion des évènements Et la "touche finale" Méthodes live() ou bien bind() Ο $('elem').live('eventname', callback); Exemples en vrac : //s'applique à tout le document (non testé) $(document).live('tap',function(event, ui){ alert('tapotage'); ); //S'applique à toutes les pages $('div').live('pageshow',function(event, ui){ alert('affichage de la page active'); ); //Ne s'applique qu'à une page donnée $('#aboutpage').live('pagecreate',function(event){ alert('cette page vient d'être améliorée par Jquery'); ); Cf. fonctionnement des sélecteurs CSS : $('div') $('div.foo') $('div > p') $('#bar') Immiter une icône de lancement native Ο Créer une favicon de 57x57 pixels, au format PNG Ο <link rel="apple-touch-icon" href="myicon.png" /> Solutions sous iphone et Android Tester votre WebApp Test en visuel, via un terminal mobile Ο Consulter le niveau de support (le grade) du navigateur Tester en visuel, sans terminal mobile Ο jquery Mobile fonctionne sur un navigateur standard! Ο Ripple Emulator (Extension pour Chrome) Ο Opera Mobile Emulator Framework de test pour jquery Ο Qunit : Démo : Bankster Bankster : La banque des gangsters Ο Plagie une WebApp mobile-friendly d'un organisme bancaire Fonctionnalités de l'application Bankster Ο Partie publique Formulaire d'identification, infos bourse (récupérés au format JSON), liste des agences (image google maps), annuaire Ο Partie privée Le client s'est authentifié, il a accès à son solde et aux opérations de virements Exemples login/password : demo/demo, dsk/dsk Flashez pour accèder à la démo Développer une MobileApp [sous Android] 2003 Naissance de la startup Android Inc. Bref historique 2007 Voir annonce par Sergey Brin sur Youtube : Annonce d'android +SDK Open Handset Alliance Rachat de la startup par Google Inc. Premier mobile sous Android : le T-Mobile G1
7 Open Handset Alliance (OHA) Matériels Android Regroupement de + de 50 entreprises Ο Fabricants de matériels Ο Opérateurs mobiles Ο Développeurs d'applications Ο... Objectif : Ο Développer des normes ouvertes pour les appareils de téléphonie mobile Smartphone Tablette Netbook APN Télévision Embarqué Points forts d'android Versions d'android Point de vue constructeur Système Linux + Java Point de vue bidouilleur Point de vue utilisateur Système fonctionnel, intuitif, évolutif Point de vue développeur CodeName Platform API Level Cupcake Android Donut Android Eclair Android Froyo Android Gingerbread Android Honeycomb Android Ice Cream Sandwich Android Jelly Bean?? Key Lime Pie Kouign-Amann?? Projet Open Source C++ / Java Application développées en syntaxe Java SDK complet fourni Android en images... Architecture logicielle Version Ice Cream Sandwich (ICS)
8 Priorité Machine virtuelle "Dalvik" Priorités des processus Offre l'avantage de toute machine virtuelle Ο Couche d'abstraction entre le développeur d'applications et des implémentations matérielles particulières La VM Dalvik n'est pas une VM Java Ο Tient compte des contraintes de CPU et mémoire Ο Exécute des fichiers.dex (Dalvik Executable) optimisés La VM créé une instance Dalvik pour chaque processus (lourd) Ο Les applications sont totalement indépendantes ("sandbox") Espaces protégés (mémoire, disque) Evite un plantage généralisé! Processus actif Processus visible Processus de service en cours d'exécution Processus d'arrière-plan Processus vide Android gère ses ressources de manière agressive Ο Pour garantir une haute réactivité Ο Elimination de processus sans avertissement! Ο Politique de priorité basée sur une hierarchisation des processus Le petit univers Java Outils du développeur Concepts de la POO Java Ο Paquetage, classe, annotation, héritage, interface... Idiômes Ο Classes anonymes, classes internes, POJOs... Bibliothèques (API) Ο J2SE (subset) : java.io.*, java.lang.*... Ο Android : android.view.*, android.telephony.*... Ο Google : com.google.android.maps.*... Design patterns Ο Singleton, Builder, Observer (Listener), DAO... Apache Harmony Plugin Eclipse ADT (Android Development Tools) Ο Assistant à la création de projet Ο Createur d'interface graphique (WYSIWYG) Ο Vues et perspectives dédiées Android SDK Ο API Ο Emulateurs Ο Debugger, compilateur, empaqueteur, signature Ο Exemples (démos) Ο... Plugin ADT Eclipse Emulateur : aperçu Perspectives Vues Numéro du terminal Boutton 'HOME' Boutton 'MENU' Boutton 'BACK' Ecran ''Tactile'' Theme (skin) par défaut
9 Emulateur : limitations Arborescence système Long au démarrage... Ο Car c'est un linux qui démarre + tous les services! Fonctionnalités non-disponibles Ο Appareil photo Ο Vibreur Ο Appels téléphoniques réels Ο Capteurs en général Ο Connexions USB Ο Enregistrement audio Ο Évolution de la charge de la batterie Applications utilisateur (.apk) (AngryBirds, Météo...) Applications système (.apk) (Horloge, Browser, Calculatrice...) Données des applications (database SQLite, SharedPreferences...) Commandes système (mkdir, chmod, ls...) Arborescence projet Externaliser les ressources Dossier du projet Vos fichiers sources (*.java) API Android (ici version 2.2) Ressources organisées (icônes, layout, textes...) Le plugin ADT gère et facilite cette structuration Fichier source automatiquement généré (à partir du contenu du répertoire res) Ressources non-organisées (zip, pdf, html...) Fichier Manifest Android prévoit de-facto l'externalisation des ressources Ο Facilité de maintenance, de mise à jour et de gestion Créer des ressources Ο Simples valeurs, chaînes de caractères, couleurs, menu, layout, styles, images, etc. Ο Stockées dans le répertoire /res/ d'un projet Android Compilation et déploiement Environnement contraint Sources Java.java Bytecode Java.class Ressources + Manifest.png.xml Bytecode Dalvik (optimisé).dex.apk Application empaquetée Entièrement automatisé avec le plugin ADT sous Eclipse!! /data/app Pour vos développements, gardez à l'esprit que les appareils mobiles ont : Ο Une puissance processeur plus faible Ο Une RAM limitée Ο Des capacités de stockage permanent limitées Ο De petits écrans avec de faibles résolutions Ο Des coûts élevés de transfert de données Ο Des taux de transferts plus lents avec une latence élevée Ο Des connexions réseau moins fiables Ο Des batteries à autonomie limitée
10 Types d'applications Android Construction d'une application Android Application de premier plan (ex: jeu de Poker) Application d'arrière plan (ex: répondeur automatique aux SMS) Intermittente (ex: lecteur de média) Widget (ex: météo du jour) Les différents composants Le manifeste Activities Écrans de présentation Content Providers Sources de données partageables Services Tâches d'arrière-plan Manifeste Métadonnées, composants, prérequis Broadcast Receivers Réactions Ecrans à de présentation des annonces/évènements Intents Activations & messages inter/intra-applications Chaque projet contient à sa racine un fichier AndroidManifest.xml qui : Ο Nomme le paquetage Java de l'application. Ce dernier sert d'identificateur unique de l'application. Ο Déclare les composants applicatifs (activities, services, broadcast receivers, content providers) de l'application et leurs filtres si nécessaire (à quels intents ils réagissent) Ο Déclare les permissions que l'application doit avoir pour fonctionner (droit de passer des appels, droit d'accèder à Internet, droit d'accèder au GPS...) Ο Déclare le niveau minimum de compatibilité du SDK pour que l'application fonctionne Ο... AndroidManifest.xml Notion de contexte Permissions requises Nœud de l'application Nœud d'une activité de l'application Nœud d'un service de l'application Nœud d'un broadcast receiver de l'application Nœud d'un content provider de l'application <?xml version="1.0" encoding="utf-8"?> <manifest package="fr.univpau.bankster"> <uses-permission /> <uses-sdk /> <supports-screens /> <application> <activity> <intent-filter> <action /> <category /> <data /> </intent-filter> </activity> <service> <intent-filter>... </intent-filter> </service> <receiver> <intent-filter>... </intent-filter> </receiver> <provider> <grant-uri-permission /> </provider> </application> </manifest> Pensez à bien déclarer tous les composants applicatif de votre application! Le contexte modélise les informations globales sur l'environnement de l'application Possède les méthodes importantes Ο getressources, getpackagename, getsystemservice... Ο startactivity, startservice, sendbroadcast, getcontentresolver... Ο openfileinput, openorcreatedatabase, getsharedpreferences... Accès au contexte Ο Depuis une Activity ou un Service : this (car héritage) Ο Depuis un BroadcastReceiver : en argument de onreceive() Ο Depuis un ContentProvider : this.getcontext()
11 Activité Cycle de vie d'une activité Une activité un écran graphique Ο Incarne souvent un cas d'utilisation (use case UML) Une application est formée de n activités Exemple : application de téléphonie 1) Numéroteur 2) Annuaire des contacts 3) Fiche d'un contact 4) Ajout d'un contact Etend android.app.activity 7 méthodes de callback Ο void oncreate(...) Ο void onstart() Ο void onrestart() Ο void onresume() Ο void onpause() Ο void onstop() Ο void ondestroy() Diagramme de cas d'utilisation (UML) Activité : code source Lancer une activité package fr.univpau.bankster; import android.app.activity; public class Home extends Activity public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); /* Allocation des ressources ici protected void ondestroy() { super.ondestroy(); /* Desallocation des ressources ici */ Le bundle sert à mémoriser l'état de l'ui de l'activité lorsqu'elle passe en arrière plan Pour pouvoir être lancée, toute activité doit être préalablement déclarée dans le manifeste Une activité est désignée comme activité initiale de l'application Ο Ceci est indiqué dans le fichier manifeste Lancer une activité Ο Méthode startactivity(...) Lancer une activité en vue d'obtenir un résultat en retour Ο Méthode startactivityforresult(...) La pile des activités Multi-tâches Les activités sont empilées/dépilées Ο Empilée quand une activité démarre Ο Dépilée (i.e. détruite) quand on presse le bouton 'BACK' Une pression sur le bouton 'HOME' ne dépile pas l'activité. Ο Elle passe simplement en arrière plan Plusieurs piles d'activités peuvent co-exister avec Android Ο L'utilisateur passe de l'une à l'autre Reprend l'activité située au sommet de la pile
12 Service Sert à effectuer des opérations ou des calculs en dehors de l interaction utilisateur Ο Ne nécessite pas une interface graphique Deux types de services : Ο Local : services qui s exécutent dans le même processus que votre application Ο Distant (IPC) : services qui s exécutent dans des processus indépendants de votre application (cf. description AIDL) Un service est une classe qui étend Ο android.app.service Cycle de vie d'un service 5 méthodes de callback Ο oncreate() Ο onstart() SDK<2.0 Ο onstartcommand() Ο ondestroy() Ο onbind() Ο onunbind() S'éxécute dans le processus courant Service : code source Démarrage et arrêt d'un service package fr.univpau.bankster; import android.app.service; public class AccountCleaner extends Service public void oncreate() { /* allocation des ressources ici void onstartcommand(intent intent, int flags, int startid) { /* Votre code du service ici protected void ondestroy() { super.ondestroy(); /* Desallocation des ressources ici */ Mode Unbounded Ο Un composant démarre et arrête un traitement en tâche de fond comme il le souhaite Opérations Ο startservice(...) Ο stopservice(...) Un même service peut supporter les 2 modes simultanément Mode Bounded Ο Des composant (des "clients") établissent une connexion permanente afin d'interagir avec un service par le biais d'une interface Opérations Ο bindservice(...) Ο unbindservice(...) Ο + toutes les méthodes de l'interface définie Intents : principes Intents : vue d'ensemble Les trois types de composants applicatifs sont activés via des intentions (Intents) Main Activity startactivity(intent) startactivityforresult(intent) finishactivity(int) Activity Ο Activity, Service et BroadcastReceveir onactivityresult(intent) setresult(intent) Intent getintent() Principe d'un bus à messages asynchrones A S B sendbroadcast(intent) sendorderedbroadcast(intent) sendstickybroadcast(intent) startservice(intent) stopservice(intent) bindservice(intent) Filtre d'intentions de A Intent Filtre d'intentions de S Filtre d'intentions de B BroadcastReceiver onreceive(intent) Service onstartcommand(intent) IBinder onbind(intent) Bus
13 Types d'intention 1. Directe Natures des intents Instance de android.content.intent Le composant cible est activé par le composant source 2. Par procuration Instance de android.content.pendingintent Le composant cible est activé par un élément tiers, de la part du composant source (toutes ses permissions lui sont cédées pour l'occasion) Modes de désignation 1. Explicite Le composant cible est nommé «Activer tel composant» 2. Implicite Le composant cible n'est pas nommé «Activer un composant capable de prendre en charge cette action, sur cette donnée» Les filtres d'intention indiquent au bus si le message d'activation doit être délivré au composant Intents : les extras Il est possible d'utiliser l'intent pour convoyer des données supplémentaires Ο Une à une, ou regroupées dans un bundle (android.os.bundle) Stockage sur le principe d'une table de hash Ο Méthode putextra surchargée Ο Les types de base (+array) sont gérés Ο Les types complexes (c-a-d les classes) doivent implémenter Parcelable,ou Serializable Récupération Ο Méthode propre à chaque type, de la forme getxxxextra() Intent : code source Actions et URI courantes package fr.univpau.bankster; import android.app.activity; import android.content.intent; public class Home extends Activity { void gotonextscreen() { Intent i = new Intent(); /* Intent direct */ i.putextra("first", false); /* Donnée additionelle */ if(je_connais_la_cible) { /* Designation explicite (implémentation) */ i.setclass(home.this, NextActivity.class); else { /* Designation implicite(action + data) */ i.setaction(intent.action_dial); i.setdata(uri.parse("tel: ")); this.startactivity(i); /* Poussé sur le bus */ Action URI Signification ACTION_EDIT content://contacts/people/125 Editer la fiche du contact 125 ACTION_VIEW geo: , Ouvrir l application de géo-localisation à la position donnée (latitude, longitude). ACTION_CALL tel: Appeller le numéro ACTION_VIEW google.streetview: cbll= , Ouvrir google street view à la localisation donnée Actions natives android Ο Constantes de la classe android.content.intent Format d'une URI Ο scheme://host:port/path Ο schemes usuels : http, mailto, tel, mms, geo, file... Filtres d'intention Chaque composant peut définir des filtres d'intention au niveau du manifeste Ο Quelles actions sont supportées? Ο Sur des URIs de quelle forme? Quels types de données? Ο Dans quelles circonstances? Permettra au bus de savoir si le message d'activation (i.e. l'intent) doit être délivré au composant ou non L'absence de filtres implique une désignation explicite du composant Résolution des intentions Importance du mode de désignation ACTION_VIEW tel:112 Ο Explicite : le composant cible est éxécuté Ο Implicite : 0, 1 ou plusieurs composants sont ciblés, mais un seul sera éxécuté (choix de l'utilisateur si besoin) A1 <activity android:name="a1"> <intent-filter> <action name="...view"/> <data scheme="http"/> </intent-filter> </activity> A2 <activity android:name="a2"> <activity <intent-filter> android:name="a2"> <intent-filter> <action name="...view"/> <data <action scheme="tel"/> name="...view"/> </intent-filter> <data scheme="tel"/> </activity> </intent-filter> </activity> A3 <activity android:name="a3"> </activity> Bus
14 Actions personnalisées Définir ses propres verbes d'action package fr.univpau.bankster; public class Home extends Activity { public static final string DEBITER = public void oncreate(bundle savedinstancestate) { startservice(new Intent(Home.DEBITER)); Déclarer des filtres en conséquence <manifest> <application> <service android:name="accountmanager"> <intent-filter> <action android:name="fr.univpau.bankster.debiter"/> <category android:name="android.intent.category.default"/> </intent-filter> </service> </application> </manifest> Applications et Tâches Ainsi, une application peut faire appels des "morceaux" d'autres applications Ο Réutilisation/partage de composants voulu par Android Une succession d'activités pour atteindre un objectif donné est appelée "Tâche" Ο Les activités empilées proviennent de diverses applications Ο Complétement transparent du point de vue de l'utilisateur Une application android possède plusieurs points d'entrée (pas de "main") Ο Il est possible de lancer n'importe quelle partie exposée d'une application sans en lancer la totalité Broadcast receiver Receiver : code source Réagit à aux annonces diffusées à l'aide sendbroadcast(...) Ο System-defined : la batterie est faible, un SMS vient d'arriver, etc. Ο User-defined : solde bancaire négatif, etc. Ne nécessite pas une interface graphique Un broadcast receiver est une classe qui étend Ο android.content.broadcastreceiver Un receiver s'abonne/désabonne via le fichier manifest ou programmatiquement package fr.univpau.bankster; import android.content.broadcastreceiver; public class Sleep extends BroadcastReceiver public void onreceive(context arg0, Intent arg1) { //si besoin, accèder aux extras de l'intent arg1 Intent i = new Intent(arg0, AccountCleaner.class); arg0.startservice(i); <manifest> <application> <receiver class="fr.univpau.bankster.sleep"> <intent-filter> <action android:name="android.intent.action.screen_off"/> </intent-filter> </receiver> </application> </manifest> Content Provider Un content provider sert à rendre une partie des données d'une application accessibles aux autres applications Ο Seul moyen pour un partage de données inter-applications Un content provider est une classe qui étend Ο android.content.contentprovider Expose les données via une URI dont le scheme est 'content' Ο System-defined : content://contacts/people/125 Ο User-defined : content://fr.univpau.bankster/account/ Résolution de contenu Différentes techniques de persistence Ο Fichier binaire (serialisation d'objets) Ο Fichier XML/JSON Ο Base de donnée embarquée ou distante Ο Etc. La façon dont sont réellement stockées les données doit rester transparente Ο Interface commune pour manipuler les données offertes par un content provider Ο Elle s'obtient via un contentresolver ContentResolver cr = getcontentresolver();
15 Content Resolver : exemples URI et type MIME SpyApp content://call_log/calls Content Providers Natifs Publier l'uri de votre provider Ο Elle sera utilisée pour y accèder via le ContentResolver + delete() + insert() + notifychange() + query() + update() Content Resolver Settings CallLog MediaStore.Images MediaStore.Audios Ο public static final URI CONTENT_URI = Uri.parse("content://fr.univpau.bankster/account"); Deux cas de figures : Ο Un seul enregistrement URI : content://fr.univpau.bankster/account/[id] Type MIME : vnd.android.cursor.item/fr.univpau.bankster Ο Plusieurs enregistrements URI : content://fr.univpau.bankster/account/ Type MIME : vnd.android.cursor.dir/fr.univpau.bankster Provider : code source package fr.univpau.bankster; import android.content.contentprovider; public class AccountProvider extends ContentProvider { public static final URI CONTENT_URI = Uri.parse("content://fr.univpau.bankster/account"); Interface graphique utilisateur (GUI) public boolean oncreate() { /* Initialiser la source de données ici */ return true; public Cursor query(uri uri, String[] projection, ) { /* En fonction du format de l'uri */ if (uri_termine_par_un_id) { /* Renvoyer un seul compte client */ else { /* Renvoyer tous les comptes */ Principe de R.java R.java Chaque élément défini dans le répertoire /res impacte le fichier R.java (à ne pas toucher) Ο Génèration automatique de classes internes à la classe R, ainsi que des constantes de type entier sur 32bits Chemin d'accès aux ressources via R.java Ο user-defined : fr.univpau.foo.r.color.rose_bonbon Ο system-defined : android.r.color.darker_gray Objet java représentant les ressources Ο Instance de la classe android.content.res.resources Ο Ressources du projet en cours : context.getresources() public final class R { public static final class attr { public static final class drawable { public static final int icon=0x7f020000; public static final class id { public static final int edittext1=0x7f050000; public static final int listview1=0x7f050001; public static final class layout { public static final int main=0x7f030000; public static final class string { public static final int app_name=0x7f040001; public static final int hello=0x7f040000; Le fichier R permet de tirer parti d'une vérification syntaxique par le compilateur Le fichier R permet de tirer parti d'une complétion automatique de code dans l'éditeur Eclipse
16 Exploiter les ressources UI : User Interface Utiliser des ressources depuis le code Ο La plupart des éléments de l'api sont prévus pour accepter des ressources android en paramètre (int ressource) Ο obj.setcolor(r.color.rose_bonbon); Ο obj.setcolor(android.r.color.darker_gray); Référencer des ressources depuis d'autres ressources Ο attribute="@[packagename]:resourcetype/resourseident" Ο <EditText android:textcolor="@color/rose_bonbon"/> Ο <EditText android:textcolor="@android:color/darker_gray"/> Une API Java riche Ο Des layouts et des widgets (appelés «Vues») Programmation déclarative à la XML Ο Sépare la vue du code métier Fonctionnalité de personnalisation Ο Hériter et redéfinir un widget de base Ο Combiner des widgets existants Ο Dessin 100% personnalisé - View::onDraw(Canvas canvas) Rendu 2D/3D (non abordé dans ce cours) Ο OpenGL, Renderscript Mais peut se faire de façon 100% programmatique Les Vues Android Layouts : aperçu Principe du design pattern Composite View 0..* +ondraw(canvas canvas) ViewGroup ViewSimple +addview(view child) ViewGroup ( layout) Ο LinearLayout Ο TableLayout Ο RelativeLayout Ο FrameLayout Ο ScrollView ViewSimple ( widget) Ο Button Ο EditText Ο TextView Ο Spinner Ο CheckBox Propriétés de placement Propriétés de placement Orientation Ο Sens de placement des vues dans un conteneur Ο android:orientation = vertical horizontal Taille Ο Surface prise par la vue Ο android:layout_width/android:layout_height =??px fill_parent wrap_content Gravité Ο Alignement d'une vue dans son conteneur Ο android:layout_gravity = left center_horizontal top bottom right... Poids Ο Taux d'espace libre affectés à chaque widgets Ο android:layout_weight =?(0 par défaut) Espacement (intra) Ο Espacement entre un contenu et les bords de sa vue Ο android:padding? = top left right bottom Espacement (inter) Ο Espacement entre les vues Ο android:layout_margin? =??px
17 Widgets : aperçu Activités dédiées Afin de simplifier les choses, il existe des classes pré-définies à étendre directement Ο ListActivity : si votre activité présente une liste d'items Ο ExpandableListActivity : si votre activité présente une liste d'items extensible Ο MapActivity : si votre activité présente une carte google Ο TabActivity : si votre activité présente des onglets Ο WebViewClient : si votre activité présente un rendu de pages web Ο PreferenceActivity : si votre activité présente un panneau de préférences Fragments Dialogues et Toasts Nouveauté depuis Android 3.0 Ο Prévus pour les écrans plus large, comme les tablettes Principe de base Ο Fragmentation de l'espace d'affichage en différentes zones, chargeables indépendamment Ο Même idée que les "Frames" en HTML Un fragment est une classe qui étend Ο android.app.fragment Les fragments sont ensuite insérés dans une activité hôte (FragmentActivity) Dialogues Ο Confirmation Ο Progession Toasts Ο Message compact et rapide à l'intention de l'utilisateur Menus Barres Menu principal Menu contextuel Barre d'action rapide Barre d'action
18 Instanciation des vues Il est nécessaire d'instancier les vues (i.e. obtenir des objets) pour pouvoir les manipuler Récupérer les widgets depuis le code Ο Grâce aux identifiants affectés à chaque vue Ο Button mybutton = (Button) findviewbyid(r.id.my_button); Récupérer tout une vue depuis le code Ο Grâce au nom du fichier xml décrivant un layout ou un menu Ο View my_view = LayoutInflater.inflate(R.layout.main, null); Ο MenuInflater.inflate(R.menu.control, my_menu); Gestion des évènements Principe des écouteurs de Java SE Ο Fournir une implémentation respectant un contrat (interface) afin de réagir à des types d'évènements particuliers Gestion du KeyPad (tap, trackball) Ο OnClickListener, OnLongClickListener onclick(view), onlongclick(view) Ο OnKeyListener onkeyup(keyevent), onkeydown(keyevent) Gestion du TouchScreen (pression, gesture) Ο OnTouchListener ontouchevent(motionevent) Les adaptateurs Model-View-Presenter (MVP) Les adaptateurs sont des classes qui lient des données aux vues de l'ui Ο Les vues concernées étendent android.widget.adapterview Classes d'adaptateurs Ο Héritent de android.widget.baseadapter Ο SimpleAdapter, ArrayAdapter<?> : sert à récupérer des données stockées dans une collection Exploite par défaut la valeur de la méthode tostring() des objets de la liste Ο CursorAdapter : sert à récupérer des données stockées dans une base de donnée relationelle (SQLite) Ο Vous pouvez étendre ces classes de base pour gérer finement vos items (conseillé) Notify data changed query data MODEL Cursor ou Collection (ArrayList, [[]...) PRESENTER BaseAdapter (CursorAdapter, ArrayAdapter,...) refresh adapted-by VIEW AdapterView (Spinner, ListView...) Apparences des items L'apparence des items sont définies par défaut par des layouts système Ο android.r.layout.simple_spinner_item spécifie un texte aligné à gauche et un boutton radio à droite, ainsi qu'un texte noir sur fond blanc. Ο android.r.layout.simple_list_item_1 Ο... Spécifie un texte aligné à gauche, ainsi qu'un texte blanc sur fond transparent. Vous pouvez évidemment définir vos propre layouts pour créer des items plus complexes Ο fr.univpau.bankster.r.layout.mon_bel_item Notifications Différentes formes de notifications : Ο LED Ο Son Ο Vibreur Ο Barre de notification (icône) Utilisation facilitée par le notification manager Ο NotificationManager nm = (NotificationManager) getsystemservice(context.notification_service); Ο nm.notify(number, new Notification(...))
19 Application Multi-écrans Images redimensionnables Prévoir différentes variantes d'une même image Ο /res/drawable-hdip/icon.png Ο /res/drawable-mdip/icon.png Ο /res/drawable-ldip/icon.png Utiliser les images 9 patchs Ο Images divisées en 9 zones (dont certaines sont étirables) Ο Outil Draw 9-patch du répertoire /tool du SDK Android Draw9patch.exe produit des fichiers *.9.png Prévoir les 2 orientations possibles (portrait ou landscape) Ο /res/layout-port/main.xml Ο /res/layout-land/main.xml Depuis le code, on manipule une seule ressource, sans se soucier de la résolution (R.drawable.icon) Application Multi-langues Prévoir différentes variantes d'une même chaîne Ο /res/values-fr/strings.xml Ο /res/values-en/strings.xml Ο /res/values-it/strings.xml Le choix sera fait automatiquement en fonction de la configuration du terminal (ex: LOCALE=FR_fr) S'applique également aux images car elles peuvent afficher du texte! Ο /res/drawable-fr/splashscreen.png Ο /res/drawable-en/splashscreen.png On manipule une seule ressource, sans se soucier de la langue (R.strings.hello) Persistance et threading Shared Preferences Gestion de fichiers plats Mécanisme simple et léger Ο Sauvegarde de paires clé/valeur simple Ο SharedPreferences pref = getpreferences(activity.mode_private) Sauvegarder des préférences Ο Récupère un éditeur de préférences : Editor ed = pref.edit() Ο Stocke les paires : ed.putstring("teacher", "Olivier Le Goaer"); ed.putboolean("isbrilliant", true); Ο Valide les modifications : ed.commit(); Retrouvez des préférences Ο String t = pref.getstring("teacher","unknown"); Mécanisme de lecture/écriture de fichiers Ο Exploite l'espace de stockage interne ou externe Ο API habituelle java.io Sauvegarde et chargement Ο Flux de sortie : FileOutputStream fos = openfileoutput("cac40.dat", Context.MODE_PRIVATE) Ο Flux d'entrée : FileInputStream fis = openfileinput("cac40.dat") Accès uniquement aux fichiers de l'application courante Ο Séparateurs de chemins interdits
20 Serialisation d'objets Chaque classe implémente l'interface Serializable (+champs serialversionuid) Ο Idem que pour java SE Ο Format de stockage binaire Basé sur la gestion de fichiers ci-avant Ο Serialisation ObjectOutputStream oos = new ObjectOutputStream(fos); oos.writeobject(myobject); Ο Dé-sérialisation ObjectInputStream ois = new ObjectInputStream(fis); myobject = (myclass) ois.readobject(); XML XML et JSON Ο Parsing de ressources au format XML Ο Voir API javax.xml.parsers JSON Approche hiérarchique (DOM) : org.w3c.dom Approche évènementielle (SAX) : org.xml.sax Ο Parsing de ressources au format JSON Ο Voir API org.json Note SAX plus performant que DOM! Base de donnée relationelle Android embarque le SGBDR SQLite Ο Léger et puissant Ο Typage dynamique des colonnes Ο Ne gère pas les contraintes d'intégrité référentielle Types de données Ο NONE, INTEGER, REAL, TEXT, BLOB Implémentation Ο Support du standard SQL-92 Les types Booléens, Dates, sont ''émulés'' avec ces types primitifs Mais manque RIGHT OUTER JOIN et FULL OUTER JOIN... Ο Support partiel des déclencheurs (triggers) Bonnes pratiques Créer son propre helper Ο Etendre android.database.sqlite.sqliteopenhelper Ο Classe abstraite qui gère la création, l'ouverture et la montée de version d'une base de données Ο myhelper = new BanksterHelper(context, "bankster.db", null, 1) L'instance de la BDD est ensuite obtenue à l'aide du helper, selon deux modes Ο SQLiteDatabase db; Ο db = myhelper.getwritabledatabase() //lecture et ecriture Ο db = myhelper.getreadabledatabase() //lecture seule Interrogation de la base Approche par SQL brut Ο La requête est fournie sous forme de chaîne de caractères du dialecte SQL Ο db.rawquery("select * FROM Customer WHERE id>? AND id<?", new String[]{"47645", "58421") Approche par composante Ο Une requête est fournie via ses composantes relationnelles (projection, selection, groupement, tri...) Ο db.query (boolean distinct, String table, String[] columns, String selection, String[] selectionargs, String groupby, String having, String orderby, String limit) Résultats L'ensemble des t-uples retournés par une requête est un curseur Ο Cursor res = db.query(...) On peut parcourir cet ensemble Ο Même principe que les itérateurs de collection Java Ο Utiliser les méthode get<type> pour récupérer la valeur d'un champ //vérifie qu'il y a au moins un tuple if (res.movetofirst()) { //itère sur chaque tuple (i.e. chaque ligne) do { String customername = res.getstring(3); //3e champ while(res.movetonext()) Fermeture d'un curseur : manuellement ou en mode ''managé''
21 Ajout, suppression, m-a-j Thread principal Représentation d'un t-uple Ο Un t-uple est une instance de android.content.contentvalues Ο t paires nom-de-champs/valeur-de-champ Ajout de t-uples Ο db.insert(string table, String nullcolumnhack, ContentValues values) Supression de t-uples Ο db.delete(string table, String whereclause, String[] whereargs) Mise à jour de t-uples Ο db.update(string table, ContentValues values, String whereclause, String[] whereargs) Tous les composants d'une application démarrent dans le thread principal UIThread Ο Gère l'affichage graphique et les interactions utilisateur Ο Vos traitements "consommateurs" et lents bloqueront tous les autres composants (dont affichage + interactions) :-( Nécessité de les déplacer en arrière-plan : Ο A l'aide de tâches asynchrones Ο A l'aide de vos propres Threads enfants Puis les synchroniser avec l'interface graphique Ο Car le UIThread est le seul habilité à modifier les vues! Tâche asynchrone Thread enfant Classe qui étend android.os.asynctask<?,?,?> Fournie des gestionnaires d'évènements déjà synchronisés avec le UIThread pour mettre à jour les vues Ο doinbackground : placez le code à exécuter à cet endroit. Pas d'interaction avec l'ui! Ο onprogressupdate : mettez à jour l'ui au fil du traitement Ο onpostexecute : une fois le traitement terminé, m-a-j de l'ui Execution de la tâche Ο new MyAsyncTask().execute(data1, data2,...); Même fonctionnement que JAVA SE Ο Créer une instance de la classe java.lang.thread qui encapsulera une instance implémentant la méthode run() de l'interface java.lang.runnable Ο new Thread(new Runnable() { public void run(...) ).start(); Pour synchroniser un thread enfant avec l'ui Ο Directement depuis une activité runonuithread(new Runnable() {...); Ο Dans les autres cas Instancier un handler nécessairement dans le UiThread : h = new Handler(); Y enfiler des runnables depuis le thread enfant : h.post(new Runnable(){...); Les capteurs Capteurs & pointage tactile Un périphérique Android peut possèder aucun ou plusieurs capteurs (sensors en anglais) Ο Cinémomètre (ou accèléromètre) Ο Gyroscope (ou boussole) Ο Luminomètre Ο Magnétomètre Ο... Constantes supportées par la classe android.hardware.sensor Ο TYPE_AMBIENT_TEMPERATURE, TYPE_GRAVITY, TYPE_GYROSCOPE, TYPE_LIGHT...
22 Principes des capteurs Capteurs : code source Système d'abonnement à un capteur Ο Votre programme est à l'écoute des évènements qui surviennent au niveau d'un capteur Ο Le SensorManager (android.hardware.sensormanager) permet de gèrer facilement les abonnements en cours Méthodes registerlistener et unregisterlistener Surtout, bien penser à se désabonner Ο Car les données continuent d'être acquises (même si elles ne sont pas traitées) et cela consomme de l'énergie! Ο Se gère au niveau du cycle de vie des composants concernés Typiquement, dans les méthodes onpause() et ondestroy() d'une activité package fr.univpau.bankster; import android.app.service; import android.hardware.*; public class FallingDown extends Service public void oncreate() { // Mise en place de l'écoute de l'accèléromètre sm = (SensorManager)getSystemService(SENSOR_SERVICE); a = sm.getdefaultsensor(sensor.type_accelerometer); sm.registerlistener(new SensorEventListener() {..., protected void ondestroy() { super.ondestroy(); sm.unregisterlistener(...); Acquisition des données Evènement de capteur Choisir son taux d'acquisition (toutes les n microsecondes) Ο Exemple de contantes de la classe Sensor : SENSOR_DELAY_NORMAL, SENSOR_DELAY_FASTEST... Interface android.hardware.sensoreventlistener commune à tous les capteurs Ο onaccuracychanged() : la précision a changée (+/-) Ο onsensorchanged() : une nouvelle valeur brute est disponible Chaque évènement est un objet instance de la classe android.hardware.sensorevent L'évènement est modélisé par : Ο la précision de l'acquisition Ο le capteur qui l'a généré Ο son horodatage Ο les valeurs brutes Vecteur de flottants dont la taille dépends du capteur Une seule valeur Ο Luminomètre, pression, proximité... Trois valeurs (X-Y-Z) Ο Accèléromètre, gravité, gyroscope... Multi-touch Trois gestes de base a) Tap b) Drag c) Pinch-Zoom Un ou deux doigts En vrac Ο Le dominant Ο Le secondaire
23 Serveur HTTP Serveur HTTP + + PHP, PHP, JSP/Servlets, JSP/Servlets, Services système Il est fréquent de récupérer des Managers à partir de services systèmes pré-configurés Ο Appel de la méthode getsystemservice(context.xxxxx) Ο Retour : LocationManager, LayoutInflater, WifiManager... Exemples de services (constantes) Ο Context.LOCATION_SERVICE Ο Context.LAYOUT_INFLATER_SERVICE Ο Context.STORAGE_SERVICE Ο Context.TELEPHONY_SERVICE Ο Context.WIFI_SERVICE Alarmes et Timers Les alarmes sont un moyen de déclencher des intents (et donc des composants) Ο à des heures déterminées Ο à des intervalles déterminés Prise en charge par le gestionnaire d'alarme Ο AlarmManager am = (AlarmManager)getSystemService(Context.ALARM_SERVICE) Ο am.set(type, TIME, pendingintent) Les timers gèrent l'exécution de tâches Ο new Timer().shedule(new TimerTask() {..., new Date()); Linkify, TextWatcher Transformer des textes (TextView) en liens cliquables (générateur d'intent) Ο Classe utilitaire android.text.util.linkify Ο Reconnaissance de motifs : n tel, , url web, map... Controler la saisie d'un texte (EditText) Ο Classe utilitaire android.text.textwatcher Ο Gère des évènements : avant, après, pendant la saisie Application : variable globale Comment partager des données à travers tous les composants d'une application Ο Créer une sous classe de android.app.application Ο Gère des énènements propres à la vie de l'application oncreate(), onterminate(), onlowmemory(), onconfigurationchanged() Ο Se déclare au niveau du nœud <application> du manifeste Principe du singleton Ο Une seule instance de la classe pour toute l'application Ο Les variables d'instances sont les données à partager Mapping objet-relationnel Le vas-et-viens entre la BDD embarquée et les objets métiers est fastidieuse Ο Appliquer le fameux pattern DAO Il existe toutefois des solutions ORM adaptée à Android (car légère) Ο ORMLite Ο ActiveAndroid Ο NeoDatis Ο DB4O Ο Orman Ο DataFramework Ο Androrm BDD distante La connexion d'un périphérique Android à une BDD distante n'est pas prévue (ni souhaitable) Ο Pas de pont "JDBC" en quelque sorte Il est nécessaire de mettre en place une approche par "WebService" Ο SOAP Ο REST Astuce : masquez le tout avec un ContentProvider Requête Réponse... XML/SOAP, JSON BDD (Oracle, MySQL, PosgreSQL...)
24 Mockups pour MobileApps Prototypage de l'ui de votre MobileApp Ο Dessiner les écrans avant de démarrer le développement Outils de mockups Tests et déploiement Ο Balsamiq (web demo) Ο MobiOne Studio (free) Ο OmniGraffle (Mac, $99) Ο Ο Ο... Test de la couche métier Test de l'ui Tests des activités, services, et providers Paquetage android.test TODO Le test du singe sur votre IHM Ο Test de résistance : "Si elle resiste au comportement anarchique d'un singe, elle resistera à l'utilisateur" Ο Génère des évènements pseudos-aléatoire, tels que des clics, des pressions de touches, des gestes, etc. Le programme s'éxécute dans votre émulateur Ο Se lance en ligne de commande adb shell monkey [options] <event-count> Ο Vous suivez les évènements générés dans le logcat :Sending Pointer ACTION_DOWN x=437.0 y=183.0 :SendKey (ACTION_DOWN): 90 // KEYCODE_FORWARD=... Exporter et signer Distribution des MobileApps Toute application doit être signée Ο Signature digitale avec un certificat dont la clé privée est conservée par le(s) développeur(s) Ο Signature avec debug.keystore par défaut Trois étapes : 1 Obtenir une clé privée Utilitaire keytool.exe du JDK 2 Signer l'apk avec la clé privée Utilitaire jarsigner.exe du JDK 3 Optimiser l'apk qui vient d'être signé Utilitaire zipalign.exe du SDK Android Procédure entièrement automatisée avec ADT 3 solutions s'offrent à vous Ο Utiliser Google Play (anciennement Android Market) Site officiel : 25$ de frais de dossier pour l'accès au store 70% du prix de vente va aux développeurs (30% à Google) Les autres revenus générés sont reversés via Google Checkout Ο Auto-publier sur votre propre site web Exemple : Type MIME pour le téléchargement : application/vnd.android.package-archive Ο Utiliser un magasin tiers YAAM ( Bazaar ( AndroLib (
25 Analyse d'audience Google Analytics SDK pour Android Ο Nombre d'utilisateurs actifs de votre application Ο Leur localisation à travers le monde Ο Impact de votre campagne de pub (réalisation d'objectifs) Ο Et plein d'autres métriques... Principes de fonctionnement Ο Affection d'un UA number de la forme UA-xxxxx-yy Ο Insertion d'instructions de tracking (évènements, affichages...) dans le code Ο Tableau de bord disponible sur
Programmation des applications mobiles avec Android. 1 Inspiré du cours de Olivier Le Goaer
Programmation des applications mobiles avec Android 1 Inspiré du cours de Olivier Le Goaer 2 OS mobile : outils de développement D après le cours de Olivier Le Goaer 3 Plateforme de développement MobileApp
Android 4 Les fondamentaux du développement d'applications Java
La plateforme Android 1. Présentation 13 2. Historique 14 3. Google Play 15 3.1 Création d'un compte développeur 16 3.2 Publication d'une application 16 3.3 Suivi et mise à jour d'une application 18 Environnement
Les fondamentaux du développement d applications Java
Android 5 Les fondamentaux du développement d applications Java Nazim BENBOURAHLA Table des matières 1 Les éléments à télécharger sont disponibles à l'adresse suivante : http://www.editions-eni.fr Saisissez
Outils, langage et approche Android Une introduction. Nicolas Stouls nicolas.stouls@insa lyon.fr
Outils, langage et approche Android Une introduction Nicolas Stouls nicolas.stouls@insa lyon.fr Webographie La bible contenant «tout» : http://developer.android.com/index.html Les supports cette intervention
Tutorial pour une application simple
ANDROID & ECLIPSE Tutorial pour une application simple 1. Introduction Android est un système d'exploitation pour téléphone portable de nouvelle génération développé par Google. Celui-ci met à disposition
TP au menu «UI ANDROID»
TP au menu «UI ANDROID» Pré-requis & Installation ( du couvert) soit installer en natif sur vos postes (!!! ATTENTION!!! FromScratch 1,1 Go à télécharger ) JDK http://www.oracle.com/technetwork/java/javase/downloads/index.html
Table des matières. Partie I Concepts de base... 1. Préface... VII
Table des matières Préface... VII Partie I Concepts de base... 1 1. Tour d horizon... 3 Avantages et inconvénients de la programmation des smartphones... 3 Contenu d un programme Android... 4 Fonctionnalités
Optimiser pour les appareils mobiles
chapitre 6 Optimiser pour les appareils mobiles 6.1 Créer un site adapté aux terminaux mobiles avec jquery Mobile... 217 6.2 Transformer son site mobile en application native grâce à PhoneGap:Build...
TP2 : Client d une BDD SqlServer
TP2 : Client d une BDD SqlServer Objectifs : utiliser la barre de menu, utiliser les préférences d application (settings) ou (options), gérer la persistance des données, utiliser la bibliothèque jtds:jdbc
Point sur les solutions de développement d apps pour les périphériques mobiles
Point sur les solutions de développement d apps pour les périphériques mobiles Par Hugues MEUNIER 1. INTRODUCTION a. Une notion importante : le responsive web design Nous sommes en train de vivre une nouvelle
Android. Présentation d Android. Florent Garin http://www.docdoku.com http://twitter.com/docdoku
Android Présentation d Android 20 novembre 2010 Florent Garin http://www.docdoku.com http://twitter.com/docdoku Florent Garin Co-fondateur de DocDoku Société innovante IT http://www.docdoku.com Co-fondateur
DÉVELOPPEMENT ANDROID
DÉVELOPPEMENT ANDROID ESIEE / Key Consulting Partie 2 v2.2-2012 INTENT Key Consulting INTENT Intent : intention Une Intent est une agrégation d informations, décrivant de manière abstraite une action devant
LANGAGUE JAVA. Public Développeurs souhaitant étendre leur panel de langages de programmation
ING 01 LANGAGUE JAVA Durée : 21 heures 1090 HT / jour Dates : à définir en 2012 Concevoir et développer des programmes en langage Java Comprendre le fonctionnement de la machine virtuelle S approprier
www.elektor.fr/android SOMMAIRE
www.elektor.fr/android Android Apprendre à programmer des applis Environnement de développement Eclipse Programmation orientée objet en JAVA Auteur : Stephan Schwark Éditeur : Elektor ISBN : 978-2-86661-187-3
TD/TP 1 Introduction au SDK d Android
TD/TP 1 Introduction au SDK d Android Romain Raveaux 1 Introduction Android est un système d'exploitation pour téléphone portable de nouvelle génération développé par Google. Celui-ci met à disposition
Installation et prise en main
TP1 Installation et prise en main Android est le système d'exploitation pour smartphones, tablettes et autres appareils développé par Google. Pour permettre aux utilisateurs d'installer des applications
Chapitre 1 Retour en arrière
Chapitre 1 : Retour en arrière 1 Chapitre 1 Retour en arrière Chapitre 1 : Retour en arrière 2 1. Difficultés de développer pour les systèmes embarqués Quelques contraintes à prendre en compte : - Mémoire:
Formation : WEbMaster
Formation : WEbMaster Objectif et Description : Centre Eclipse vous propose une formation complète WebMaster, vous permettant de : Utiliser dès maintenant les nouveautés du web2, ainsi alléger les besoins
1.3 Gestion d'une application
1.3 Gestion d'une application 1. Un premier projet... Il est temps maintenant d'écrire la véritable première application Android avec l'inévitable affichage du mot bonjour, ce qui évidemment pour un développement
Développement tablette Android. SophiaConf2011 Par Arnaud FARINE
Développement tablette Android SophiaConf2011 Par Arnaud FARINE Parts de marché Android en 2011 1er OS vendu aux EU fin 2010 24% des smartphones en France (35% ios, 11% Blackberry) 3,6 millions de smartphones
Auteur LARDOUX Guillaume Contact [email protected] Année 2014 DEVELOPPEMENT MOBILE AVEC CORDOVA
Auteur LARDOUX Guillaume Contact [email protected] Année 2014 DEVELOPPEMENT MOBILE AVEC CORDOVA Sommaire 1. Introduction 2. Installation 3. Fonctionnement 4. Développement 5. Démonstration 2
Béatrice Bertrand CDDP de l Eure. Béatrice Bertrand CDDP de l'eure
CDDP de l Eure Android (prononcé androïde) est un système d'exploitation fondé sur un noyau Linux, en open source, pour Smartphones, PDA (Personal Digital Assistant) et terminaux mobiles. Il comporte une
1. Base de données SQLite
Dans ce TP, nous allons voir comment créer et utiliser une base de données SQL locale pour stocker les informations. La semaine prochaine, ça sera avec un WebService. On repart de l application AvosAvis
BIRT (Business Intelligence and Reporting Tools)
BIRT (Business Intelligence and Reporting Tools) Introduction Cette publication a pour objectif de présenter l outil de reporting BIRT, dans le cadre de l unité de valeur «Data Warehouse et Outils Décisionnels»
Développement d applications professionnelles avec Android 2
Développement d applications professionnelles avec Android 2 Reto Meier Traduit par Dalil Djidel, avec la contribution technique d Arnaud Farine Pearson Education France a apporté le plus grand soin à
Iphone vs. Android. Mardi 17 Novembre 2009 Paris, la Défense. Xavier PARADON, Directeur Technique Valtech Training xavier.paradon@valtech-training.
Mardi 17 Novembre 2009 Paris, la Défense Iphone vs. Android Xavier PARADON, Directeur Technique Valtech Training [email protected] Anthony DAHANNE, Consultant Valtech Technology Consulting
Stockage de données sous Android
Stockage de données sous Android Master 2 informatique 2012-2013 Michel Chilowicz (sous licence CC By-NC-SA) Données temporaires d'une activité Une activité peut être détruite
Projet Android (LI260) Cours 2
Projet Android (LI260) Cours 2 Nicolas Baskiotis Université Pierre et Marie Curie (UPMC) Laboratoire d Informatique de Paris 6 (LIP6) S2-2013/2014 Plan Les ressources Debug Communication entre activités
TP SIN Programmation sur androïde Support : eclipse
TP SIN Programmation sur androïde Support : eclipse Support : Smartphone sur androïde Pré requis (l élève doit savoir): Savoir utiliser un ordinateur Savoir utiliser un Smartphone Programme Objectif terminale
ECLIPSE ET PDT (Php development tools)
ECLIPSE ET PDT (Php development tools) Eclipse Eclipse est un IDE (Integrated Development Environment)).C estun projet de la Fondation Eclipse visant à développer tout un environnement de développement
Devenez un véritable développeur web en 3 mois!
Devenez un véritable développeur web en 3 mois! L objectif de la 3W Academy est de former des petits groupes d élèves au développement de sites web dynamiques ainsi qu à la création d applications web
WEB & DÉVELOPPEMENT LES BASES DU WEB LE LANGAGE HTML FEUILLES DE STYLES CSS HISTORIQUE D INTERNET ET DU WEB LES DIFFÉRENTS LANGAGES
WEB & DÉVELOPPEMENT LES BASES DU WEB HISTORIQUE D INTERNET ET DU WEB LES DIFFÉRENTS LANGAGES LE LANGAGE HTML STRUCTURE D UNE PAGE En-tête et corps Syntaxe INSÉRER DES CONTENUS Texte : formatage (titre,
Développement sous Android
Développement sous Android Chapitres traités Les fournisseurs de contenu (Content Provider) Pour cette dernière étude de l'environnement Android, nous allons en profiter pour découvrir plein de fonctionnalités
Android Publish/Subscribe, GCM, Google Cloud Messaging : une introduction
Android Publish/Subscribe, GCM, Google Cloud Messaging : une introduction jean-michel Douin, douin au cnam point fr version : 8 Décembre 2014 Notes de cours 1 Sommaire Le socle, les fondements Le patron
Présentation du Framework BootstrapTwitter
COUARD Kévin HELVIG-LARBRET Blandine Présentation du Framework BootstrapTwitter IUT Nice-Sophia LP-SIL IDSE Octobre 2012 Sommaire I. INTRODUCTION... 3 Définition d'un framework... 3 A propos de BootstrapTwitter...
Développer des Applications Internet Riches (RIA) avec les API d ArcGIS Server. Sébastien Boutard Thomas David
Développer des Applications Internet Riches (RIA) avec les API d ArcGIS Server Sébastien Boutard Thomas David Le plan de la présentation Petit retour sur les environnements de développement ArcGIS Server
Edutab. gestion centralisée de tablettes Android
Edutab gestion centralisée de tablettes Android Résumé Ce document présente le logiciel Edutab : utilisation en mode enseignant (applications, documents) utilisation en mode administrateur (configuration,
Introduction à. Oracle Application Express
Introduction à Oracle Application Express Sommaire Qu est-ce que Oracle Application Express (APEX)? Vue d ensemble des fonctionnalités et des différents composants d Oracle APEX Démonstration de création
Projet Viticulture - TP 3 : bases de données distantes BTS Services informatiques aux organisations
Projet Viticulture TP 3 : bases de données externes Description du thème Partie 1 : bases de données locales SQLite Partie 2 : projet H2O stockage local Partie 3 : bases de données distantes Partie 4 :
Cursus Sage ERP X3 Outils & Développement. Le parcours pédagogique Sage ERP X3 Outils et Développement
Cursus Outils & Développement Vous êtes Consultant, Chef de Projets, Directeur des Systèmes d Information, Directeur Administratif et Financier, Optez pour les «formations Produits» Nous vous proposons
FORMATION PcVue. Mise en œuvre de WEBVUE. Journées de formation au logiciel de supervision PcVue 8.1. Lieu : Lycée Pablo Neruda Saint Martin d hères
FORMATION PcVue Mise en œuvre de WEBVUE Journées de formation au logiciel de supervision PcVue 8.1 Lieu : Lycée Pablo Neruda Saint Martin d hères Centre ressource Génie Electrique Intervenant : Enseignant
Introduction ANDROID
Introduction ANDROID 1 Un monde ouvert Première plateforme ouverte pour appareils mobiles.les applications natives et tierces utilisent les mêmes API. Un système d exploitation open source libre pour appareils
Gestion des différentes tailles d écran
25 Gestion des différentes tailles d écran Les écrans des terminaux Android, qui sont apparus sur le marché l année qui a suivi l apparition d Android 1.0, avaient tous la même résolution (HVGA, 320 480
INTRODUCTION A JAVA. Fichier en langage machine Exécutable
INTRODUCTION A JAVA JAVA est un langage orienté-objet pur. Il ressemble beaucoup à C++ au niveau de la syntaxe. En revanche, ces deux langages sont très différents dans leur structure (organisation du
Formation. Module WEB 4.1. Support de cours
Formation Module WEB 4.1 Support de cours Rédacteur Date de rédaction F.CHEA 08/02/2012 Les informations contenues dans ce document pourront faire l'objet de modifications sans préavis Sauf mention contraire,
Serveur d'application Client HTML/JS. Apache Thrift Bootcamp
Serveur d'application Client HTML/JS Apache Thrift Bootcamp Pré-requis La liste ci-dessous de logiciels doit être installée et opérationnelle sur la machine des participants : Compilateur thrift http://thrift.apache.org/
Bases de données et fournisseurs de contenu
8 Bases de données et fournisseurs de contenu Au sommaire de ce chapitre : Créer des bases de données et utiliser SQLite Utiliser les fournisseurs de contenu, les curseurs et les content values pour stocker,
Android. Programmation. De la conception au déploiement avec le SDK Google Android 2. Damien Guignard Julien Chable Emmanuel Robles
Programmation Android De la conception au déploiement avec le SDK Google Android 2 Damien Guignard Julien Chable Emmanuel Robles Avec la contribution de Nicolas Sorel et Vanessa Conchodon Groupe Eyrolles,
Programme «Analyste Programmeur» Diplôme d état : «Développeur Informatique» Homologué au niveau III (Bac+2) (JO N 176 du 1 août 2003) (34 semaines)
Programme «Analyste Programmeur» Diplôme d état : «Développeur Informatique» Homologué au niveau III (Bac+2) (JO N 176 du 1 août 2003) (34 semaines) Module 1 : Programmer une application informatique Durée
Manuel logiciel client for Android
1 Manuel logiciel client for Android 2 Copyright Systancia 2012 Tous droits réservés Les informations fournies dans le présent document sont fournies à titre d information, et de ce fait ne font l objet
Environnements de développement (intégrés)
Environnements de développement (intégrés) Introduction aux EDI, la plateforme Eclipse Patrick Labatut [email protected] http://www.di.ens.fr/~labatut/ Département d informatique École normale supérieure
SQL Server Installation Center et SQL Server Management Studio
SQL Server Installation Center et SQL Server Management Studio Version 1.0 Grégory CASANOVA 2 SQL Server Installation Center et SQL Server Management Studio [03/07/09] Sommaire 1 Installation de SQL Server
Java 7 Les fondamentaux du langage Java
184 Java 7 Les fondamentaux du langage Java 1.1 Les bibliothèques graphiques Le langage Java propose deux bibliothèques dédiées à la conception d'interfaces graphiques. La bibliothèque AWT et la bibliothèque
Compte Rendu d intégration d application
ISMA 3EME ANNEE Compte Rendu d intégration d application Compte Rendu Final Maxime ESCOURBIAC Jean-Christophe SEPTIER 19/12/2011 Table des matières Table des matières... 1 Introduction... 3 1. Le SGBD:...
Livre Blanc WebSphere Transcoding Publisher
Livre Blanc WebSphere Transcoding Publisher Introduction WebSphere Transcoding Publisher vous permet d'offrir aux utilisateurs des informations Web adaptées à leurs besoins. Il vous permet, par exemple,
DEVELOPPEMENT MOBILE - ETAT DE L ART DES SOLUTIONS
SI 2.0 DEVELOPPEMENT MOBILE - ETAT DE L ART DES SOLUTIONS REF : SIMO002 DUREE : 2 JOURS TARIF : 1 450 HT Public DSI, responsables informatiques et études, Architectes, responsables de projets, chefs de
Education Delivery Intelligent Tool
Education Delivery Intelligent Tool Projet AMO2 Maxence RAOUX Joachim SEGALA RICM 4 Avril 2012 Sommaire I. Presentation du projet... 2 1. Contexte... 2 2. Demande... 2 3. Spécifications... 2 II. Guide
Visual Paradigm Contraintes inter-associations
Visual Paradigm Contraintes inter-associations Travail de Bachelor d'informaticien de gestion Partie C Présentation de Visual Paradigm 1 Présentation de Visual Paradigm For UML L objet du travail de Bachelor
< Atelier 1 /> Démarrer une application web
MES ANNOTATIONS SONT EN ROUGE : Axel < Atelier 1 /> Démarrer une application web Microsoft France Tutorial Découverte de ASP.NET 2.0 Sommaire 1 INTRODUCTION... 3 1.1 CONTEXTE FONCTIONNEL... 3 1.2 CONTEXTE
CQP Développeur Nouvelles Technologies (DNT)
ORGANISME REFERENCE STAGE : 26572 20 rue de l Arcade 75 008 PARIS CONTACT Couverture géographique : M. Frédéric DIOLEZ Bordeaux, Rouen, Lyon, Toulouse, Marseille Tél. : 09 88 66 17 40 Nantes, Lille, Strasbourg,
Bureautique Initiation Excel-Powerpoint
Module de Formation Personnalisée : Bureautique Initiation Excel-Powerpoint Durée : jours ouvrables Prix : Formation personnalisée en vue d obtenir les notions de base indispensables pour : Excel Office
Développement sous Android
Développement sous Android Chapitres traités Architecture générale d'android Android est une plateforme ouverte pour le développement de mobiles (smartphones). C'est la première plateforme pour appareils
WysiUpStudio. CMS professionnel. pour la création et la maintenance évolutive de sites et applications Internet V. 6.x
WysiUpStudio CMS professionnel pour la création et la maintenance évolutive de sites et applications Internet V. 6.x UNE SOLUTION DE GESTION DE CONTENUS D UNE SOUPLESSE INÉGALÉE POUR CRÉER, MAINTENIR ET
APPLICATIONS MOBILES Catalogue de services Econocom-Osiatis 21.01.2014
APPLICATIONS MOBILES Catalogue de services 21.01.2014 Sommaire 1 2 Catalogue d applications mobiles types Organisation (5) Communication & Collaboration (3) Gestion d activités de services (3) CRM / B2C
Développement d'applications Web HTML5 L'art et la manière avec Visual Studio 2015 et TFS
Avant de commencer 1. Introduction 15 2. HTML5 oui, mais pas que... 15 2.1 HTML5 16 2.2 JavaScript 17 2.3 CSS 18 3. Les outils 18 Préparation des outils et création du projet 1. Introduction 21 2. Team
PRODIGE V3. Manuel utilisateurs. Consultation des métadonnées
PRODIGE V3 Manuel utilisateurs Consultation des métadonnées Pour plus d'information sur le dispositif : à remplir par chaque site éventuellement 2 PRODIGE V3 : Consultation des métadonnées SOMMAIRE 1.
WINDEV MOBILE. ios SMARTPHONE SUPPORT: IOS, ANDROID, WINDOWS PHONE 8.
WINDEV MOBILE ios SMARTPHONE SUPPORT: IOS, ANDROID, WINDOWS PHONE 8. WINDOWS Mobile permet de créer des applications pour les smartphones, les tablettes et les terminaux mobiles. Les applications sont
ContactForm et ContactFormLight - Gestionnaires de formulaire pour Prestashop Edité par ARETMIC S.A.
ContactForm et ContactFormLight - Gestionnaires de formulaire pour Prestashop Edité par ARETMIC S.A. - 1 - PREAMBULE Les conditions générales d utilisation détaillant l ensemble des dispositions applicables
Développement mobile MIDP 2.0 Mobile 3D Graphics API (M3G) JSR 184. Frédéric BERTIN [email protected]
Développement mobile MIDP 2.0 Mobile 3D Graphics API (M3G) JSR 184 Frédéric BERTIN [email protected] Présentaion : Mobile 3D Graphics API JSR 184 M3G :présentation Package optionnel de l api J2ME. Prend
Qu'est-ce que le BPM?
Qu'est-ce que le BPM? Le BPM (Business Process Management) n'est pas seulement une technologie mais, dans les grandes lignes, une discipline de gestion d'entreprise qui s'occupe des procédures contribuant
Plate formes mobiles. Utilisation. Contexte 9/29/2010 IFC 2. Deux utilisations assez distinctes :
Plate formes mobiles IFC 2 Markus Jaton Utilisation Deux utilisations assez distinctes : Téléphones évolués (Nokia, Motorola) Smartphones (Apple,, Windows) La téléphonie est en stagnation, alors que les
SYSTÈMES D INFORMATIONS
SYSTÈMES D INFORMATIONS Développement Modx Les systèmes de gestion de contenu Les Content Management Système (CMS) servent à simplifier le développement de sites web ainsi que la mise à jour des contenus.
PHP 5.4 Développez un site web dynamique et interactif
Editions ENI PHP 5.4 Développez un site web dynamique et interactif Collection Ressources Informatiques Table des matières Table des matières 1 Chapitre 1 Introduction 1. Objectif de l'ouvrage.............................................
La base de données XML exist. A. Belaïd
La base de données XML exist Introduction Qu est-ce-que exist? C est une base de donnée native, entièrement écrite en Java XML n est pas une base de données en soi Bien qu il possède quelques caractéristiques
Ceci est un Chromebook, ton ordinateur!
Ceci est un Chromebook, ton ordinateur! CHROMEBOOK - Dans le royaume des ordinateurs personnels, il n'y a pas beaucoup de choix. Pour schématiser, soit vous avez un PC, soit vous avez un Mac. Et ce depuis
et Groupe Eyrolles, 2006, ISBN : 2-212-11747-7
Tsoft et Groupe Eyrolles, 2006, ISBN : 2-212-11747-7 OEM Console Java OEM Console HTTP OEM Database Control Oracle Net Manager 6 Module 6 : Oracle Enterprise Manager Objectifs Contenu A la fin de ce module,
CRÉER, ROUTER ET GÉRER UNE NEWSLETTER, UN E-MAILING
CRÉER, ROUTER ET GÉRER UNE NEWSLETTER, UN E-MAILING Durée : 3J / 21H Formateur : Consultant expert en PAO et Web-marketing. Groupe de : 4 max Formation au web marketing Objectifs : Mettre en oeuvre des
Guide d installation
Free Android Security Guide d installation Marques et copyright Marques commerciales Windows est une marque déposée de Microsoft Corporation aux États-Unis et dans d'autres pays. Tous les autres noms de
Formation Webase 5. Formation Webase 5. Ses secrets, de l architecture MVC à l application Web. Adrien Grand <[email protected]> Centrale Réseaux
Formation Webase 5 Ses secrets, de l architecture MVC à l application Web Adrien Grand Centrale Réseaux Sommaire 1 Obtenir des informations sur Webase 5 2 Composants de Webase 5 Un
2 Grad Info Soir Langage C++ Juin 2007. Projet BANQUE
2 Grad Info Soir Langage C++ Juin 2007 Projet BANQUE 1. Explications L'examen comprend un projet à réaliser à domicile et à documenter : - structure des données, - objets utilisés, - relations de dépendance
Développement Android. J.-F. Couchot
Développement Android J.-F. Couchot 12 novembre 2012 Table des matières 1 Introduction à l OS embarqué Android 3 I Composants principaux d une application................................ 3 I.1 Une activité............................................
Votre premier projet Android
3 Votre premier projet Android Maintenant que le SDK Android est installé, il est temps de créer votre premier projet. La bonne nouvelle est qu il n exige aucune ligne de code les outils Android créent
Oracle Developer Suite 10g. Guide de l installation. Vista & Seven
TRAVAIL RÉALISÉ PAR ABED ABDERRAHMANE Oracle Developer Suite 10g Guide de l installation 10g Release 2 (10.1.2) pour Windows Vista & Seven www.oraweb.ca Page 1 TABLE DES MATIÈRES : PARTIE 1 : CONCEPTS
MID. Table des matières
Table des matières Table des matières...1 1. Description de l apparence...2 2. Guide de démarrage...3 2.1 Chargement de la batterie...3 2.2 Comment utiliser la carte mémoire...3 2.3 Espace de stockage...4
Cyberclasse L'interface web pas à pas
Cyberclasse L'interface web pas à pas Version 1.4.18 Janvier 2008 Remarque préliminaire : les fonctionnalités décrites dans ce guide sont celles testées dans les écoles pilotes du projet Cyberclasse; il
Armand PY-PATINEC 2010
Armand PY-PATINEC 2010 EPREUVE PRATIQUE : TABLEAU SYNOPTIQUE Activités Inventaire de bières et de leur lieu de fabrication Gestion des clients pour un programme de facturation Emploi du ruban de l interface
TP1 : Initiation à Java et Eclipse
TP1 : Initiation à Java et Eclipse 1 TP1 : Initiation à Java et Eclipse Systèmes d Exploitation Avancés I. Objectifs du TP Ce TP est une introduction au langage Java. Il vous permettra de comprendre les
- TP Programmation Android - NFA024 Conservatoire National des Arts et Métiers
- TP Programmation Android - NFA024 Conservatoire National des Arts et Métiers vendredi 22 février 2013 Installation : Pour programmer des applications Android, il faut tout d abord veiller à disposer
JAVA 8. JAVA 8 - Les fondamentaux du langage. Les fondamentaux du langage Java. Avec exercices pratiques et corrigés JAVA 8 29,90.
Analyste et développeur pendant plus de 10 ans, Thierry GROUSSARD s est ensuite orienté vers la formation et plus particulièrement dans le domaine du développement. Sa connaissance approfondie des besoins
creer votre site internet en html/css
3 jours (21 heures) 1110 HT (Inter) 2670 HT (Intra) Toute personne (particulier ou professionnel) souhaitant créer son site Internet Créez son site Internet Assurez sa mise en ligne Gérer les mises à jour
Table des matières Introduction... 1 1. Démarrage... 8 2. Les composants graphiques... 26
Table des matières À propos de l'auteur... x Préface... xi Avant-propos... xiv 1. Public visé et prérequis... xiv 2. Sources des exemples... xv 3. Accès aux vidéos... xv 4. URL raccourcies... xv 5. Remerciements...
Introduction à Eclipse
Introduction à Eclipse Eclipse IDE est un environnement de développement intégré libre (le terme Eclipse désigne également le projet correspondant, lancé par IBM) extensible, universel et polyvalent, permettant
Avanquest Software présente la nouvelle gamme WebEasy 8
La Garenne Colombes, le 22 Juin 2009 Avanquest Software présente la nouvelle gamme WebEasy 8 Des logiciels pour créer simplement des sites internet de qualité professionnelle sans aucune connaissance en
Programme ASI Développeur
Programme ASI Développeur Titre de niveau II inscrit au RNCP Objectifs : Savoir utiliser un langage dynamique dans la création et la gestion d un site web. Apprendre à développer des programmes en objet.
Warren PAULUS. Android SDK et Android x86
Android SDK et Android x86 2010/2011 Voici un petit tutoriel pour installer Android de façon à ce qu il soit compatible avec NetBeans et Eclipse, ainsi que l utilisation d Android x86. Ce tutoriel a été
VRM Monitor. Aide en ligne
VRM Monitor fr Aide en ligne VRM Monitor Table des matières fr 3 Table des matières 1 Introduction 3 2 Vue d'ensemble du système 3 3 Getting started 4 3.1 Démarrage de VRM Monitor 4 3.2 Démarrage de Configuration
DOSSIER D'ACTIVITES SUR LE PHP N 03 Créer une base de données MySQL avec PHPMyAdmin
DOSSIER D'ACTIVITES SUR LE PHP N 03 Créer une base de données MySQL avec PHPMyAdmin Objectifs : Apprendre à l apprenant à lancer un serveur local «Apache» Apprendre à l'apprenant à lancer un serveur MySQL
