Projets:Interfaces XAC
Description du projet
Réaliser et mettre oeuvre une solution logicielle et hardware pour connecter des interfaces de type Joystick à une XAC (Xbox Adaptive Controller)
Un boitier et une nouvelle carte on été réalisé pour Chloé. Cette réalisation s'appuie sur les éléments présents de cette page :
[[1]]
Synoptique des différentes configurations possibles
On doit pouvoir se connecter sur les entrées arrières X1,X2 ou sur les entrées USB Gauche et Droite.
Plusieurs types de dispositifs
- Joystick Proportionnel Sensible (JPS) ou Arduino sur Entrées Arrières X1 ou X2
- Joystick JPS ou Arduino sur Teensy LC connectée comme Joystick à une entrée USB XAC
- Joystick JPS ou arduino sur Arduino Micro Pro connectée comme Joystick à une entrée USB XAC
- Souris avec ou sans fil ou Souris au-travers de R-Net BT connectées comme Joystick à une entrée USB XAC
Analyse de l'existant
Equipe (Porteur de projet et contributeurs)
- Christian (Concepteur)
- Jonathan (Porteur de projet)
- Delphine (Fabmanager référent)
- Delphine & Christian (Documentation)
Matériel nécessaire
- Carte Teensy LC. ou Carte Arduino Micro-pro selon la configuration souhaitée
- Carte Mini Host Usb
Outils nécessaires
- Imprimante 3d (si réalisation d'un Joystick Proportionnel Sensible(JPS))
- IDE Arduino 1.89 ou 1.10
- TeensyDuino 1.46 ou 1.48
Coût
Délai estimé
Fichiers source
Schémas
- Les fichiers "Sch" et "lib" sous Kicad pour concevoir les PCB
- Les fichiers kicad: Fichier:KICAD XAC.zip
Préparation de l'environnement
- Installer l'IDE Arduino (1.8.10)
- Installer teensyduino 1.48 (attention seulement compatible avec certaines versions d'Arduino)
Dossiers à placer dans le dossier des librairies Arduino
Deux librairies sont à ajouter : Joystick1 (version modifiée de la librairie xac-mouse2joy, et USB_Host_Shield_20)
Télécharger les librairies et les ajouter au dossier Libraries de Arduino
La librairie USB_Host_Shield_20 permet de configurer les boutons en leur assignant des numéros qu'on retrouve dans l'interface XAC ou interface de la console. C'est dans le fichier MouseParser.h du sketch qu'on assigne ces boutons.
Le développement de ce code a été modifié par Christian Fromentin MHK Rennes.
(A retrouver : Voir le fichier "Regarde-moi.txt" dans le dossier XAC-Joystick)
Sources librairies avant modification
https://github.com/felis/USB_Host_Shield_2.0
https://github.com/gdsports/xac-mouse2joy/blob/master/joystick_teensy_20181205.zip
Fichiers à placer dans le répertoire du logiciel /../Arduino/Hardware
Précaution : Faire un backup des fichiers originaux avant de les remplacer. En effet ce changement de configuration vient modifier les headers de certains fichiers lors de la compilation.
A deposer dans Arduino>hardware
Sur windows
C>Program Files (x86)>Arduino>hardware
Sur Linux
Selon où et comment le programme a été installé, peut être dans :
Ordinateur>opt>arduino-1.8.10>hardware
Pour être certain d'être dans le bon dossier, vérifier que le dossier contient l'ensemble des dossiers (examples, hardware,java,lib, libraries,reference,tools,tools-builder)
Code Arduino
Attention pour que le fichier compile il ne faut pas oublier de configurer depuis IDE Arduino>Outil>USB type>Serial+Joystick
Si cette option n'est pas visible, c'est que les librairies sont mal ou pas installées.
- Les fichiers ".Ino" pour le firmware des cartes :
- BT Hid vers XAC ou Pc sans envoie sur le port série carte Teensy LC :
- BT Hid vers Pc avec envoie sur le port série carte Teensy LC :
- USB Hid vers XAC ou Pc sans envoie sur le port série carte Teensy LC :
- USB Hid vers Pc avec envoie sur le port série carte Teensy LC :
- JPS ou Analogique Arduino vers XAC ou Pc sans envoie sur le port série carte Teensy LC :
- JPS ou Analogique Arduino vers Pc avec envoie sur le port série carte Teensy LC :
- JPS ou Analogique Arduino vers XAC ou Pc sans envoie sur le port série carte Micro Pro :
- JPS ou Analogique Arduino vers Pc avec envoie sur le port série carte Micro Pro :
Notes d'utilisation des différents type de joystick
Quand on utilise le Joystick Proportionnel Sensible, il doit être alimenté en 5V. Si on le met directement sur une entrée analogique de la teensy, elle va griller car va recevoir 5V or car elle accepte 3V max. (Les entrées analogiques ne sont pas régulées comme le VIn). il faut donc ajouter un régulateur de tension (5V->3.3V) pour éviter la catastrophe.
Quand on utilise un joystick type arduino, il y a des potentiomètres ordinaires dedans, on les alimente avec le 3.3V récupéré sur la teensy. Quelle que soit la tension d'alimentation du joystick, la sortie du potentiomètre ira de 0 au maximum de la tension. Au lieu de les alimenter en 5V , on les alimente en 3.3v, et on aura bien toute la plage de valeurs de 0 à 1024.
Si on connecte les joysticks directement sur les entrées arrières de la xac , c'est pareil (joystick type arduino, besoin de rien, avec le Joystick Proportionnel Sensible il faut un régulateur)
Description de la XAC
Différence des entrées sur la xac
- Entrées à l'arrière: entrées analogiques
- Entrées USB sur le coté: entrées numériques.
Préparation de la carte Mini USB Host
La carte Mini Usb Host doit être modifiée.
(Certaines cartes possèdent un strap qui permet de le faire sans couper une piste)
Il faut permettre l'alimentation du connecteur USB avec 5 volt et non 3.3v par défaut avec cette carte:
Etape 1 :Couper la piste comme sur la photo (juste avant l'inscription "2.2k") et souder un fil
Etape 2: Souder l'autre extrémité du fil
Config 1: BT Hid vers XAC ou PC sans envoi sur le port série carte Teensy LC
Cette configuration permet de rendre la XAC bluetooth et de s'y connecter via un joystick de fauteuil roulant afin de pouvoir jouer à des jeux videos sur console.
Schema
Les résistances+leds ne sont pas essentiels au montage. Par contre les condensateurs si.
Le 3.3V et le RESET mentionnés sur le schema (en bas à gauche) sont ceux de la carte host USB.
Méthode pour valider le fonctionnement de l'ensemble
Pour tester le Joystick du fauteuil (industriel), il faut couper le Bluetooth du PC pour empêcher le fauteuil de se connecter directement au PC en mode souris.
1-Vérifier que le montage Teensy+Host USB est reconnu en tant que joystick par l'ordinateur
- Connecter uniquement la teensy avec le host USB à l'ordinateur
- Ouvrir le sketch test du joystick :LC JPS-to-Joy XAC-PC_TEST
- Dans l'IDE Arduino, choisir dans Outil>USB Type : Joystick +Serial (vous devez voir cette option sinon c'est que les librairies sont mal ou pas installées)
- Téléverser le sketch sur la Teensy.
- Ouvrir les périphériques contrôleur de jeu :
- Sur Windows, taper dans la barre de recherche en bas à gauche, "Configurer les contrôleurs de jeu" puis la fenêtre Contrôleurs de jeu s'ouvre et vous devriez voir Keyboard/Mouse/Joystick, puis cliquer sur Propriétés pour avoir un affichage de l'état du joystick.)
- sur linux: taper en ligne de commande :jstest-gtk
- Vous devriez voir le joystick bouger
2-Vérifier la communication entre la XAC et l'ordinateur
- Connecter la XAC à l'ordinateur (le pilote s'installe à la connection)
- On garde les propriétés du contrôleur de jeu ouvert
- On doit voir le dispositif xbox reconnu, avec le périphérique qui s'actualise dans la fenêtre des propriétés du controleur. Evidemment ici on ne voit pas le joystick bouger puisque la teensy n'est pas connectée
(Il faut télécharger l'interface de la xbox pour ordi pour pouvoir prendre le contrôle/remapper/etc... (ou on peut le faire sur la xbox)
3-Vérifier que le joystick simulé par la teensy est reconnu quand connecté à la XAC
- connecter le proto host usb/teensy sur la xac toujours avec le sketch test du joystick :LC JPS-to-Joy XAC-PC_TEST
- vérifier dans les propriétés du contrôleur de jeu que le joystick bouge
4-Test avec le joystick du fauteuil
- Teléverser le sketch LC_BTHID_Mouse-to-Joy_XAC-PC sur la teensy
- Connecter directement la teensy+host sur le pc
- Vérifier dans les propriétés du contrôleur que le joystick du fauteuil envoie en bluetooth les informations de déplacement
5-Vérifier que la XAC est reconnue par le PC
- Déconnecter la teensy du pc
- Connecter la xac sur le pc
- Vérifier dans le contrôleur de jeu que la xbox one (xac) est bien reconnue (le contrôleur doit actualiser le nom du périphérique reconnu)
- connecter ensuite la teensy+host usb sur la xac. Vous devriez visualiser les mouvements du joystick du fauteuil.
6-[OPTIONNEL] Test avec l'application Accessoire xbox
- Télécharger l'application. Cette application est uniquement valable pour Windows 10. Elle permet de visualiser la XAC et de la paramétrer. https://www.microsoft.com/fr-fr/p/accessoires-xbox/9nblggh30xj3?activetab=pivot:regionofsystemrequirementstab
- Démarrer l'application
Aller sur "configurer">Editer en cliquant sur l'icône crayon>Stick analogique gauche Vous devriez visualiser le joystick bouger.
La sensibilité du joystick se règle directement sur la xac. Il est préférable de laisser toute la configuration du mapping se faire dans l'interface la XAC et de ne pas introduire cette notion dans le code.
7-Tester le dispositif sur la XBOX
- Déconnecter la XAC du PC
- Connecter la XAC +teensy host USB sur la XBOX
Contexte technique du projet
Contraintes du joystick du fauteuil
Le joystick du fauteuil est en réalité une souris, c'est-à-dire qu'à chaque fois qu'on bouge la souris on reprend la position là où on l'avait laché, on est en position relative qui s'incrémente à chaque fois qu'on la bouge. Le code n'est pas optimisé pour l'utilisation avec le joystick du fauteuil, mais pour le joystick proportionnel sensible qui lui a une position neutre (mécanique) et fonctionne avec des positions absolues.
Le joystick du fauteuil a deux clicks : droit et gauche
Mapping du joystick
Christian n'a pas mappé les valeurs dans le code. Les valeurs vont de 0 à 1024 sur les deux axes (X et Y). Il est impératif de faire le mapping à un seul endroit : soit dans l'interface de la xac, soit dans l'interface de la xbox ou de son application mais en aucun dans le code !
Valeurs renvoyées par la souris (joystick)
La valeur de la position de la souris est proportionnel à la vitesse de déplacement.
Par défaut sur une souris, la vitesse de deplacement est prise en compte pour l'incrémentation (lentement on incrémente de 1 et rapidement on a un pas de 100 voir plus).
Ce qu'il faudrait , c'est implémenter dans le code une transformation de ce comportement : au lieu d'avoir un pas de 100, le remplacer par un pas de 1 mais qui va beaucoup plus vite.
C'est le fichier MouseParser.h qui communique avec la librairie Host USB, et qui traite les informations reçues de la souris (joystick).
La variable mi = valeurs renvoyées par la souris
Développements à prévoir
Introduction du neutre dans le code
- Avoir un neutre sur une souris en respectant les contraintes de temps (latence) dans un jeu. On ne peut avoir l'information que la souris est en position neutre à part observer qu'elle n'envoie pas d'information sur un temps donné (ce temps doit être très court, de l'ordre de microsecondes). Ajouter cette fonction dans le fichier MouseParser.h du sketch LC_BTHID_Mouse-to-Joy_XAC-PC
Assignation des boutons
Ajout du clic droit
Pour l'instant, il n'a pas été implémenté.
Configuration des déplacements de la souris (joystick)
Dans le code, la vitesse de deplacement de la souris est prise en compte pour l'incrémentation (lentement on incrémente de 1 et rapidement on a un pas de 100). Ce qu'il faudrait , c'est au lieu d'avoir un pas de 100, le remplacer par un pas de 1 mais qui va beaucoup plus vite.
Code à prévoir et actualisation de la carte électronique pour retour visuel des connections/com
Prévoir des leds de couleurs ou clignotement pour avoir un retour visuel des informations reçus par la Teensy :
- l'appairage en bluetooth
- reconnaissance du joystick fauteuil
- de la xac
- Quand le joystick bouge.
- système sous tension
Anticiper l'ajout de boutons/leds/ ... sur des pins
- Prévoir les pins pour les devs futurs avec des pins headers (voir schema) pour pouvoir ajouter des boutons, leds ou autres
Schemas sur Fritzing et / ou sur veroboard (DIYLC)
Transférer le schema ci-dessus sur les logiciels Fritzing et / ou sur veroboard (DIYLC)
Faire une boite
Ce développement à venir a été continué sur la page du projet Magic Joystick Projets:Magic_Joystick