Module RFID RC522 – Arduino

Ce page est obsolète… Se rendre ici pour la mise à jour : https://mataucarre.fr/index.php/2022/03/03/arduino-et-module-rfid-rc522-gerer-plusieurs-cartes/

Le Module RFID-RC522 est module RFID utilisé pour lecture/écriture sans contact d’un tag. Le lecteur utilise une communication SPI.

RFID est l’abréviation de Radio Frequency IDentification. Les modules RFID utilisent des champs électromagnétiques pour transférer des données entre la carte et le lecteur. Différents tags sont attachés à des objets (carte, porte clé…) et lorsque nous plaçons cet objet en face du lecteur, le lecteur lit ces balises.

Un avantage du RFID est qu’il n’a pas besoin d’être dans une ligne de mire pour être détecté.

Les Tags possèdent une antenne associée à une puce électronique qui leur permet de recevoir et de répondre aux requêtes radio émises depuis l’émetteur-récepteur.
Ils contiennent un identifiant individuel (standard Epc-96 sur 96 bits). Leur fonctionnement est passif (sans source d’énergie, donc c’est autonome et inusable).

RFID – RC522 Arduino Leonardo
VCC 3,3V
RST/Reset ICSP 5
GND ICSP 6
IRQ /
MISO ICSP 1
MOSI ICSP 4
SCK ICSP 3
SDA Interface 10

Il faut télécharger les librairies suivantes et les installer dans le dossier librairies de votre dossier Arduino : Librairies RFID et SPI

Vous trouverez ensuite deux codes :
– Le premier permet de récupérer le numéro d’un TAG RFID
– Le second permet de vérifier si le TAG est correct (un numéro de TAG est en mémoire dans le programme).

#include <SPI.h>
#include <RFID.h>

RFID RFID(10,9); //RFID(SPI PIN, RST PIN)

int UID[5];

void setup()
{
Serial.begin(9600);
SPI.begin();
RFID.init();

}

void loop()
{
if (RFID.isCard()) { //Si une carte est présente près du lecteur
if (RFID.readCardSerial()) { // Si cette carte possède un numéro de série
Serial.print("L'UID est: ");
for(int i=0;i<=4;i++)
{
UID[i]=RFID.serNum[i];
Serial.print(UID[i],DEC);
Serial.print(".");
}
Serial.println("");
}
RFID.halt();
}
delay(100);
}
Lecture d'un TAG RFID
#include <SPI.h>
#include <RFID.h>

RFID RFID(10,9);

int UID[5]={};
int IDCarte[5]={1,100,52,75,209}; // UID du badge ou de la carte acceptée sous forme de tableau (Array).
bool statut = 1;

void setup()
{
Serial.begin(9600);
SPI.begin();
RFID.init();

}

void loop()
{


for(int i=0;i<=4;i++)
{
UID[i]=RFID.serNum[i];

}

if (UID[0] == IDCarte[0] // Si l'UID 0 est égale à 1
&& UID[1] == IDCarte[1] // Et si l'UID 1 est égale à 100
&& UID[2] == IDCarte[2] // Et si l'UID 1 est égale à 52
&& UID[3] == IDCarte[3] // Et si l'UID 1 est égale à 75
&& UID[4] == IDCarte[4]) // Et si l'UID 1 est égale à 209
{
Serial.print("Bonne carte");}

else
{
Serial.print("Mauvaise carte");

}

RFID.halt();
delay(100);

}
Comparer un numéro de carte, avec un autre en mémoire

Contrôler une LED RGB – Arduino

Une led RGB contient en fait trois Leds ; une rouge, une verte et une bleue. En modulant l’intensité lumineuse de chaque couleur, on peut obtenir toutes les couleurs possibles.

Une commande PWM pour chaque LED permet ainsi de mélanger les trois couleurs (rouge, verte et bleu) avec des intensités différentes.

Un nuancier est disponible sur le site : https://lehollandaisvolant.net/tout/tools/color/.

Nous pouvons obtenir la couleur en fonction des trois rapports cycliques.

Attention, certaines cartes de LED RGB intègrent déjà les résistances de limitation de courant. Il n’est donc pas nécessaire de les ajouter sur votre breadboard. Il faudra également faire attention au câblage indiquée sur cette carte (les interfaces risquent de ne pas être dans le même ordre que dans le schéma de câblage suivant) !!

 

Ce programme permet d’afficher une couleur rouge, une couleur verte, puis une couleur bleu. Il est donc possible d’obtenir plus de nuance en faisant varier les sorties PWM de la commande analogWrite entre 0 et 255.

// Définition des broches utilisées
int Rouge = 11; // R sur broche 11
int Vert = 9; // V sur la broche 9
int Bleu = 10; // B sur la broche 10

void setup()
{
pinMode(Rouge, OUTPUT);
pinMode(Vert, OUTPUT);
pinMode(Bleu, OUTPUT);

}

void loop()
{

//Affichage de la couleur Rouge
analogWrite(Rouge,255); // Rouge
analogWrite(Vert,0); // Vert
analogWrite(Bleu,0); // Bleu

delay(1000);

//Affichage de la couleur verte
analogWrite(Rouge,0); // Rouge
analogWrite(Vert,255); // Vert
analogWrite(Bleu,0); // Bleu

delay(1000);

//Affichage de la couleur bleue
analogWrite(Rouge,0); // Rouge
analogWrite(Vert,0); // Vert
analogWrite(Bleu,255); // Bleu

delay(1000);
}

 

Capteur Détecteur de Flamme KY-026 – Arduino

Le capteur de flamme KY-026 est un capteur qui permet de mesurer des longueurs d’onde sur une plage comprise entre 760 nm et 1100 nm. Ce capteur réagira donc en présence d’une flamme.

Caractéristiques :
– Extrêmement sensible aux longueurs d’ondes entre 760-1100nm
– Seuil de détection de flamme modifiable par un potentiomètre
– Plage d’angle de détection: environ 60 degrés
– Alimentation: 3.3-5.5 VDC

 

// Définition des broches utilisées
int Led = 1 ;// LED
int capt_num = 3; // Interface Capteur Flamme
int capt_ana = A3; // Interface Capteur Flamme

int val ;
float capteur_flamme;

void setup ()
{
pinMode(Led, OUTPUT);// Définir l'interface de la LED en sortie
pinMode(capt_num, INPUT);// Définir l'interface du capteur de flamme en entrée
pinMode(capt_ana, INPUT);// Définir l'interface du capteur de flamme en entrée
Serial.begin(9600);
}

void loop ()
{
capteur_flamme = analogRead(capt_ana);

Serial.println(capteur_flamme);

val = digitalRead (capt_num) ;
if (val == HIGH) // Quand le capteur détecte une flamme, la led s'allume
{
digitalWrite (Led, HIGH);
Serial.println("Flamme");
}
else
{
digitalWrite (Led, LOW);
Serial.println("Pas de flamme");
}
delay(2000);
}

 

Capteur de tempétature TMP36 – Arduino

Afin de récupérer une température avec un Arduino, nous pouvons utiliser un capteur TMP36.

Ce capteur doit-être alimenté entre 2.7 et 5.5V, et consomme moins de 50µA en fonctionnement, et 0.5µA en veille

Attention au branchement de ce capteur. S’il est branché dans le mauvais sens, il risque de chauffer très vite et à de hautes températures. Vous risquez une brûlure si vous entrez en contact avec lui !

Le document constructeur est disponible ici : datasheet

Caractéristiques :
– Taille: boitier TO-92 à 3 broches (similaire à un transistor)
– Gamme de température: -40°C a 150°C / -40°F a 302°F
– Tension de sortie: 0.1V (-40°C) to 2.0V (150°C) mais la précision diminue après 125°C
– Tension d’alimentation: 2.7V a 5.5V

//définition des broches utilisées
int capteur_temp = 0;

void setup()
{
Serial.begin(9600);
}

void loop()
{

// Lecture de l'entrée analogique
int reading = analogRead(capteur_temp);

// Conversion de la lecture d'entrée en tension
float volt = reading * 5.0;
volt = volt / 1024.0;

// Afficher la tension d'entrée
Serial.print(volt); Serial.println(" volts");

// Afficher la température
float temperature = (volt - 0.5) * 100 ; // Convertir la tension en temperature

Serial.print(temperature);
Serial.println(" degrees C");

delay(1000);
}

Capteur à Ultrason HC-SR04 – Raspberry Pi

Les informations sur les caractéristiques du capteur sont disponibles ici.

Le signal de sortie du capteur (ECHO) sur le HC-SR04 est de à 5V. Cependant, nous pouvons envoyer sur la broche d’entrée sur du GPIO Raspberry Pi 3,3V.

En envoyant un signal 5V dans ce port d’entrée de 3,3 V non protégé, on pourrait endommager les broches GPIO.
Nous aurons besoin d’utiliser un diviseur de tension, composé de deux résistances, pour abaisser la tension de sortie du capteur à une tension que le Raspberry Pi peut manipuler.

Schéma de câblage :

# Importer les librairies 
import time
import RPi.GPIO as GPIO

GPIO.setmode(GPIO.BCM)

# Definir les ports GPIO
GPIO_TRIGGER = 23
GPIO_ECHO = 24

# Definir les ports GPIO en entrée et Sortie
GPIO.setup(GPIO_TRIGGER,GPIO.OUT) # Trigger
GPIO.setup(GPIO_ECHO,GPIO.IN) # Echo

GPIO.output(GPIO_TRIGGER, False)
time.sleep(0.5)

# Envoyer une impulsion de 10us sur le Trigger
GPIO.output(GPIO_TRIGGER, True)
time.sleep(0.00001)
GPIO.output(GPIO_TRIGGER, False)
start = time.time()
while GPIO.input(GPIO_ECHO)==0:
start = time.time()

while GPIO.input(GPIO_ECHO)==1:
stop = time.time()

# Calculer la longueur de la pulsation
elapsed = stop-start

distance = elapsed * 34000
distance = distance / 2

print "Distance : %.1f" % distance

# Reset GPIO
GPIO.cleanup()