Projets:Interfaces XAC

De wikiup
Sauter à la navigation Sauter à la recherche
Interfaces XAC

Mini Host Usb Soude.jpg

Informations
Description Réaliser et mettre oeuvre une solution logicielle et hardware pour connecter des interfaces de type Joystick à une XAC


Catégorie Motricité
Etat d'avancement Réalisés
Techniques teensy
Durée de fabrication de 4 à 8 h
Coût matériel Moins de 50 euros"Moins de 50 euros" n’est pas dans la liste (De 50 à 100 euros, De 100 à 200 euros, Plus de 200 euros, Moins de 10 euros, De 10 à 50 euros) de valeurs autorisées pour la propriété "A coût matériel".
Niveau
Licence by-sa
Date de création 2019-10-10
Équipe
Porteur de projet Jonathan
Contributeurs Elektron
Fabmanager Delphine
Référent documentation Elektron, Delphine
Nom humanlab Humanlab_MHK
Documentation
Statut de la documentation Complète
Relecture de la documentation Non vérifiée

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 :

Boitier Souris Vers XAC

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


Interfaces XAC.png

XAC.jpg JPS Ensemble Vue-01.jpg

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

Coût

Délai estimé

Fichiers source

Schémas

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.

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

Mini Host Usb Prepa.jpg

Etape 2: Souder l'autre extrémité du fil

Mini Host Usb Soude.jpg


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

Host Usb-to-LC-to-XAC

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

  1. Connecter uniquement la teensy avec le host USB à l'ordinateur
  2. Ouvrir le sketch test du joystick :LC JPS-to-Joy XAC-PC_TEST
  3. 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)
  4. Téléverser le sketch sur la Teensy.
  5. 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
  1. Vous devriez voir le joystick bouger

2-Vérifier la communication entre la XAC et l'ordinateur

  1. Connecter la XAC à l'ordinateur (le pilote s'installe à la connection)
  2. On garde les propriétés du contrôleur de jeu ouvert
  3. 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

  1. connecter le proto host usb/teensy sur la xac toujours avec le sketch test du joystick :LC JPS-to-Joy XAC-PC_TEST
  2. vérifier dans les propriétés du contrôleur de jeu que le joystick bouge

4-Test avec le joystick du fauteuil

  1. Teléverser le sketch LC_BTHID_Mouse-to-Joy_XAC-PC sur la teensy
  2. Connecter directement la teensy+host sur le pc
  3. 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

  1. Déconnecter la teensy du pc
  2. Connecter la xac sur le pc
  3. 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)
  4. 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

  1. 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
  2. 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

  1. Déconnecter la XAC du PC
  2. 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