Un service est une composante essentielle d’une application. Il est nécessaire lorsque votre application souhaite effectuer des opérations ou des calculs en dehors de l’interaction utilisateur. Donc comme vous l’aurez compris un service ne dispose pas d’interface graphique.
Rien de mieux qu’un exemple, votre lecteur de musique vous permet d’écouter la musique tout en surfant sur internet, lisant vos mails et cette fonctionnalité n’est possible qu’à l’aide des services.
Il existe deux types de services :
- LocalService : Services qui s’exécutent dans le même processus que votre application.
- RemoteService : Ils s’exécutent dans des processus indépendants de votre application.
Cycle de vie d’un service
Un service n’a pas de durée définie , il est là pour exécuter sa tâche et il fonctionnera tant que c’est nécessaire.
On va présenter les différentes méthodes qui correspondent au cycle de vie d’un service. Ces méthodes seront à surcharger quand vous créerez votre service :- OnCreate() : Cette méthode est appelée à la création du service et est en général utilisée pour initialiser ce qui sera nécessaire à votre service.
- OnStart(Intent i) : Le service démarre. Valable uniquement pour les versions du SDK inférieur à 2.0.
- OnStartCommand(Intent i, int flags, int startId) : Le service démarre. Valable uniquement pour les versions du SDK supérieur à 2.0.
- OnDestroy() : Appelé à la fermeture du service.
Mon premier Service
Nous allons faire un exemple pour mieux comprendre, dans ce dernier nous allons créer un service qui affichera un toast contenant les coordonnées du téléphone. Le toast s’affichera quand les coordonnées seront mises à jour.
Nous allons créer un projet qui s’appellera MonPremierService, avec la version 2.1 du SDK.
- Nom de l’application : Mon Premier Service
- Package : com.tuto.android
- Activité : HomeActivity
Dans notre classe HomeActivity, nous allons juste créer un bouton qui lancera le servicequand on cliquera dessus :
Dans le fichier main.xml, on met le code suivant :
1 2 3 4 5 6 7 8 9 10 11 12 13 | <? xml version = "1.0" encoding = "utf-8" ?> android:orientation = "vertical" android:layout_width = "fill_parent" android:layout_height = "fill_parent" > < Button android:layout_width = "fill_parent" android:layout_height = "wrap_content" android:text = "@string/btn1" android:id = "@+id/serviceBtn" /> </ LinearLayout > |
et voici le code à mettre dans l’activité correspondante
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | package com.tuto.android; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; public class HomeActivity extends Activity { @Override public void onCreate(Bundle savedInstanceState) { super .onCreate(savedInstanceState); setContentView(R.layout.main); Button serviceBtn = (Button) findViewById(R.id.serviceBtn); serviceBtn.setOnClickListener( new OnClickListener() { @Override public void onClick(View actuelView) { startService( new Intent(HomeActivity. this , MonPremierService. class )); } }); } } |
Passons à notre service, pour le créer il suffit d’implémenter une classe qui hérite de la classe Service. Voici notre exemple :
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 | package com.tuto.android; import android.app.Service; import android.content.Context; import android.content.Intent; import android.location.Location; import android.location.LocationListener; import android.location.LocationManager; import android.os.Bundle; import android.os.IBinder; import android.widget.Toast; public class MonPremierService extends Service { private LocationManager locationMgr = null ; private LocationListener onLocationChange = new LocationListener() { @Override public void onStatusChanged(String provider, int status, Bundle extras) { } @Override public void onProviderEnabled(String provider) { } @Override public void onProviderDisabled(String provider) { } @Override public void onLocationChanged(Location location) { Double latitude = location.getLatitude(); Double longitude = location.getLongitude(); Toast.makeText(getBaseContext(), "Voici les coordonnées de votre téléphone : " + latitude + " " + longitude, Toast.LENGTH_LONG).show(); } }; @Override public IBinder onBind(Intent arg0) { return null ; } @Override public void onCreate() { locationMgr = (LocationManager) getSystemService(Context.LOCATION_SERVICE); locationMgr.requestLocationUpdates(LocationManager.NETWORK_PROVIDER, 10000 , 0 , onLocationChange); locationMgr.requestLocationUpdates(LocationManager.GPS_PROVIDER, 10000 , 0 , onLocationChange); super .onCreate(); } @Override public int onStartCommand(Intent intent, int flags, int startId) { return super .onStartCommand(intent, flags, startId); } @Override public void onDestroy() { super .onDestroy(); locationMgr.removeUpdates(onLocationChange); } |
- Dans le OnCreate, On s’abonne au changement de géolocalisation, et dans le OnDestroy on se désabonne.
- On crée une instance de la classe LocationListener, pour récupérer les nouvelles coordonnées.
- Dans la méthode OnLocationChanged, on affiche les coordonnées à l’aide d’un Toast.
- La méthode onBind sert quand on veut faire communiquer le service avec un autre service, ou avec une activité ..etc.
Pour finir il faut déclarer le service dans le fichier AndroidManifest.xml, dans la partie Application
1 | < service android:name = "com.tuto.android.MonPremierService" /> |
sans oublier les permissions suivantes :
1 2 3 4 5 | < uses-permission android:name = "android.permission.INTERNET" /> < uses-permission android:name = "android.permission.ACCESS_FINE_LOCATION" /> < uses-permission android:name = "android.permission.ACCESS_GPS" /> < uses-permission android:name = "android.permission.ACCESS_ASSISTED_GPS" /> < uses-permission android:name = "android.permission.LOCATION" /> |
Ce qui donnera
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | <? xml version = "1.0" encoding = "utf-8" ?> package = "com.tuto.android" android:versionCode = "1" android:versionName = "1.0" > < application android:icon = "@drawable/icon" android:label = "@string/app_name" > < activity android:name = ".HomeActivity" android:label = "@string/app_name" > < intent-filter > < action android:name = "android.intent.action.MAIN" /> < category android:name = "android.intent.category.LAUNCHER" /> </ intent-filter > </ activity > < service android:name = "com.tuto.android.MonPremierService" /> </ application > < uses-permission android:name = "android.permission.INTERNET" /> < uses-permission android:name = "android.permission.ACCESS_FINE_LOCATION" /> < uses-permission android:name = "android.permission.ACCESS_GPS" /> < uses-permission android:name = "android.permission.ACCESS_ASSISTED_GPS" /> < uses-permission android:name = "android.permission.LOCATION" /> </ manifest > |
sans oublier le fichier strings.xml
1 2 3 4 5 | <? xml version = "1.0" encoding = "utf-8" ?> < resources > < string name = "btn1" >Lancer le service de géolocalisation</ string > < string name = "app_name" >Mon Premier Service</ string > </ resources > |
Donc pour tester il suffit de :
- Lancer sur le projet.
- Cliquer sur le bouton.
- Mettre à jour les coordonnées de géolocalisation.
- Un Toast devrait apparaitre avec les coordonnées de géolocalisation
Voilà ce que vous devez obtenir :
Sur l’image çi-dessous, on voit bien que le service est lancé (propriétés applications dans les paramètres du téléphones).
Conclusion
Voilà ce tutoriel se finit ici, en espérant qu’il vous a aidé à comprendre comment fonctionne les services sous android.
0 commentaires:
Enregistrer un commentaire