Ligne 8 : | Ligne 8 : | ||
|Duration=1 | |Duration=1 | ||
|Duration-type=heure(s) | |Duration-type=heure(s) | ||
− | |Licences=Attribution - Partage dans les Mêmes Conditions | + | |Licences=Attribution - Partage dans les Mêmes Conditions (CC BY-SA) |
|Main_Picture=Vumontage.jpg | |Main_Picture=Vumontage.jpg | ||
}} | }} | ||
{{Introduction | {{Introduction | ||
− | |Introduction= | + | |Introduction=Avec ce tutoriel vous apprendrez à utiliser Arduino et des capteurs (température, pression et humidité) plus émission/réception en 2.4Ghz. Et en plus la réception sur un Raspberry pi en Python. L’idée m’est venue en voulant ajouter la pression et l’humidité à mon capteur de température extérieur. |
− | + | Pour en savoir plus sur mes projets, [http://rasp-pi.fr.nf visitez mon site]. | |
− | http://rasp-pi.fr.nf | ||
}} | }} | ||
{{Materials | {{Materials | ||
− | |Material= | + | |Material=* Un Raspberry moi c’est un PI Model B. |
− | |||
− | * Un Raspberry moi c’est un PI Model B. | ||
* Un Arduino uno | * Un Arduino uno | ||
* 2 émetteurs/récepteurs en 2.4Ghz | * 2 émetteurs/récepteurs en 2.4Ghz | ||
Ligne 28 : | Ligne 25 : | ||
* Plaque d'essai et fil de connexion. | * Plaque d'essai et fil de connexion. | ||
|Step_Picture_00=montage.jpg | |Step_Picture_00=montage.jpg | ||
− | |ExternalAttachmentsLinks= | + | |ExternalAttachmentsLinks={{ExternalAttachmentsLinks |
+ | |ExternalAttachmentsLinks=https://github.com/Michelgard/Multi-capteur-Arduino-avec-emetteur-2.4Ghz | ||
+ | }}{{ExternalAttachmentsLinks | ||
+ | |ExternalAttachmentsLinks=http://ouiaremakers.com/wp-content/uploads/formidable/capteur_multietNF24.ino | ||
+ | }} | ||
|Tuto_Attachments= | |Tuto_Attachments= | ||
}} | }} | ||
Ligne 45 : | Ligne 46 : | ||
|Step_Content=Pour la programmation de l’Arduino il faut quelques biblio : | |Step_Content=Pour la programmation de l’Arduino il faut quelques biblio : | ||
− | Le capteur de pression : Barometer, SPI et Wire . Je vous ajoute tous les liens sur mon | + | Le capteur de pression : Barometer, SPI et Wire . Je vous ajoute tous les liens sur mon [https://github.com/Michelgard/Multi-capteur-Arduino-avec-emetteur-2.4Ghz Github] : |
* Le capteur d’humidité : DHT22 | * Le capteur d’humidité : DHT22 | ||
* Le capteur de température : DS18D20 | * Le capteur de température : DS18D20 | ||
* L’émetteur 2.4Ghz : RF24 | * L’émetteur 2.4Ghz : RF24 | ||
− | Pour le programme de l’Arduino je vais pas le mettre ici en intégral mais vous pouvez le trouver sur mon | + | Pour le programme de l’Arduino je vais pas le mettre ici en intégral mais vous pouvez le trouver sur mon [https://github.com/Michelgard/Multi-capteur-Arduino-avec-emetteur-2.4Ghz Github]. |
+ | |||
Par contre quelques informations sur son fonctionnement. Les données à envoyer sont préparées avant l’envoie dans un tableau de char de cette façon : | Par contre quelques informations sur son fonctionnement. Les données à envoyer sont préparées avant l’envoie dans un tableau de char de cette façon : | ||
On crée le char avec une valeur de départ : | On crée le char avec une valeur de départ : | ||
− | char SendPayload[32] = “RS1 :”; | + | <code>char SendPayload[32] = “RS1 :”;</code> |
Ensuite on ajoute le valeurs. Chaque valeur est précédé et suivie d’une lettre permettant à la réception son repérage. Par exemple pour la température : | Ensuite on ajoute le valeurs. Chaque valeur est précédé et suivie d’une lettre permettant à la réception son repérage. Par exemple pour la température : | ||
− | strcat(SendPayload, “T”); | + | |
+ | <code>strcat(SendPayload, “T”); | ||
dtostrf(txbuffer[0],2,2,tempstr); | dtostrf(txbuffer[0],2,2,tempstr); | ||
strcat(SendPayload,tempstr); | strcat(SendPayload,tempstr); | ||
− | strcat(SendPayload, “T”); | + | strcat(SendPayload, “T”);</code> |
Et ensuite le char complet est envoyé : | Et ensuite le char complet est envoyé : | ||
− | bool ok = radio.write(&SendPayload,sizeof(SendPayload)); | + | <code>bool ok = radio.write(&SendPayload,sizeof(SendPayload));</code> |
Mais comme il y a trop de donnée et que le nombre de caractère est au maximum de 32 il faut faire deux char envoyés à la suite. Chaque char sera repéré à la réception par son numéro “RS1” et “RS2”. | Mais comme il y a trop de donnée et que le nombre de caractère est au maximum de 32 il faut faire deux char envoyés à la suite. Chaque char sera repéré à la réception par son numéro “RS1” et “RS2”. | ||
− | |||
− | |||
}} | }} | ||
{{Tuto Step | {{Tuto Step | ||
Ligne 84 : | Ligne 85 : | ||
Voilà. Bon bricolage. La suite sera un affichage sur mon DashScreen des données collectées. | Voilà. Bon bricolage. La suite sera un affichage sur mon DashScreen des données collectées. | ||
− | Vous trouverez tous les documents et codes sur | + | Vous trouverez tous les documents et codes sur [https://github.com/Michelgard/Multi-capteur-Arduino-avec-emetteur-2.4Ghz Github]. |
Et d’autre info sur mon blog : http://rasp-pi.fr.nf | Et d’autre info sur mon blog : http://rasp-pi.fr.nf | ||
|Step_Picture_00=Recepteur-Raspi-2 4Ghz bb.jpg | |Step_Picture_00=Recepteur-Raspi-2 4Ghz bb.jpg | ||
}} | }} | ||
{{Notes}} | {{Notes}} |
Auteur MichelGard | Dernière modification 9/12/2019 par Clementflipo
Vumontage.jpg Création
Avec ce tutoriel vous apprendrez à utiliser Arduino et des capteurs (température, pression et humidité) plus émission/réception en 2.4Ghz. Et en plus la réception sur un Raspberry pi en Python. L’idée m’est venue en voulant ajouter la pression et l’humidité à mon capteur de température extérieur.
Pour en savoir plus sur mes projets, visitez mon site.
Un capteur de température intérieur, un capteur de température extérieur, un capteur d’humidité et un capteur de pression le tout connecté à un Arduino et les valeurs transférées par un émetteur en 2.4Ghz. Et pour la réception Raspberry, récepteur 2.4Ghz et du python. Voilà l’objet de ce petit tuto.
Pour le montage de l’émetteur voici le schéma. Rien de très compliqué mais il y a beaucoup de fil…
Bien penser aux résistances de 4.7K sur le récepteur de température et d’humidité. Et surtout attention l’émetteur 2.4Ghz fonctionne sous 3.3V.
Pour la programmation de l’Arduino il faut quelques biblio :
Le capteur de pression : Barometer, SPI et Wire . Je vous ajoute tous les liens sur mon Github :
Pour le programme de l’Arduino je vais pas le mettre ici en intégral mais vous pouvez le trouver sur mon Github.
Par contre quelques informations sur son fonctionnement. Les données à envoyer sont préparées avant l’envoie dans un tableau de char de cette façon :
On crée le char avec une valeur de départ :
char SendPayload[32] = “RS1 :”;
Ensuite on ajoute le valeurs. Chaque valeur est précédé et suivie d’une lettre permettant à la réception son repérage. Par exemple pour la température :
strcat(SendPayload, “T”);
dtostrf(txbuffer[0],2,2,tempstr);
strcat(SendPayload,tempstr);
strcat(SendPayload, “T”);
Et ensuite le char complet est envoyé :
bool ok = radio.write(&SendPayload,sizeof(SendPayload));
Mais comme il y a trop de donnée et que le nombre de caractère est au maximum de 32 il faut faire deux char envoyés à la suite. Chaque char sera repéré à la réception par son numéro “RS1” et “RS2”.
Pour la réception nous avons un montage plus simple. Un raspberry pi et un récepteur en 2.4Ghz. Il faut configurer le Raspberry Pi pour le récepteur tout est dans ce fichier pdf ci-joint : Config Raspberry et Récepteur 2.4Ghz.pdf
Et pour finir un fichier en Python pour la réception et l’enregistrement des données dans une base de données.
Pour la réception je lui fait faire deux boucles pour avoir mes deux char qui sont décortiqués pour à la fin des deux boucles avoir toutes le données qui sont, pour finir envoyer dans la base.
Le programme en Python : multi_capteurs-NF24.py. Pour fonctionner il lui faut un programme de config en xlm pour les données de connxion à la base : config
Et le sql pour créer la table dans votre base de donnée : Table SQL
Voilà. Bon bricolage. La suite sera un affichage sur mon DashScreen des données collectées.
Vous trouverez tous les documents et codes sur Github. Et d’autre info sur mon blog : http://rasp-pi.fr.nf
Vous avez entré un nom de page invalide, avec un ou plusieurs caractères suivants :
< > @ ~ : * € £ ` + = / \ | [ ] { } ; ? #