La présentation est en train de télécharger. S'il vous plaît, attendez

La présentation est en train de télécharger. S'il vous plaît, attendez

Receiver, CGM et + 1 Android Publish/Subscribe, GCM, Google Cloud Messaging : une introduction Notes de cours jean-michel Douin, douin au cnam point fr.

Présentations similaires


Présentation au sujet: "Receiver, CGM et + 1 Android Publish/Subscribe, GCM, Google Cloud Messaging : une introduction Notes de cours jean-michel Douin, douin au cnam point fr."— Transcription de la présentation:

1 Receiver, CGM et + 1 Android Publish/Subscribe, GCM, Google Cloud Messaging : une introduction Notes de cours jean-michel Douin, douin au cnam point fr version : 8 Décembre 2014

2 Receiver, CGM et + 2 Sommaire Le socle, les fondements –Le patron publish-subscribe L’entité Android de base : Receiver –Publication sendBroadcast(Intent i), sendOrderedBroadcast –Souscription onReceive, (BroadcastReceiver) –Exemples: Abonnement à un évènement –Batterie, réception de SMS Abonnement à une alarme –Service déjà installé sur le mobile GCM, Google Cloud Messaging –Google/Cloud s’occupe de tout Compte gmail dédié Abonnement de plusieurs mobiles Librairies, BroadcastReceiver et service, prêts à l’emploi –Ce qui reste à faire: Une classe dérivée, 4 redéfinitions de méthodes et c’est tout Une architecture logicielle possible, pour discussions

3 Receiver, CGM et + 3 Principale bibliographie Le tutorial indispensable –http://developer.android.com/google/gcm/index.html Avant il y avait c2dm –Vogella http://www.vogella.com/articles/AndroidCloudToDeviceMessaging/article.html –http://blog.octo.com/notifications-push-android-c2dm/http://blog.octo.com/notifications-push-android-c2dm/ –https://github.com/joemoore/c2demohttps://github.com/joemoore/c2demo

4 Receiver, CGM et + 4 Les fondements Le patron publish/subscribe –Publication à l’occurrence d’un évènement –Un sms entrant, la batterie déchargée, … –Un évènement engendré par l’utilisateur –Souscription à un évènement –Agir en conséquence –Un médiateur se charge De la réception des évènements, de leur filtrage De la diffusion auprès des souscripteurs sélectionnés –Diffusion aléatoire ou ordonnée

5 Receiver, CGM et + 5 Publish-Subscribe,cf NSY102 source: http://www2.lifl.fr/icar/Chapters/Intro/intro.html

6 Receiver, CGM et + 6 Publish-subscribe/ pull-push Les news d’internet, ou le forum de jfod … –Enregistrement d’un « client » à un sujet de discussion, –Un des « clients » décide de poster un message, –Les utilisateurs à leur initiative vont chercher l’information, –Publish-subscribe, mode pull Les listes de diffusion, logiciels de causerie, (« chat ») –Abonnement d’un « client » à une liste de diffusion, –Un des « clients » décide de poster un message, –Tous les abonnés reçoivent ce message, –Publish-subscribe, mode push

7 Receiver, CGM et + 7 Un exemple, mode push

8 Receiver, CGM et + 8 En Java/ notation UML/BlueJ

9 Receiver, CGM et + 9 Android et le patron Publish/Subscribe Une application Android peut : –Souscrire à un thème de publication, réception de SMS, niveau de batterie, … –Publier un évènement une alarme à son échéance, un évènement interne à l’application, … –Google Cloud Messaging une API prête à l’emploi plusieurs mobiles peuvent souscrire et être notifiés « Over the Air »

10 Receiver, CGM et + 10 Android/Publish-Subscribe : les bases Source : http://marakana.com/s/architecting_android_apps,1178/index.html souscription publication

11 Receiver, CGM et + 11 Publish-Subscribe/Intent & Context http://www2.lifl.fr/icar/Chapters/Intro/intro.html Context X,Y Intent BroadcastReceiver

12 Receiver, CGM et + 12 Souscription : schéma de programme Basée sur les –Intent (Topic), –Context (Mediator), –BroadcastReceiver (Subscriber). import android.content.Intent; import android.content.Context; import android.content.BroadcastReceiver; import android.util.Log; public class ReceiverTemplate extends BroadcastReceiver { public void onReceive(Context context, Intent intent) { Log.i(TAG, "onReceive action: "+intent.getAction() ); }

13 Receiver, CGM et + 13 Souscription effective Déclarative, AndroidManifest.xml –Au sein d’une application Par programme –getApplicationContext().registerReceiver( new ReceiverTemplate(), new IntentFilter(Intent.SMS_RECEIVED_ACTION));

14 Receiver, CGM et + 14 Par programme Cf. le cycle de vie d’une activité onResume –registerReceiver( … onPause –unregisterReceiver( …

15 Receiver, CGM et + 15 Les acteurs classe Context, le Mediator –http://developer.android.com/reference/android/content/Context.htmlhttp://developer.android.com/reference/android/content/Context.html classe BroadcastReceiver, le Subscriber –http://developer.android.com/reference/android/content/BroadcastReceiver.htmlhttp://developer.android.com/reference/android/content/BroadcastReceiver.html classe Intent + IntentFilter, X,Y les thèmes –http://developer.android.com/reference/android/content/Intent.htmlhttp://developer.android.com/reference/android/content/Intent.html À suivre: 3 exemples avec le système Android 1.Le niveau de la batterie vient d’être réactualisé, 2.Un sms vient d’arriver, 3.Un évènement de l’utilisateur.

16 Receiver, CGM et + 16 Exemple 1 : la batterie a changé d’état public class LowBatteryActivity extends Activity { private BroadcastReceiver receiver; public void onCreate(Bundle savedInstanceState) { …} public void onResume() { IntentFilter filter = new IntentFilter(Intent.ACTION_BATTERY_CHANGED); this.receiver = new BatteryChangedReceiver(); // Souscription registerReceiver(this.receiver, filter ); } public void onPause() { // Dé-souscription unregisterReceiver(this.receiver); }

17 Receiver, CGM et + 17 Le souscripteur // le Souscripteur private static class BatteryChangedReceiver extends BroadcastReceiver { public void onReceive(Context context, Intent intent) { Toast.makeText(context, "battery changed", Toast.LENGTH_SHORT).show(); Log.d(TAG, "onReceive action: "+intent.getAction() ); } http://developer.android.com/training/monitoring-device-state/battery-monitoring.html

18 Receiver, CGM et + 18 La publication par Android ressemblerait à android.os.BatteryManager Intent broadcastIntent = new Intent(); broadcastIntent.setAction( " ACTION_BATTERY_CHANGED " ); broadcastIntent.putExtra( " level ", 3567); // // http://developer.android.com/reference/android/os/BatteryManager.html // context.sendBroadcast(broadcastIntent);

19 Receiver, CGM et + 19 Exemple 2 : réception d’un SMS // le souscripteur public class SMSReceiver extends BroadcastReceiver{ @Override public void onReceive(Context context, Intent intent) { Toast.makeText(context, "sms received", Toast.LENGTH_SHORT).show(); }

20 Receiver, CGM et + 20 Configuration du souscripteur, // AndroidManifest.xml // La souscription Souscription effectuée (appel implicite de registerReceiver) au chargement de l’application (unregisterReceiver lorsque l’application est détruite)

21 Receiver, CGM et + 21 Exemple 3: « un évènement utilisateur » Ajout, retrait d’un « contrôleur » cf. MVC @Override public void onResume(){ super.onResume(); IntentFilter intentFilter = new IntentFilter(); intentFilter.addAction(Controller.ACTION); registerReceiver(this.controller, intentFilter); @Override public void onPause(){ super.onPause(); unregisterReceiver(this.controller); Avec Controller.ACTION public static final String ACTION = "fr.cnam.list.ITEMS";

22 Receiver, CGM et + 22 La classe « Controller », ici gestion d’une liste Le contrôleur agit sur le modèle, ici une liste (classe Items) public class ItemsController extends BroadcastReceiver { public static final String ACTION = "fr.cnam.list.ITEMS"; public static final String ADD = "add"; // valeurs public static final String REMOVE = "remove"; private Items items; // le modèle private Context context; // Android framework public ItemsController(Context context, final Items items){ this.context = context; this.items = items; // le modèle } @Override public void onReceive(final Context context, final Intent intent) { String operation = intent.getStringExtra(OPERATION_KEY); if(operation.equals(ADD)) items.ajouter(intent.getStringExtra(DATA_KEY)); else if(operation.equals(REMOVE)) items.retirer(Integer.parseInt(intent.getStringExtra(DATA_KEY))); }

23 Receiver, CGM et + 23 Démonstration Un des trois exemples Le contrôleur Optionnels: Intent.ACTION_BATTERY_CHANGED android.intent.action.SMS_RECEIVED_ACTION

24 Receiver, CGM et + 24 Autre façon de souscrire PendingIntent Intent à effet immédiat PendingIntent à effet retardé –Destiné à un tiers A destination d’un service existant –AlarmManager, NotificationManager … Souscription auprès du service –Exécution de l’intent passé en paramètre, à l’aide d’un PendingIntent

25 Receiver, CGM et + 25 Souscription auprès d’un service existant Intent intent = new Intent(this, ReceiverTemplate.class); PendingIntent appIntent = PendingIntent.getBroadcast(this, 0, intent, 0); Calendar calendar = Calendar.getInstance(); calendar.setTimeInMillis(System.currentTimeMillis()); calendar.add(Calendar.SECOND, 3); AlarmManager am = (AlarmManager)getSystemService(ALARM_SERVICE); am.set(AlarmManager.RTC, calendar.getTimeInMillis(), appIntent); // sendBroadcast( intent) par le service d’alarme

26 Receiver, CGM et + 26 Variante de l’écriture précédente PendingIntent appIntent = PendingIntent.getBroadcast (this, 0, new Intent(), 0); Calendar calendar = Calendar.getInstance(); // idem diapositive précédente am.set(AlarmManager.RTC, calendar.getTimeInMillis(), appIntent); // Ce sont les receveurs déclarés dans AndroidManifest.xml // qui seront déclenchés, (méthode onReceive) // puis sendBroadcast( intent) par le service d’alarme

27 Receiver, CGM et + 27 Notification Souvent associée à la réception d’un évènement –Déclenchée par le souscripteur Un « Receiver », un service, … –Exemple: Une notification à la réception d’un message sms »telnet localhost 5554 »send 1234 SMS test message

28 Receiver, CGM et + 28 Notification : affichage private static void generateNotification(Context context, String message) { long when = System.currentTimeMillis(); NotificationManager notificationManager = null; notificationManager(NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); Notification notification = new Notification(R.drawable.ic_launcher,message, when); String title = context.getString(R.string.app_name); Intent intent = // page suivante notification.setLatestEventInfo(context, title, message, intent); notification.flags |= Notification.FLAG_AUTO_CANCEL; notificationManager.notify(0, notification); }

29 Receiver, CGM et + 29 Autre exemple : une notification Au clic sur la notification une application est déclenchée private static void generateNotification(Context context, String message) { long when = System.currentTimeMillis(); NotificationManager notificationManager = null; notificationManager(NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); Notification notification = new Notification(R.drawable.ic_launcher,message, when); String title = context.getString(R.string.app_name); Intent notificationIntent = new Intent(context,GCMClientActivity.class); // afin que l’intent retardée démarre une nouvelle activité notificationIntent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_SINGLE_TOP); PendingIntent intent = PendingIntent.getActivity(context, 0, notificationIntent, 0); notification.setLatestEventInfo(context, title, message, intent); notification.flags |= Notification.FLAG_AUTO_CANCEL; notificationManager.notify(0, notification); } Source: http://android.amolgupta.in/2012/07/google-cloud-messaging-gcm-tutorial.htmlhttp://android.amolgupta.in/2012/07/google-cloud-messaging-gcm-tutorial.html

30 Receiver, CGM et + 30 Autre usage : une notification, sans effet au clic Au clic sur la notification rien ne se passe private static void generateNotification(Context context, String message) { long when = System.currentTimeMillis(); NotificationManager notificationManager = null; notificationManager(NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); Notification notification = new Notification(R.drawable.ic_launcher,message, when); String title = context.getString(R.string.app_name); PendingIntent intent = PendingIntent.getActivity(context, 0, null, 0); notification.setLatestEventInfo(context, title, message, intent); notification.flags |= Notification.FLAG_AUTO_CANCEL; notificationManager.notify(0, notification); } Source: http://android.amolgupta.in/2012/07/google-cloud-messaging-gcm-tutorial.htmlhttp://android.amolgupta.in/2012/07/google-cloud-messaging-gcm-tutorial.html

31 Receiver, CGM et + 31 Démonstration

32 Receiver, CGM et + 32 GCM Google Cloud Messaging –Anciennement c2dm, Cloud to Delivering Message >= Android 2.2 Message <= 4ko Trafic illimité –Nécessite une inscription auprès de Google Avec de préférence un compte gmail que l’on dédiera à cet usage

33 Receiver, CGM et + 33 Architecture : Objectifs Un client, tout système connecté –S’adresse au serveur Google qui se chargera de publier auprès des mobiles Mobiles ayant préalablement souscrits Mise en œuvre : une librairie toute prête, un appel de méthode suffit

34 Receiver, CGM et + 34 Architecture : Mise en œuvre, inscription Chaque participant –Doit avoir un compte google gmail –S’inscrit auprès de GCM, en retour un identifiant lui est attribué Un serveur mémorise, l’identifiant retourné par GCM –Un serveur au protocole HTTP de préférence –Ces serveur contient les abonnés 1)inscription 2)identifiant 3) dépôt de l’identifiant GCM

35 Receiver, CGM et + 35 Architecture : Mise en œuvre, inscriptions Le serveur contient une liste des identifiants Un identifiant par application –Application : un service sous Android Exemple : Une liste d’identifiants accessible depuis le web http://jfod.cnam.fr/registration/demo/?cmd=toString id1 id2 id3 …

36 Receiver, CGM et + 36 Architecture : Mise en œuvre, publications Publication par tout système connecté 1,2) Obtention de la liste des identifiants, des abonnés 3) Envoi de cette liste au serveur Google/GCM accompagnée du message à transmettre GCM se charge de publier le message, de le ré-émettre, de le conserver … 2) [id1, id2, id3, ……] 1) Demande de la liste 3) Demande de publication [id1, id2, id3, ……] + message id1 message id2 id3

37 Receiver, CGM et + 37 Architecture : publications Chaque mobile de la liste [id1, id2, id3, ……] est notifié –C’est un « Receiver » prêt à l’emploi qui est déclenché sur chaque mobile –Un service prêt à l’emploi est créé afin de prendre en compte cette notification Une de ses méthodes est appelée (onMessage) id1 message id2 id3

38 Receiver, CGM et + 38 Le tutorial que l’on se doit de lire http://developer.android.com/google/gcm/index.html https://cloud.google.com/console

39 Receiver, CGM et + 39 Comment ? Création d’un projet auprès des serveurs Google 1.https://code.google.com/apis/consolehttps://code.google.com/apis/console 2.En retour : un numéro_de_projet (ProjectId) 1.https://code.google.com/apis/console/#project:numéro_de_projethttps://code.google.com/apis/console/#project:numéro_de_projet 3.Une API key est nécessaire 1.Exemple ProjectId:138387916323, API_KEY: AIzaSyC60sIgG-fB3JSW47X2zGrOqJHGzV1jh0g 1.Un mobile s’inscrit auprès du serveur Google (ProjectId) 1.En retour un jeton d’identification lui est attribué Chaque participant doit posséder un compte gmail 2.Cet identifiant est déposé sur un serveur, qui est connu de tous les participants 2.Envoi d’un message aux participants(API_KEY) 1.Obtention de la liste des identifiants auprès du serveur 2.Publication du message Librairies toutes prêtes

40 Receiver, CGM et + 40 Création du projet https://code.google.com/apis/console/#project:138387916323 API_Key ProjectId

41 Receiver, CGM et + 41 Inscription, mise en oeuvre Depuis une activity –1) Inscription auprès du cloud GCMRegistrar.register(this, "138387916323"); –GCMRegistrar, une classe toute prête –Démarrage du service… –Attente asynchrone de la réponse de GCM 1)inscription 2)identifiant 3) dépôt de l’identifiant GCM

42 Receiver, CGM et + 42 Le service hérite d’une classe toute prête 4 méthodes à redéfinir, public class GCMIntentService extends GCMBaseIntentService { –Méthode déclenchée à la suite de la demande d’inscription au GCM –2) onRegistered(Context context, String identifiant) 3) Dépôt de l’identifiant sur un serveur –onMessage(Context context, Intent intent ) –onError …. –onUnregistered 1)inscription 2)identifiant 3) dépôt de l’identifiant GCM

43 Receiver, CGM et + 43 Liste des indentifiants Service web, servlette, php –http://jfod.cnam.fr/registration/demo/?cmd=toString 1)inscription 2)identifiant 3) dépôt de l’identifiant GCM id1 id2 id3 … id1 id2 id3 …

44 Receiver, CGM et + 44 Publication Envoi de la liste des identifiants au GCM + un message + API_KEY Et se charge de tout id1 message id3 id1 id2 id3 … API_KEY + Message + id1 message id2 id3

45 Receiver, CGM et + 45 Librairie toute prête \android-sdk\extras\google\gcm\gcm-client\dist\ –gcm.jar Souscription, abonnement –Un service qu’il suffit de dériver public class GCMIntentService extends GCMBaseIntentService { Réception d’un message : un Receiver + un service –Un Receiver prêt à l’emploi –Une classe GCMIntentBaseService qu’il suffit de dériver

46 Receiver, CGM et + 46 Démonstration, Obtention du jeton GCMRegistrar: Classe interface avec le service GCM ProjectId: 138387916323 1.GCMRegistrar.getRegistrationId(this, " 138387916323 "); Une demande est faite auprès de Google 2. onRegistered(Context context, String regId) –En retour cette méthode du service est déclenchée Un exemple d’identifiant reçu par le mobile: APA91bGy- GWQqqrgyFc652jghpTPygBsKyDHNFPWqzJDCMvtcIx7rtVecmxAYkDItfgztJcEJhyA Rnx0fmmp6FtqrFKNXqftmGXhRIGM5eObyLY67YkT_Aez3RJeOZFVkOpjv- _FRNASI0ZJL6VQk95Y925MQ9Wihw

47 Receiver, CGM et + 47 Souscription suite Souscription du mobile –Permissions –Le receveur, un extrait de AndroiManifest.xml –<receiver android:name=".C2DMRegistrationReceiver" android:permission="com.google.android.c2dm.permission.SEND" >

48 Receiver, CGM et + 48 Le service public class GCMIntentService extends GCMBaseIntentService –onRegistered(Context context, String regId) Déclenchée par le Receiver pré-installé à la suite de l’abonnement –Mémorisation de regId –onMessage(Context context, Intent intent ) Déclenchée par le Receiver pré-installé à la suite de la réception d’un message –String msg = intent.get( "message");

49 Receiver, CGM et + 49 Publication : le message Par tout système connecté, \android-sdk-new\extras\google\gcm\gcm-server\dist\ –gcm-server.jar Sender sender = new Sender(API_KEY); String msg = "un message"; Message message = new Message.Builder() //.collapseKey("1").timeToLive(60*60*24) // 24 heures //.timeToLive(0) // maintenant ou jamais.delayWhileIdle(true).addData("message",msg).build();

50 Receiver, CGM et + 50 Publication : Envoi de message Publication d’un message –Send devices : une liste de regId –MulticastResult result = sender.send(message, devices, 5); // 5 essais en cas d’indisponibilité des serveurs google –Ensuite le cloud s’occupe de tout …

51 Receiver, CGM et + 51 Une architecture possible, publication De type MVC … un essai pour discussions –Rappels: Hypothèse –Un receveur et un service prêts à l’emploi »Ce service est appelé à chaque publication par le cloud »onMessage, onRegistered, onUnregistered, onError –A chaque réception d’un message, envoi de celui-ci vers le receveur concerné Un champ du message contient l’ACTION à déclencher … Les receveurs peuvent être locaux à une activité, un service … publishonMessage(…) receveurs

52 Receiver, CGM et + 52 Réalisation, onMessage Émis directement au receveur concerné –intentToAnControler(intentFromCloud.getStringExtra(OPERATION_KEY));

53 Receiver, CGM et + 53 Réalisation, une variante onMessage Un contrôleur dédié au cloud est installé Il est chargé de générer un journal, d’effectuer des statistiques, de contrôler… publishonMessage(…) Receveur dédié au cloud Receveur associé à l’ACTION

54 Receiver, CGM et + 54 Publication, le contrôleur dédié au cloud pourrait s’en charger… Publication vers le GCM via le contrôleur PUBLISH ACTION Receveur dédié au cloud publish

55 Receiver, CGM et + 55 Une Application Une liste partagée

56 Receiver, CGM et + 56 Architecture MVC, rappel Application: –Une liste d’item : le modèle, du java standard, portable –ListView + ListActivity : la Vue –Un Receiver : le Contrôleur

57 Receiver, CGM et + 57 Android Les outils nécessaires Intent IntentFilter BroadcastReceiver –registerReceiver

58 Receiver, CGM et + 58 La vue, une liste d’items Affichage Opérations –d’ajout et de suppression

59 Receiver, CGM et + 59 La liste d’items Items : le modèle MainActivity : la vue ItemsController : le contrôleur Items extends Observable MainActivity extends ListActivity implements Observer ItemsControler extends BroadcastReceiver MainActivity extends ListActivity implements Observer ItemsController extends BroadcastReceiver le modèle la vue le contrôleur

60 Receiver, CGM et + 60 La classe Items : le modèle Java J2SE portable –synchronized(this) par précaution (plusieurs contrôleurs)

61 Receiver, CGM et + 61 Architecture suite Items : le modèle –extends java.util.Observable MainActivity : la vue –extends android.app.ListActivity implements java.util.Observer ItemsController : le contrôleur –extends android.content.BroadcastReceiver

62 Receiver, CGM et + 62 Le contrôleur est un BroadcastReceiver Items extends Observable MainActivity extends ListActivity implements Observer ItemsControler extends BroadcastReceiver MainActivity extends ListActivity implements Observer ItemsController extends BroadcastReceiver sendBroadcast A chaque Click  sendBroadcast Intent intent = new Intent(); intent.setAction(ItemsController.ACTION); … sendBroadcast(

63 Receiver, CGM et + 63 Action de l’utilisateur, gérée par le contrôleur sendBroadcast MainActivity extends ListActivity implements Observer ItemsControler extends BroadcastReceiver MainActivity extends ListActivity implements Observer ItemsController extends BroadcastReceiver sendBroadcast

64 Receiver, CGM et + 64 ItemsController A chaque « clic » la méthode onReceive est exécutée abortBroadcast(); si non cumul du comportement

65 Receiver, CGM et + 65 Contrôleur -> Modèle Appel de la méthode ajouter du modèle Items extends Observable ItemsControler extends BroadcastReceiver ItemsController extends BroadcastReceiver

66 Receiver, CGM et + 66 Modèle -> Vue La méthode update est déclenchée au sein de l’activité Items extends Observable MainActivity extends ListActivity implements Observer

67 Receiver, CGM et + 67 La Vue 1 /4 initialisation onCreate de l’activité –Création du modèle et du contrôleur

68 Receiver, CGM et + 68 La Vue 2 /4 enregistrement du contrôleur onResume de l’activité (ou onCreate, dépend de l’application) –enregistrement du contrôleur onPause (ou onDestroy)

69 Receiver, CGM et + 69 La Vue 3 /4 A chaque clic ! onClickAjouter

70 Receiver, CGM et + 70 La Vue 4 /4 update update appelée par le modèle –(extends Observable) –La vue est un observateur( implements java.util.Observer)

71 Receiver, CGM et + 71 CloudController Généralisation, discussions

72 Receiver, CGM et + 72 MVC MVC respecté Couplage faible conservé Au sein de la même application Items extends Observable MainActivity extends ListActivity implements Observer MainActivity extends ListActivity implements Observer ItemsController extends BroadcastReceiver CloudController AnotherActivity extends Activity implements Observer web, cloud ItemsController extends BroadcastReceiver

73 Receiver, CGM et + 73 Généralisation Le champ Action sélectionne le contrôleur ad’hoc MVC respecté Couplage faible conservé Items extends Observable MainActivity extends ListActivity implements Observer MainActivity extends ListActivity implements Observer ItemsController extends BroadcastReceiver GenericController AnotherActivity extends Activity implements Observer web, cloud

74 Receiver, CGM et + 74 GenericController L’ACTION_KEY est redirigée vers le « bon » contrôleur Discussion ItemsController extends BroadcastReceiver GenericController

75 Receiver, CGM et + 75 Cumul du comportement Avec une sous classe de ItemsController: ItemsControllerPlus @Override onReceive(Context context, Intent intent){ super.onReceive(context, intent); … ItemsController extends BroadcastReceiver ItemsControllerPlus extends ItemsController

76 Receiver, CGM et + 76 Démonstration

77 Receiver, CGM et + 77 Mise en œuvre Répertoire du projet eclipse du client souscripteur Depuis l’explorateur windows, (eclipse n’est pas démarré) créer un répertoire libs dans lequel vous copiez gcm.jar libs>copy D:\android-sdk\extras\google\gcm\gcm-client\dist\gcm.jar. Répertoire du projet eclipse du client « publieur » Depuis l’explorateur windows, (eclipse n’est pas démarré) créer un répertoire libs dans lequel vous copiez gcm-server.jar libs>copy D:\android-sdk\extras\google\gcm\gcm-server\dist\gcm-server.jar.. Si bluej, installez gcm-server.jar dans le répertoire +libs A l’exécution json est requis D:\android-sdk\extras\google\gcm\gcm-server\lib\ json_simple-1.1.jar

78 Receiver, CGM et + 78 Conclusion Simple Push/polling (voir en annexe) … Indispensable Note: Sous eclipse dans le projet créez un dossier libs –Dans lequel sont copiés : gcm.jar pour souscrire gcm-server.jar et json-simple-1.1.jar pour publier

79 Receiver, CGM et + 79 Annexe consommation en « polling »


Télécharger ppt "Receiver, CGM et + 1 Android Publish/Subscribe, GCM, Google Cloud Messaging : une introduction Notes de cours jean-michel Douin, douin au cnam point fr."

Présentations similaires


Annonces Google