Activity et Intent


HĂ©las, la VF n’est pas très Ă  jour.

Ce cours étant désormais enseigné en anglais, vous êtes invité à consulter cette version


Objectifs

L’objectif de ce travail pratique est de dĂ©couvrir Ă  relier plusieurs Activity en utilisant des Intents.

Nous allons continuer à développer le projet commencé la dernière fois.

Dans ce TP, nous allons crĂ©er une interface très basique pour renseigner les taux d’Ă©change : nous allons rajouter un nouveau bouton Ă  notre Activity pour lancer un nouvel Activity qui affiche des taux d’Ă©change chargĂ©s d’un service. (En fait, dans un premier temps, nous allons utiliser un fichier JSON câblĂ© en dur dans notre application.)

Ceci n’est pas forcĂ©ment l’interface la plus Ă©lĂ©gante, mais elle va nous donner un peu d’expĂ©rience avec des Activity et Intent. Nous allons garder l’interface de la dernière fois en y rajouter un bouton pour configurer le taux. Lorsque l’utilisateur tape ce bouton, on passera Ă  une nouvelle Activity pour choisir le monnaies et donc configurer automatiquement le taux.

Ce nouveau CurrencyChooserActivity (ou quelque chose dans l’idĂ©e) prĂ©sentera deux colonnes de radio boutons: la monnaie source, et la monnaie cible. Voici un exemple :

Layout simple : Currency Converter

Pour vous aider Ă  crĂ©er ce genre de layout, n’oubliez pas :

  • Un RadioButton est une sous-classe de Button
  • Un RadioButton doit forcĂ©ment ĂŞtre dans un RadioGroup
  • Un RadioGroup est une sous-classe de LinearLayout (vertical par dĂ©faut)
  • Vous pouvez consulter le TP prĂ©cĂ©dant pour vous rappeler de la crĂ©ation des rangs et colonnes, des boutons et des champs de texte.

Créer un nouvel Activity

Rajoutez un nouvel Activity Ă  votre projet (e.g., avec File -> New …). On peut l’appeler CurrencyChooserActivity. Dans son layout XML, crĂ©er l’interface pour votre chooser, dans l’esprit de l’interface dessus.

Charger le JSON

Dans un premier temps, nous allons rajouter les taux de conversion directement dans notre application. Évidement, ces taux évoluent, nous allons ultérieurement les charger par les interwebs.

Rajouter les taux comme ressource

TĂ©lĂ©chargez ce fichier et le mettez comme ressource raw dans votre projet. Pour faire cela, il faudra crĂ©er un nouveau dossier de ressources pour ce genre de donnĂ©es qu’utilisera l’application. Faites un clic-droite sur le dossier res (dans l’arborescence du projet, Ă  gauche), puis choisissez New → Android resource directory. Dans la fenĂŞtre qui s’affiche, changer le resource type en raw, puis faites OK.

Nous avons maintenant un dossier pour des ressources raw oĂą on peut mettre des fichiers qui serons mis dans notre application lorsque Android Studio le compile. Lorsque l’application tourne, on pourrait utiliser la classe magique R pour faire rĂ©fĂ©rence Ă  ces fichiers ainsi : R.raw.nom_du_fichier. Il ne suffit que de mettre le fichier qu’on a tĂ©lĂ©chargĂ© dans ce dossier.

Nous allons par la suite Ă©crire une mĂ©thode qui cherchera ce fichier JSON pour le charger et convertir en JSONObject qu’on peut utiliser dans notre app. CrĂ©ez une mĂ©thode pour charger le fichier JSON. Ce code pour crĂ©er une chaine de caractères avec les contenus d’un fichier vous pourriez ĂŞtre utile :


    InputStream inputStream = getResources().openRawResource(R.raw.taux_2017_11_02);
    StringBuilder stringBuilder = new StringBuilder();
    try (BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream))) {
        String line = null;
        while ((line = reader.readLine()) != null) {
            stringBuilder.append(line + "\n");
        }

        String jsonString = stringBuilder.toString();
        return new JSONObject(jsonString);
    } catch (IOException e) {
        System.err.println("Warning: could not read rates: " + e.getLocalizedMessage());
    } catch (JSONException e) {
        System.err.println("Warning: could not parse rates: " + e.getLocalizedMessage());
    }

    return null;

Nous allons charger ce fichier lorsque la CurrencyChooserActivity se lance. Quelle mĂ©thode avons-nous vu en cours pour faire quelque chose lorsque l’activitĂ© est lancĂ©e ?

Relier les deux Activity

Connecter les boutons au code pour renvoyer de notre Activity le taux d’Ă©change sĂ©lectionnĂ© par l’utilisateur. Si rates est un JSONObject crĂ©Ă© Ă  partir du fichier ci-dessus, vous pourriez utiliser rates.getJSONObject("rates").getDouble("GBP") en supposant que rates est le JSONObject rĂ©fĂ©rencĂ© ci-dessus.

Charger les taux dynamiquement

Les taux de change Ă©voluent, les mettre en dur n’est sĂ»rement pas la bonne stratĂ©gie. On pourrait utiliser un service comme openexchangerates pour charger les taux Ă  jour, et vous pouvez le faire si vous voulez crĂ©er une compte. Mais dans cet exercice, nous allons simuler ce genre de service en chargeant les taux directement du serveur web local de l’Ă©cole. Ce fichier sera toujours le mĂŞme, mais on n’aura pas besoin d’une inscription Ă  OpenExchangeRates (la source, d’ailleurs, du fichier qu’on utilise ici).

Charger d’une page web versus d’un fichier local en Java est très simple :


    URL exchangeRatesURL = new URL("https://.../rates.json");
    InputStream inputStream = exchageRatesURL.openStream();

Modifiez votre chargement du fichier JSON ainsi (en mettant bien sĂ»r le bon URL) pour voir qu’en fait, c’Ă©tait trop simple.

Qu’est-ce que vous remarquez ?

En fait, toute action par internet est interdit Ă  partir du fil d’exĂ©cution principal.

Utiliser AsyncTask

Nous allons utiliser AsyncTask pour gerer cela. Pour faire cela, il suffit de crĂ©er un AsyncTask qui va lancer le chargement du JSON. Une fois chargĂ©, la tâche pourrait mettre Ă  jour l’interface (e.g. en activant le bouton convert (setEnabled(true))). Consulter les transparents du cours ou la documentation sur AsyncTask

Rendu

Peaufinez votre solution, puis mettez votre projet dans un fichier zip et déposez-le sur le site du dépôt avant “minuit” de la date affichée. Il sera noté sur un schéma bonus-malus. (NB : “minuit” veut dire avant que je ne télécharge les projets le lendemain matin.)