Serious game pour apprendre à coder en Python (une aventure à coder sur Mars)
Go to file
2022-11-26 00:45:38 +00:00
asset Supprimé asset/icons/hud/icon_store.FCStd1, asset/icons/hud/icon_battery.FCStd1 2022-11-26 00:45:38 +00:00
img Ajout de l'icone de l'application 2022-11-26 01:40:34 +01:00
twins Coquille dans commentaire 2022-11-13 05:28:08 +01:00
LICENSE Autonomisation du projet 2022-02-24 11:48:12 +01:00
README.md Mettre à jour README.md 2022-11-24 10:07:47 +00:00
ropy-27.blend Ajout de l'animation du forage 2022-10-08 11:35:45 +02:00
ropy-28.blend Ajout du jumeau numérique 2022-11-02 19:21:27 +01:00
ropy-29.blend Bugfix : la plupart des traces de l'aide ont été enlevées, mais il en reste encore. 2022-11-14 04:17:47 +01:00
ropy-30.blend Bugfix : affichage du texte de la documentation : duplication complète des objets 2022-11-25 18:07:23 +01:00
ropy-31.blend Invisibilisation des boutons < et > en fonction de la taille de l'écran 2022-11-26 01:29:27 +01:00
ropy.svg Ajout de l'icone de l'application 2022-11-26 01:40:34 +01:00
rp_about.py Invisibilisation des boutons < et > en fonction de la taille de l'écran 2022-11-26 01:29:27 +01:00
rp_cmd.py Ajout du relais : télécommande -> ropy 2022-11-13 05:23:14 +01:00
rp_config.xml Bugfix : affichage du texte de la documentation : duplication complète des objets 2022-11-25 18:07:23 +01:00
rp_doc.py Bugfix : affichage du texte de la documentation : mise en cache du texte 2022-11-25 18:51:13 +01:00
rp_lib.py Bugfix : affichage du texte de la documentation : duplication complète des objets 2022-11-25 18:07:23 +01:00
rp_map1.py Bugfix : la plupart des traces de l'aide ont été enlevées, mais il en reste encore. 2022-11-14 04:17:47 +01:00
rp_store.py Ajout des programmes des cartes micro:bit pour le jumeau numérique Maqueen 2022-11-04 16:30:35 +01:00
rp.py Invisibilisation des boutons < et > en fonction de la taille de l'écran 2022-11-26 01:29:27 +01:00

Ropy

Discover Python with Ropy (coding adventure)
Découvre le Python avec Ropy (code ton aventure)

Ropy est un rover martien qui se programme en Python. Les aventures de Ropy permettent la découverte de la programmation procédurale et du language Python. A travers les différents missions, donc de manière graduée, les élèves vont apprendre à manipuler les structures algorithmiques et à les coder en Python.

Ropy présentation

Poster

Ropy a fortement été inpiré par RobotProg et Light Bot.

Ce jeu sérieux fait partie du projet open source Blender-EduTech (Blender/UPBGE pour l'Enseignement Technologique).

Téléchargement

Les binaires (Game Engine Runtime) sont hébergés sur phroy.org.

Instructions et missions

Le script Python qui permet la commande du robot est le fichier 'rp_cmd.py'. Il est éditable avec tout éditeur (Spyder, Emacs, Atoms, ...).

Les instructions de base sont :

  • Avancer : rp_avancer()
  • Reculer : rp_reculer()
  • Tourner à gauche : rp_gauche()
  • Tourner à droite : rp_droite()
  • Marquer la case : rp_marquer()
  • Détecter la présence d'un mur devant à un pas : rp_detect() -> retourne True en présence d'un mur et False en absence de mur

Il y a 6 missions :

  • Mission 1 : Les premiers pas de Ropy
  • Mission 2 : Ma première fonction
  • Mission 3 : Sécuriser Ropy
  • Mission 4 : Partir au bout du monde
  • Mission 5 : Faire face à l'inconnu
  • Mission 6 : Se rendre utile

Du niveau 1 au niveau 5, chaque niveau donne lieu à la découverte d'une nouvelle structure algorithmique. Le niveau 6 correspond à la mission principale, il faudra mobiliser l'ensemble de structures vues précédement.

Par son interface sur le port série, Ropy peut devenir le jumeau numérique d'un robot réel. Trois missions sont proposées sur son jumelage avec le robot Maqueen (carte micro:bit) présentes dans les documents pédagogiques.

Deux vidéos :

Documents pédagogiques

Les applications pédagogique se trouvent dans le dépôt des documents pédagogiques du projet Blender-EduTech .

Ropy est une plateforme pédagogique où d'autres missions pouvent être dévelopées pour mettre en oeuvre des concepts comme la programmation objet, le multithreading ou encore le machine learning.

Développement

L'environnement de développement est basé sur : la plateforme de modélisation et d'animation 3D Blender ( https://blender.org ), le langage Python (https://python.org ) et le moteur de jeu 3D UPBGE ( https://upbge.org ).

Le code source, les fichiers blender et les assets sont hébergés sur le dépôt gitlab.

La bibliothèque serial utilisée pour la communication sur le port série (jumeau numérique) n'est pas incluse par défaut dans l'environnement UPGE.

Il faut donc l'installer localement, les étapes sont :

  • GNU-Linux : La configuration ici présente est UPBGE installé sur ~ avec Python 3.9 :

    • Aller dans le répertoire local de Python de UPBGE: $ cd ~/UPBGE-0.30-linux-x86_64/3.0/python/bin
    • Installer localement (UPBGE) le gestionnaire de paquet pip : $ ./python3.9 -m ensurepip --default-pip
    • Installer localement (UPBGE) la bibliothèque serial : $ ./pip install serial -t ~/UPBGE-0.30-linux-x86_64/3.0/python/lib/python3.9/site-packages
  • Windows : La configuration ici présente est UPBGE installé sur le bureau utilisateur (philippe.roy) avec la distribution Anaconda installée :

    • Avec Anaconda Navigator ouvrir un terminal Powershell
    • Avec le terminal installer localement (UPBGE) la bibliothèque serial : pip install serial -t C:\Users\philippe.roy\Desktop\UPBGE-0.30-windows-x86_64\3.0\python\lib\site-packages