La position X et Y du joystick est sortie sous forme de tension analogique sur les broches de sortie.

Dans ce joystick, un potentiomètre séparé a été installé pour l'axe X et pour l'axe Y. On obtient ainsi un diviseur de tension comme celui de l'image suivante.

A l'état de repos, le potentiomètre est au milieu, de sorte que la résistance 1=résistance 2, ce qui signifie que la tension appliquée est répartie de manière égale entre les deux - par exemple, la valeur mesurée à +V=5V -> 2,5V.

Si maintenant la position de l'axe X, par exemple, est modifiée, les résistances respectives changent en fonction de la position actuelle - par exemple, si elle va dans une direction, la résistance 1 devient plus petite et la résistance 2 plus grande, si elle va dans l'autre direction, la résistance 1 devient plus grande et la résistance 2 plus petite.

Selon la façon dont les résistances sont réparties entre elles, il en résulte une valeur de tension respective qui peut être mesurée entre les résistances (dans le cas du potentiomètre, ce que l'on appelle des curseurs) et ainsi déterminer la position de l'axe.

Affectation des broches

Exemple de code Arduino

Affectation des broches Arduino

Arduino Capteur
5V +V
Masse GND
Pin A1 VRy
Pin A0 VRx
Pin 3 Bouton

Le programme lit les valeurs actuelles des broches d'entrée, les convertit en une tension (0-1023 -> 0V-5V) et la sort sur la sortie série.

// Déclaration et initialisation des broches d'entrées
int JoyStick_X = A0; // Signal de l'axe X
int JoyStick_Y = A1; // Signal de l'axe Y
int Button = 3; // Bouton
 
void setup ()
{
  pinMode (JoyStick_X, INPUT);
  pinMode (JoyStick_Y, INPUT);
  pinMode (Button, INPUT);
   
  // Lorsqu'on pousse sur le bouton, la mise à la masse
  // active la résistance de PullUp.
  digitalWrite(Button, HIGH);  
   
  Serial.begin (9600); // Sortie série à 9600 bauds
}
 
// Le programme lit les valeurs des broches d'entrée et les envoie à la sortie série
void loop ()
{
  float x, y;
  int Knopf;
   
  //Les valeurs sont lues, sont converties en tension...
  x = analogRead (JoyStick_X) * (5.0 / 1023.0); 
  y = analogRead (JoyStick_Y) * (5.0 / 1023.0);
  Knopf = digitalRead (Button);
   
  //... et envoyées à la sortie série.
  Serial.print ("Axe X:"); Serial.print (x, 4);  Serial.print ("V, ");
  Serial.print ("Axe Y:"); Serial.print (y, 4);  Serial.print ("V, ");
  Serial.print ("Bouton:");
 
  if(Knopf==1)
  {
      Serial.println (" pas de pression sur le bouton");
  }
  else
  {
      Serial.println (" pression sur le bouton");
  }
  delay (200);
}

Télécharger l'exemple de programme

KY023-Arduino.zip

Exemple de code Raspberry Pi

Affectation des broches Raspberry Pi

Raspberry Pi Capteur
GPIO 24 [Pin 18] Bouton
3,3V [Pin 1] +V
Masse [Pin 6] GND
KY-053 A1 VRy
KY-053 A0 VRx
Capteur KY-053
VRy A1
VRx A0
+V 3,3V [Pin 1]
GND Masse [Pin 6]
Raspberry Pi KY-053
GPIO 3 [Pin 5] SCL
Gpio 2 [Pin 3] SDA

Capteur analogique, il faut donc respecter les points suivants.

Contrairement à l'Arduino, le Raspberry Pi n'a pas d'entrées analogiques ou il n'y a pas d'ADC (convertisseur analogique numérique) intégré dans la puce du Raspberry Pi. Cela limite le Raspberry Pi, si vous voulez utiliser des capteurs, où les valeurs de sortie ne sont pas numériques [valeur de tension dépassée -> valeur numérique ON | valeur de tension sous-cotée -> valeur numérique OFF | exemple : bouton enfoncé [ON] bouton relâché [OFF]], mais il doit s'agir d'une valeur variable continue (exemple : potentiomètre -> autre position = autre valeur de tension).

Pour éviter ce problème, notre kit de capteur X40 a le KY-053, un module avec ADC précis de 16 bits, que vous pouvez utiliser sur le Raspberry pour l'étendre avec 4 entrées analogiques. Il est connecté au Raspberry Pi via I2C, prend en charge la mesure analogique et transmet la valeur numérique au Raspberry Pi.

Ainsi, nous recommandons de connecter le module KY-053 avec ledit ADC entre les capteurs analogiques de cet ensemble. Pour plus d'informations, veuillez consulter la page d'information sur le convertisseur analogique-numérique KY-053.

Le programme utilise les bibliothèques Python ADS1x15 et I2C correspondantes d'Adafruit pour piloter l'ADC ADS1115. Ceux-ci ont été publiés au lien suivant https://github.com/adafruit/Adafruit_CircuitPython_ADS1x15 sous la licence MIT. Les bibliothèques requises ne sont pas incluses dans le paquet de téléchargement ci-dessous.

Le programme lit les valeurs actuelles des broches d'entrée et les affiche dans la console sous forme de valeur en [mV].

#!/usr/bin/python
# coding=utf-8

import time
import board
import busio
import adafruit_ads1x15.ads1115 as ADS
from adafruit_ads1x15.analog_in import AnalogIn
import RPi.GPIO as GPIO
GPIO.setmode(GPIO.BCM)
GPIO.setwarnings(False)

Button_PIN = 24
GPIO.setup(Button_PIN, GPIO.IN, pull_up_down = GPIO.PUD_UP)

delayTime = 0.2
# Create the I2C bus
i2c = busio.I2C(board.SCL, board.SDA)

# Create the ADC object using the I2C bus
ads = ADS.ADS1115(i2c)

# Create single-ended input on channels
chan0 = AnalogIn(ads, ADS.P0)
chan1 = AnalogIn(ads, ADS.P1)
chan2 = AnalogIn(ads, ADS.P2)
chan3 = AnalogIn(ads, ADS.P3)


while True:
                # Les valeurs actuelles sont enregistrées
                x = '%.2f' % chan0.voltage
                y = '%.2f' % chan1.voltage
 
                # Sortie sur la console
                if GPIO.input(Button_PIN) == True:
                        print ("X-Achse:", x,"V, ","Axe Y:", y,"V, Bouton : non pressé")
                else:
                        print ("X-Achse:", x, "V, ", "Axe des Y :", y, "V, Bouton : pressé")
                print ("---------------------------------------")
 
                # Reset + Delay
                button_pressed = False
                time.sleep(delayTime)

Exemple de téléchargement de programme

KY023-RPi.zip

Pour commencer avec la commande :

sudo python3 KY023.py

Exemple de code Micro:Bit

Affectation des broches Micro:Bit :

Micro:Bit Capteur
3V +V
Masse GND
Pin 2 VRx
Pin 1 VRy
Pin 0 Bouton

Ceci est un exemple MakeCode pour Micro:Bit qui fait essentiellement la même chose que les exemples pour les deux autres variantes. Cependant, cet exemple est plus proche de celui du Raspberry Pi que de celui de l'Arduino.

Téléchargement d'un exemple de programme

microbit-KY-023.zip