Logo ÉTS
Session
Cours
Responsable(s) Abdelmoumène Toudeft

Se connecter
 

Sauvegarde réussie
Echec de sauvegarde
Avertissement
École de technologie supérieure

Responsable(s) de cours : Abdelmoumène Toudeft


PLAN DE COURS

Hiver 2024
TCH057 : Applications mobiles et expérience usager (3 crédits)





Préalables
Aucun préalable requis
Unités d'agrément
Données non disponibles




Qualités de l'ingénieur

Qn
Qualité visée dans ce cours  
Qn
  Qualité visée dans un autre cours  
  Indicateur enseigné
  Indicateur évalué
  Indicateur enseigné et évalué



Descriptif du cours

Cours offert à compter de la session d'automne 2023.
Ce cours ne peut être reconnu dans le cadre d’un programme de baccalauréat.

Ce cours vise l'initiation au développement d’applications mobiles et à la création d’une interface usager.

Au terme de ce cours, l’étudiant ou l'étudiante sera en mesure :

  • de distinguer les différents éléments qui constituent une interface usager (conteneurs, boutons, zones de saisie, etc.);
  • de réaliser le prototypage rapide d’interfaces usager aux fins de tests d’utilisabilité en sachant exploiter un concepteur d’interface et en reconnaissant ses limites;
  • d'implémenter une application mobile munie d’une interface usager adéquate et exploitant les interfaces programmatiques (API) de la plateforme;
  • de gérer les données au sein d’une application mobile;
  • de tester, déployer et publier une application mobile dans une plateforme de distribution.

Développement d’applications pour périphériques mobiles. Caractéristiques et l’architecture de base d’une application mobile. Éléments d’une interface usager. Principes de base de conception d’une interface usager telles que la capacité apprenante (learnability), la prévention d’erreurs et l’efficacité. Notions émergentes d’expérience usager et d’interfaces usager inclusives.

Ce cours comporte un projet de session, réalisé en équipes, lors duquel les étudiants seront amenés à développer une application mobile munie d’une interface usager adéquate




Objectifs du cours

Ce cours initie au développement d'applications mobiles et au domaine de l'expérience utilisateur (UX).

De manière plus spécifique, ce cours a pour objectifs de permettre à l'étudiante ou l'étudiant de :

  • Décrire les caractéristiques du monde des applications mobiles et du développement mobile;
  • Exploiter un environnement de développement et de dépoiement pour le mobile;
  • Exploiter les possibilités offertes par une technologie mobile pour programmer correctement les écrans d'une application;
  • Mettre en place une architecture d'application respectant les standards;
  • Programmer les fonctionnalités d'une application;
  • Programmer les accès à des données locales et distantes;
  • Rendre fonctionnelle une application en gérant les événements en réponse aux actions de l'utilisateur;
  • Gérer les permissions d'une application; 
  • Mettre en oeuvre les principes du design d'interfaces et de l'expérience utilisateur lors de la conception des écrans d'une application;
  • Exploiter les possibilités d'un outil de conception d'interfaces;
  • Expliquer l'importance et le rôle de l'expérience utilisateur (UX) dans les applications d'aujourd'hui;
  • Mettre en œuvre les pratiques qui permettent une bonne expérience utilisateur;
  • Appliquer les règles ergonomiques et évaluer l'ergonomie d'une interface personne-machine.



Stratégies pédagogiques

Le cours allie théorie et pratique. Les notions et concepts sont expliqués lors des séances de cours, appuiés par des exemples et des études de cas. Les séances de laboratoire sont utilisées pour la mise en pratique des apprentissages.




Utilisation d’appareils électroniques

Les étudiantes et étudiants utiliseront des émulateurs pour exécuter les applications. S'ils le veulent, ils peuvent exécuter les applications sur leurs appareils cellulaires et tablettes lors des laboratoires.




Horaire
Groupe Jour Heure Activité
01 Lundi 13:30 - 17:00 Activité de cours
Mercredi 08:15 - 10:15 Travaux pratiques (Groupe A)
Mercredi 10:30 - 12:30 Travaux pratiques (Groupe B)
02 Lundi 08:15 - 10:15 Travaux pratiques (Groupe A)
Lundi 10:30 - 12:30 Travaux pratiques (Groupe B)
Mardi 13:30 - 17:00 Activité de cours
03 Mercredi 13:30 - 15:30 Travaux pratiques (Groupe A)
Mercredi 15:45 - 17:45 Travaux pratiques (Groupe B)
Vendredi 09:00 - 12:30 Activité de cours
04 Mercredi 09:00 - 12:30 Activité de cours
Jeudi 08:15 - 10:15 Travaux pratiques (Groupe A)
Jeudi 10:30 - 12:30 Travaux pratiques (Groupe B)
05 Mardi 13:30 - 17:00 Activité de cours
Vendredi 08:15 - 10:15 Travaux pratiques (Groupe A)
Vendredi 10:30 - 12:30 Travaux pratiques (Groupe B)



Coordonnées de l’enseignant
Groupe Nom Activité Courriel Local Disponibilité
01 Naïm Himrane Activité de cours naim.himrane@etsmtl.ca
01 Naïm Himrane Travaux pratiques (Groupe A) naim.himrane@etsmtl.ca
01 Antoine Boucher Travaux pratiques (Groupe B) antoine.boucher.1@ens.etsmtl.ca
02 Abdelmoumène Toudeft Activité de cours Abdelmoumene.Toudeft@etsmtl.ca B-1642
02 Abdelmoumène Toudeft Travaux pratiques (Groupe A) Abdelmoumene.Toudeft@etsmtl.ca B-1642
02 Francis Bourdeau Travaux pratiques (Groupe B) Francis.Bourdeau@etsmtl.ca
03 Mirna Awad Activité de cours cc-Mirna.Awad@etsmtl.ca
03 Mirna Awad Travaux pratiques (Groupe A) cc-Mirna.Awad@etsmtl.ca
03 Othmane Karamat Travaux pratiques (Groupe B) othmane.karamat.1@ens.etsmtl.ca
04 Toufik Bellal Activité de cours toufik.bellal@etsmtl.ca B-2568
04 Toufik Bellal Travaux pratiques (Groupe A) toufik.bellal@etsmtl.ca B-2568
04 Othmane Karamat Travaux pratiques (Groupe B) othmane.karamat.1@ens.etsmtl.ca
05 Naïm Himrane Activité de cours naim.himrane@etsmtl.ca
05 Naïm Himrane Travaux pratiques (Groupe A) naim.himrane@etsmtl.ca
05 Othmane Karamat Travaux pratiques (Groupe B) othmane.karamat.1@ens.etsmtl.ca
05 Antoine Boucher Travaux pratiques (Groupe B) antoine.boucher.1@ens.etsmtl.ca



Cours

 

Notez Bien :

  • La première période de trois heures sert aussi à présenter le plan de cours, l’approche pédagogique utilisée et les différents modèles d’évaluation. 
  • L'ordre de présentation peux varier selon l'enseignante ou l'enseignant.
  • Une bonne partie du contenu de ce cours sera réinvestie par l'étudiante ou l'étudiant lors de la deuxième moitié de la session dans le cours TCH099 Projet intégrateur en informatique.

 

Semaine

MATIÈRE

      1

  • Présentation du cours : plan de cours, stratégies pédagogiques, évaluations, ...
  • Environnement de programmation Android Studio : téléchargement et installation.
  • Survol de l'environnement de programmation.
  • Notions nécessaires avant de commencer le développement mobile - éléments de programmation orientée objet et syntaxe Java :
    • Classes et objets;
    • Attributs et méthodes;
    • Héritage par extension (extends);
    • Redéfinition (override);
    • Interface et implémentation (implements).

Module 1 : Notions fondamentales en développement mobile

      2 - 4

  • Introduction au monde du développement mobile :
    • Caractéristiques, spécificités et contraintes;
    • Plateformes et technologies;
    • Types d'applications (natives, web, hybrides).
  • La plateforme Android;
  • Création d'une application;
  • Structure d'une application;
  • Cycle de vie d'une application;
  • Composants fondamentaux :
    • Vues (View);
    • Activités;
    • Intentions (Intent);
    • Fournisseurs de contenu;
    • Services;
    • Récepteurs de diffusion (Broadcast Receiver);
    • Le manifeste.
  • Activités;
  • États et cycle de vie d'une activité;
  • Principes fondamentaux :
    • Interfaces utilisateurs et XML;
    • Mécanisme de gestion des événements;
    • Ressources.
  • Déploiement et exécution d'une application;
  • Emulateurs (AVD);
  • Intentions et permissions;
  • Navigation entre les écrans d'une application;
  • Composants (View) de base : boutons, champs de texte, étiquettes,...

Module 2 : Interfaces Personne-Machine et UX

   5 - 7

  • Vues (View) et dispositions (LinearLayout, RelativeLayout, GridLayout,...);
  • Conception d'une interface utilisateur;
  • Listes et adaptateurs;
  • Design d'interfaces utilisateurs : règles de design, critères ergonomiques, ...
  • Introduction à l'expérience utilisateur (UX);
  • Exploitation d'un outil de conception d'interfaces utilisateur (exemples : Figma, Balsamiq,...).
    8  Examen Intra : Contenu des semaines 1 à 7

Module 3 : Développement d'applications

9-13

  • Interaction avec un serveur externe (exemple : un serveur JSON ou une API REST).
  • Accès réseau et requêtes asynchrones.
  • Traitement de données JSON.
  • Aspects architecturaux (MVC et variantes).
  • Patrons de conception pour le mobile : Singleton, DAO,...
  • Fournisseurs de contenu.
  • Bases de données (SQLite).
    • Création;
    • Exploitation;
    • Mise à jour de la structure.
  • Divers :
    • Services de localisation et Google maps;
    • Caméra;
    • ...

 Examen final

 Contenu de toute la session.




Laboratoires et travaux pratiques

Chaque semaine, un laboratoire permet de mettre en pratique la matière de la semaine et de l'intégrer aux apprentissages des semaines précédentes.

Deux laboratoires notés permettent d'intégrer ensemble les apprentissages des modules 1 et 2, respectivement.

Un projet de session permet d'intégrer ensemble tous les apprentissages du cours.




Utilisation d'outils d'ingénierie

S.O.




Évaluation
Évaluation Pondération Semaine

Examen intra
(3 heures)

20 %

8

Laboratoire noté 1

10 %

5

Laboratoire noté 2

10 %

10

Projet de session

20 %

Toute la session (remise en fin de session)

Examen final
(3 heures)

40%

Période des examen finaux

 

Les évaluations effectuées en classe pour lesquelles l’entraide n’est pas permise, notamment l’examen intra et l’examen final, sont considérées comme étant individuelles. Toutes autres évaluations pour lesquelles l’entraide entre étudiantes et étudiants est possible qu'elles aient lieu en classe ou non, et ce même si une remise par étudiante ou étudiant est exigée, sont considérées comme étant en équipe.

À propos du projet de session :

  • Le projet de session est commun à tous les groupes et vise à mettre en application, dans le cadre d'un problème réaliste, les apprentissages acquis dans le cours. Il est attendu des étudiant.es de produire des travaux qui permettent de résoudre le problème de l'énoncé mais surtout de les réaliser selon les standards de qualité et les bonnes pratiques enseignés (respect des normes de codage, mise en place d'une architecture standard,...).
  • Le projet de session se fera en équipes de 2 à 3 personnes. Une équipe ne doit remettre qu’un seul travail.
  • L'utilisation de Git et Github est fortement recommandée. Elle peut être exigée par l'enseignante ou l'enseignant.
  • Il est à noter que pour les travaux en équipe, chaque membre recevra une note inférieure ou égale à la note obtenue par l'équipe. Cette note individuelle est directement proportionnelle à l'implication de l'individu. La méthode d’évaluation de l’implication de chaque individu est laissée à la discrétion de l’enseignant.

À propos des laboratoires notés :

  • Les laboratoires notés ont lieu en présence et sont remis à la fin de la séance du laboratoire.

  • Le laboratoire noté 1 porte sur le module 1 du cours et consiste à développer une application mobile intégrant l'ensemble des apprentissages acquis dans le module.

  • Le laboratoire noté 2 porte sur le module 2 du cours et consiste à réaliser le design d'une application mobile intégrant l'ensemble des apprentissages acquis dans le module.

À propos de l'examen intra :

  • L'examen intra a lieu en présence.

À propos de l'examen final :

  • L'examen final a lieu en présence.
  • Aucune documentation et aucun accès Internet ne sont permis.
  • L'énoncé de l'examen final sera distribué en format papier aux étudiantes et étudiants qui donneront leurs réponses sur Enaquiz.

Double seuil : 

  • Une note moyenne pondérée de 50 % est exigée pour l’ensemble des évaluations à caractère individuel. Ce seuil est une condition nécessaire à la réussite du cours mais ne la garantit pas.

À propos de la langue utilisé

  • Afin de respecter les exigences relatives à la langue française telles que stipulées à la Politique linguistique de l’École, le code et les commentaires de code doivent être principalement en français tel que c'est le cas pour tous les exemples et documents qui seront fournis aux étudiantes et étudiants.



Double seuil
Note minimale : 50



Dates des examens intra
Groupe(s) Date
1 26 février 2024
2, 5 27 février 2024
3 23 février 2024
4 28 février 2024



Date de l'examen final
Votre examen final aura lieu pendant la période des examens finaux, veuillez consulter l'horaire à l'adresse suivante : http://etsmtl.ca/Etudiants-actuels/Baccalaureat/Examens-finaux


Politique de retard des travaux
Tout travail (devoir pratique, rapport de laboratoire, rapport de projet, etc.) remis en retard sans motif valable, c’est-à-dire autre que ceux mentionnés dans le Règlement des études (1er cycle, article 7.2.7 b / cycles supérieurs, article 6.5.4 b) se verra attribuer la note zéro, à moins que d’autres dispositions ne soient communiquées par écrit par l’enseignant dans les consignes de chaque travail à remettre ou dans le plan de cours pour l’ensemble des travaux.



Absence à un examen
Dans les cinq (5) jours ouvrables suivants, la tenue de son examen, l’étudiant devra justifier son absence d’un examen durant le trimestre auprès de la coordonnatrice – Affaires départementales qui en référera au directeur du département ou du SEG. Pour un examen final, l’étudiant devra justifier son absence auprès du Bureau du registraire. Dans tous les cas, l’étudiant doit effectuer sa demande en complétant le formulaire prévu à cet effet qui se trouve dans son portail Mon ÉTS/Formulaires. Toute absence non justifiée par un motif majeur (maladie certifiée par un billet de médecin, décès d’un parent immédiat, Activité compétitive d’un étudiant appartenant à un club scientifique ou un club sportif d’élite de l’ÉTS ou au programme « Alliance sport étude » ou autre) à un examen entraînera l’attribution de la note zéro (0).



Infractions de nature académique
À l’ÉTS, le respect de la propriété intellectuelle est une valeur essentielle et les étudiants sont invités à consulter la page "Citer, pas plagier !" (https://www.etsmtl.ca/Etudes/citer-pas-plagier). Les clauses du règlement sur les infractions de nature académique de l’ÉTS (« Règlement ») s’appliquent dans ce cours ainsi que dans tous les cours du département. Les étudiants doivent consulter le règlement sur les infractions de nature académique (https://www.etsmtl.ca/docs/ETS/Gouvernance/Secretariat-general/Cadre-reglementaire/Documents/Infractions-nature-academique) pour identifier les actes qui constituent des infractions de nature académique au sens du Règlement ainsi que prendre connaissance des sanctions prévues à cet effet.

Systèmes d’intelligence artificielle générative (SIAG)
L’utilisation des systèmes d’intelligence artificielle générative (SIAG) dans les activités d’évaluation constitue une infraction de nature académique au sens du Règlement sur les infractions de nature académique, sauf si elle est explicitement autorisée par l’enseignant(e) du cours.



Documentation obligatoire

Aucune référence obligatoire.




Ouvrages de références
  • Développement mobile pour Android en Java :
    • Android Programming : The Big Nerd Ranch Guide, Bryan Sills & al., Addison-Wesley Professional, 2022, ISBN : 978-0-13764-554-1.
    • Android Programming for Beginners, 3d edition, John Horton, Packt Publishing, 2021, ISBN : 978-1-80056-343-8.
  • Interfaces Personne-Machine et UX :
    • UX Design et ergonomie des interfaces, 7e édition, Jean-François Nogier, Dunod, 2020, ISBN: 978-2-10-080696-6.
    • Méthodes de design UX : 30 méthodes fondamentales pour concevoir des expériences optimales, Carine Lallemand et Guillaume Gronier, Eyrolles, 2018, ISBN : 978-2-212-67398-2.



Adresse internet du site de cours et autres liens utiles