Ligne 1 : | Ligne 1 : | ||
{{Tuto Details | {{Tuto Details | ||
− | |Main_Picture= | + | |Main_Picture=Code_minimal_des_fonctions_r_seau_WiKi_Reseau.png |
− | |Licences=Attribution | + | |Licences=Attribution (CC-BY) |
− | |Description= | + | |Description=Nous allons résumer ici les différentes façons d'utiliser les fonction réseau des cartes compatibles Arduino possédant une puce Wi-Fi (Wemos D1 mini, ESP32, ...). Ces fonctions vont permettre à ces cartes de discuter entre elles, d'accéder à un site web, ou même de se comporter elles-même comme un (mini) site web. |
− | + | |Disciplines scientifiques=Arduino, Computing | |
− | + | |Difficulty=Technical | |
− | |Disciplines scientifiques=Arduino, Computing | + | |Duration=10 |
− | |Difficulty= | ||
− | |Duration= | ||
|Duration-type=hour(s) | |Duration-type=hour(s) | ||
+ | |Tags=Wi-Fi, HTTP, MQTT, JSON | ||
}} | }} | ||
{{Introduction | {{Introduction | ||
− | |Introduction= | + | |Introduction=Cette expérience regroupe différentes manières de bénéficier des capacités de communication des cartes compatibles Arduino possédant une puce Wi-Fi. On suppose (''Cf. "Expériences ré-requises" ci-après'') que vous avez déjà manipulé une carte Arduino et son environnement de développement. '''Toutes les étapes décrites ici sont en fait indépendantes''' : |
− | + | <br /> | |
− | + | *Les deux premières étapes permettent à notre carte de se connecter au Wi-Fi, de façon basique ('''étape 1''') ou un peu plus évoluée, et souple ('''étape 2''') ; | |
+ | *L''''étape 3''' permet à la carte d'être dans un mode particulier, dit "AP"(Access Point") et se comporter comme une borne Wi-Fi. | ||
+ | *Les étapes suivantes correspondent à des besoins différents : | ||
+ | **'''étape 4''' : visualiser et/ou modifier des paramètres de notre carte via une interface web ; | ||
+ | **'''étape 5''' : permettre à notre carte d'accéder à des données d'un site externe, utilisant le format standardisé '''JSON''' <sup>(1)</sup> | ||
+ | **'''étape 6''' : permettre à notre carte d'envoyer et de recevoir des messages courts, via le protocole standardisé '''MQTT''' <sup>(1)</sup> | ||
− | + | Dans la même philosophie que les expériences "[https://www.wikidebrouillard.org/wiki/Code_minimal_des_capteurs_pour_Arduino Code minimal des capteurs pour Arduino]" et "[https://www.wikidebrouillard.org/wiki/Code_minimal_des_actionneurs_pour_Arduino Code minimal des actionneurs pour Arduino]", <u>nous fournirons ici uniquement le code relatif à nos besoins de connexion</u>, sans mettre au point une quelconque application. Donc, ici, pas besoin de connecter une led ou un capteur, donc <u>pas de schéma de montage</u> : vous branchez simplement votre carte en USB sur votre ordinateur, et les résultats seront visibles en mode texte dans le moniteur série de l'environnement de développement Arduino. | |
− | |||
− | + | Il existe bien sûr déjà un tas de tutoriels avec des exemples similaires, sans compter bien sûr les exemples fournis avec les bibliothèques que l'on va utiliser <sup>(2)</sup>. La modeste contribution de de cette page est de tenter de regrouper les cas de figures les plus importants. S'il en manque, n'hésitez pas à mettre un commentaire, voire à ajouter une étape ! | |
− | + | '''(1)''' ''Pas d'inquiétude sur les "JSON "et autre "MQTT", on explique tout dans les étapes correspondantes'' | |
+ | |||
+ | '''(2)''' ''On donnera d'ailleurs les liens vers les bibliothèques et leurs exemples à chaque étape.'' | ||
}} | }} | ||
{{Materials | {{Materials | ||
|ItemList={{ItemList | |ItemList={{ItemList | ||
− | |Item= | + | |Item=D1 mini |
}}{{ItemList | }}{{ItemList | ||
− | |Item= | + | |Item=Câble USB - micro-USB |
}}{{ItemList | }}{{ItemList | ||
− | |Item= | + | |Item=Logiciel Arduino |
}} | }} | ||
|Prerequisites={{Prerequisites | |Prerequisites={{Prerequisites | ||
− | |Prerequisites= | + | |Prerequisites=Installer l'environnement Arduino sur votre système |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
}}{{Prerequisites | }}{{Prerequisites | ||
− | |Prerequisites= | + | |Prerequisites=Premiers pas avec Arduino |
}}{{Prerequisites | }}{{Prerequisites | ||
− | |Prerequisites= | + | |Prerequisites=Utiliser le D1 mini avec Arduino |
− | |||
− | |||
− | |||
}} | }} | ||
}} | }} | ||
{{Tuto Step | {{Tuto Step | ||
− | |Step_Title= | + | |Step_Title=Connexion Wi-Fi de base |
− | |Step_Content='' | + | |Step_Content=Cette première étape permet à un Wemos D1 mini (ou autre carte compatible Arduino avec puce Wi-Fi) de se connecter au Wi-Fi dans un environnement connu, et qui ne change pas ; C'est-à-dire que l'on à accès à une borne Wi-Fi, on connait son mot de passe - aka "clé de sécurité réseau", et a priori la carte va rester dans cet environnement. |
+ | |||
+ | |||
+ | '''METTRE LIEN(S) vers description et exemples''' | ||
+ | |||
+ | |||
+ | {| class="wikitable" cellspacing="0" border="0" | ||
+ | | height="17" bgcolor="#999999" align="left" | | ||
+ | | valign="middle" bgcolor="#999999" align="center" | | ||
+ | | bgcolor="#999999" align="center" |Connexion Wi-Fi de base | ||
+ | |- | ||
+ | | rowspan="2" valign="middle" height="49" bgcolor="#999999" align="center" |Avant le Setup | ||
+ | | valign="middle" bgcolor="#999999" align="center" |Importation de la bibliothèque | ||
+ | | valign="middle" align="left" | | ||
+ | |- | ||
+ | | valign="middle" bgcolor="#999999" align="center" |Création de l’objet | ||
+ | | valign="middle" align="left" | | ||
+ | |- | ||
+ | | valign="middle" height="17" bgcolor="#999999" align="center" |Dans le Setup | ||
+ | | valign="middle" bgcolor="#999999" align="center" |Démarrage de l’objet | ||
+ | | valign="middle" align="left" | | ||
+ | |- | ||
+ | | valign="middle" height="41" bgcolor="#999999" align="center" |Dans le Loop | ||
+ | | valign="middle" bgcolor="#999999" align="center" |Utilisation | ||
+ | | valign="middle" align="left" | | ||
+ | |}<br /><syntaxhighlight lang="arduino" line="1"> | ||
+ | /* ========================================================================================================= | ||
+ | * | ||
+ | * CODE MINIMAL RESEAU - ETAPE 1 : connexion basique au Wi-Fi | ||
+ | * | ||
+ | * --------------------------------------------------------------------------------------------------------- | ||
+ | * Les petits Débrouillards - décembre 2022 - CC-By-Sa http://creativecommons.org/licenses/by-nc-sa/3.0/ | ||
+ | * ========================================================================================================= */ | ||
+ | |||
+ | // Bibliothèques WiFi : UNE SEULE EST NECESSAIRE, choisir celle correspondant à votre matériel. | ||
+ | // ATTENTION AUX MAJUSCULES & MINUSCULES ! Sinon d'autres bibliothèques, plus ou moins valides, seraient utilisées. | ||
+ | |||
+ | #include <ESP8266WiFi.h> // A utiliser pour le D1 Mini | ||
+ | //#include <WiFi.h> // A utiliser pour l'ESP32 | ||
+ | |||
+ | // Définition du point d'accès Wi-Fi et de son mot de passe ("clé de sécurité") | ||
+ | // A REMPLACER PAR LES VERITABLES VALEURS CORRESPONDANT A VOTRE EMPLACEMENT | ||
+ | |||
+ | const char* mySSID = "Livebox-45b4" ; // "MA_BOX_INTERNET"; | ||
+ | const char* mySecKey = "A7E46C7762757D254AF4AF432A" ; // "MA_CLE_DE_SECURITE"; | ||
+ | |||
+ | /* -------------------------------------------------------------------------------------------------------- | ||
+ | * SETUP : Initialisation | ||
+ | * -------------------------------------------------------------------------------------------------------- */ | ||
+ | void setup() { | ||
+ | |||
+ | // Initialisation de la liaison série, affichage 1er message | ||
+ | Serial.begin(115200); | ||
+ | delay(100) ; | ||
+ | Serial.println(); | ||
+ | Serial.println("----------------------------------") ; | ||
+ | Serial.println("Exemple de connexion Wi-Fi basique") ; | ||
+ | Serial.println("----------------------------------") ; | ||
− | ' | + | // Initialisation de la bibliothèque avec le nom du point d'accès Wi-Fi et son mot de passe |
− | + | WiFi.begin(mySSID, mySecKey) ; | |
− | - | + | // Essai de connexion au Wi-Fi, pendant 10 secondes (20 x 500 ms) |
− | + | Serial.print("Connexion à "); Serial.print(mySSID) ; Serial.print(" ") ; | |
+ | int tryNumber = 1 ; | ||
+ | while (WiFi.status() != WL_CONNECTED) | ||
+ | { | ||
+ | delay(500); | ||
+ | Serial.print("."); | ||
+ | if (++tryNumber > 20) { | ||
+ | Serial.println() ; Serial.println("Pas de connexion, abandon") ; | ||
+ | return ; | ||
+ | } | ||
+ | } | ||
+ | // La connexion a réussi ! On affiche l'adresse IP obtenue. | ||
+ | |||
+ | Serial.println(); Serial.print("Connecté ! Adresse IP : "); | ||
+ | Serial.println(WiFi.localIP()); | ||
+ | |||
+ | } | ||
− | + | /* -------------------------------------------------------------------------------------------------------------- | |
+ | * LOOP : fonction appelée régulièrement par le système | ||
+ | * ------------------------------------------------------------------------------------------------------------- */ | ||
+ | void loop() { | ||
+ | /* On ne fait rien de particulier sur cet exemple */ | ||
+ | } | ||
− | + | ||
− | + | ||
− | + | </syntaxhighlight><br /> | |
− | |||
− | |||
− | |||
− | |||
}} | }} | ||
{{Tuto Step | {{Tuto Step | ||
− | |Step_Title= | + | |Step_Title=Oui, mais si mon Wi-Fi change ? |
− | |Step_Content= | + | |Step_Content=Dans l'étape précédente on supposait que le Wi-Fi était permanent (cas où les cartes ne quittent pas notre labo, par exemple). Mais si on souhaite faire voyager nos cartes (démos dans des écoles, etc ...), on a deux possibilités |
+ | |||
+ | *on vient avec son environnement de développement Arduino, on met à jour le code Arduino avec les nouvelles informations Wi-Fi, et on téléverse le code sur toutes nos cartes ... un peu laborieux ... | ||
+ | *on utilise la bibliothèque "wifimanager", qui nous simplifie grandement la tâche ! | ||
+ | |||
+ | (... à suivre) | ||
+ | |||
+ | '''METTRE LIEN(S) vers description et exemples''' | ||
− | -> | + | {| class="wikitable" cellspacing="0" border="0" |
+ | | height="17" bgcolor="#999999" align="left" | | ||
+ | | valign="middle" bgcolor="#999999" align="center" | | ||
+ | | bgcolor="#999999" align="center" |Wifimanager | ||
+ | |- | ||
+ | | rowspan="2" valign="middle" height="49" bgcolor="#999999" align="center" |Avant le Setup | ||
+ | | valign="middle" bgcolor="#999999" align="center" |Importation de la bibliothèque | ||
+ | | valign="middle" align="left" | | ||
+ | |- | ||
+ | | valign="middle" bgcolor="#999999" align="center" |Création de l’objet | ||
+ | | valign="middle" align="left" | | ||
+ | |- | ||
+ | | valign="middle" height="17" bgcolor="#999999" align="center" |Dans le Setup | ||
+ | | valign="middle" bgcolor="#999999" align="center" |Démarrage de l’objet | ||
+ | | valign="middle" align="left" | | ||
+ | |- | ||
+ | | valign="middle" height="41" bgcolor="#999999" align="center" |Dans le Loop | ||
+ | | valign="middle" bgcolor="#999999" align="center" |Utilisation | ||
+ | | valign="middle" align="left" | | ||
+ | |}<br /><syntaxhighlight lang="arduino" line="1"> | ||
+ | //////////////////////// | ||
+ | // *Code Minimal* // | ||
+ | // Wi-Fi Manager // | ||
+ | //////////////////////// | ||
+ | /*Les programmes "Code Minimal" des petits débrouillards sont conçu pour | ||
+ | permettre la prise en main rapide d'un composant électronique. | ||
+ | A retrouver sur https://www.wikidebrouillard.org | ||
− | + | (...) | |
+ | |||
+ | ___ | ||
+ | / ___ \ | ||
+ | |_| | | | ||
+ | /_/ | ||
+ | _ ___ _ | ||
+ | |_| |___|_| |_ | ||
+ | ___|_ _| | ||
+ | |___| |_| | ||
− | - | + | Les petits Débrouillards - décembre 2020 - CC-By-Sa http://creativecommons.org/licenses/by-nc-sa/3.0/ |
− | + | */ | |
− | + | // Déclaration des variables constantes | |
+ | (...) | ||
− | + | // Boucle d'initialisation | |
+ | void setup() { | ||
+ | (...) | ||
− | + | } | |
− | <br /> | + | //Boucle principale |
− | + | void loop() { | |
− | | | + | |
+ | (...) | ||
+ | |||
+ | } | ||
+ | </syntaxhighlight><br /> | ||
+ | }} | ||
+ | {{Tuto Step | ||
+ | |Step_Title=Et si je veux rester en mode AP (Access Point ?) | ||
}} | }} | ||
{{Tuto Step | {{Tuto Step | ||
− | |Step_Title= | + | |Step_Title=Et maintenant, on fait quoi avec le Wi-Fi ? (tiens, pourquoi pas un petit serveur web ?) |
− | | | + | |Step_Content=... Site web pour allumer une led (à détailler) |
+ | |||
+ | '''METTRE LIEN(S) vers description et exemples''' | ||
+ | {| class="wikitable" cellspacing="0" border="0" | ||
+ | | height="17" bgcolor="#999999" align="left" | | ||
+ | | valign="middle" bgcolor="#999999" align="center" | | ||
+ | | bgcolor="#999999" align="center" |Site web | ||
+ | |- | ||
+ | | rowspan="2" valign="middle" height="49" bgcolor="#999999" align="center" |Avant le Setup | ||
+ | | valign="middle" bgcolor="#999999" align="center" |Importation de la bibliothèque | ||
+ | | valign="middle" align="left" | | ||
+ | |- | ||
+ | | valign="middle" bgcolor="#999999" align="center" |Création de l’objet | ||
+ | | valign="middle" align="left" | | ||
+ | |- | ||
+ | | valign="middle" height="17" bgcolor="#999999" align="center" |Dans le Setup | ||
+ | | valign="middle" bgcolor="#999999" align="center" |Démarrage de l’objet | ||
+ | | valign="middle" align="left" | | ||
+ | |- | ||
+ | | valign="middle" height="41" bgcolor="#999999" align="center" |Dans le Loop | ||
+ | | valign="middle" bgcolor="#999999" align="center" |Utilisation | ||
+ | | valign="middle" align="left" | | ||
+ | |}<br /><syntaxhighlight lang="arduino" line="1"> | ||
+ | //////////////////////// | ||
+ | // *Code Minimal* // | ||
+ | // Wi-Fi de base // | ||
+ | //////////////////////// | ||
+ | /*Les programmes "Code Minimal" des petits débrouillards sont conçu pour | ||
+ | permettre la prise en main rapide d'un composant électronique. | ||
+ | A retrouver sur https://www.wikidebrouillard.org | ||
+ | |||
+ | (...) | ||
+ | |||
+ | ___ | ||
+ | / ___ \ | ||
+ | |_| | | | ||
+ | /_/ | ||
+ | _ ___ _ | ||
+ | |_| |___|_| |_ | ||
+ | ___|_ _| | ||
+ | |___| |_| | ||
+ | |||
+ | Les petits Débrouillards - décembre 2020 - CC-By-Sa http://creativecommons.org/licenses/by-nc-sa/3.0/ | ||
− | + | */ | |
− | + | // Déclaration des variables constantes | |
+ | (...) | ||
− | + | // Boucle d'initialisation | |
− | + | void setup() { | |
− | + | ||
− | + | (...) | |
− | |||
− | |||
− | |||
− | |||
− | + | } | |
+ | //Boucle principale | ||
+ | void loop() { | ||
− | + | (...) | |
− | + | } | |
− | + | </syntaxhighlight><br /> | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | + | Une application plus complète, permettant d'actionner plusieurs leds et un moteur, et de récupérer des données d'un capteur, est disponible [https://www.wikidebrouillard.org/wiki/Commander_un_D1_mini_avec_une_interface_web ici]. | |
− | |||
− | + | L'utilisation de notre carte en mode n'est qu'un exemple de ce qu'il est possible de faire, il existe plein d'autres possibilités, détaillées dans les étapes suivantes ! | |
− | + | }} | |
− | + | {{Tuto Step | |
− | | | + | |Step_Title=Interrogation de serveurs web (mode JSON) |
− | + | }} | |
− | + | {{Tuto Step | |
− | | | + | |Step_Title=Diffusion d'information (mode MQTT) |
}} | }} | ||
{{Notes}} | {{Notes}} | ||
{{Tuto Status | {{Tuto Status | ||
− | |Complete= | + | |Complete=Draft |
}} | }} |
Auteur Philippe Blusseau | Dernière modification 6/02/2023 par Philby
Wi-Fi, HTTP, MQTT, JSON Code_minimal_des_fonctions_r_seau_WiKi_Reseau.png
Cette expérience regroupe différentes manières de bénéficier des capacités de communication des cartes compatibles Arduino possédant une puce Wi-Fi. On suppose (Cf. "Expériences ré-requises" ci-après) que vous avez déjà manipulé une carte Arduino et son environnement de développement. Toutes les étapes décrites ici sont en fait indépendantes :
Dans la même philosophie que les expériences "Code minimal des capteurs pour Arduino" et "Code minimal des actionneurs pour Arduino", nous fournirons ici uniquement le code relatif à nos besoins de connexion, sans mettre au point une quelconque application. Donc, ici, pas besoin de connecter une led ou un capteur, donc pas de schéma de montage : vous branchez simplement votre carte en USB sur votre ordinateur, et les résultats seront visibles en mode texte dans le moniteur série de l'environnement de développement Arduino.
Il existe bien sûr déjà un tas de tutoriels avec des exemples similaires, sans compter bien sûr les exemples fournis avec les bibliothèques que l'on va utiliser (2). La modeste contribution de de cette page est de tenter de regrouper les cas de figures les plus importants. S'il en manque, n'hésitez pas à mettre un commentaire, voire à ajouter une étape !
(1) Pas d'inquiétude sur les "JSON "et autre "MQTT", on explique tout dans les étapes correspondantes
Cette première étape permet à un Wemos D1 mini (ou autre carte compatible Arduino avec puce Wi-Fi) de se connecter au Wi-Fi dans un environnement connu, et qui ne change pas ; C'est-à-dire que l'on à accès à une borne Wi-Fi, on connait son mot de passe - aka "clé de sécurité réseau", et a priori la carte va rester dans cet environnement.
METTRE LIEN(S) vers description et exemples
Connexion Wi-Fi de base | ||
Avant le Setup | Importation de la bibliothèque | |
Création de l’objet | ||
Dans le Setup | Démarrage de l’objet | |
Dans le Loop | Utilisation |
1 /* =========================================================================================================
2 *
3 * CODE MINIMAL RESEAU - ETAPE 1 : connexion basique au Wi-Fi
4 *
5 * ---------------------------------------------------------------------------------------------------------
6 * Les petits Débrouillards - décembre 2022 - CC-By-Sa http://creativecommons.org/licenses/by-nc-sa/3.0/
7 * ========================================================================================================= */
8
9 // Bibliothèques WiFi : UNE SEULE EST NECESSAIRE, choisir celle correspondant à votre matériel.
10 // ATTENTION AUX MAJUSCULES & MINUSCULES ! Sinon d'autres bibliothèques, plus ou moins valides, seraient utilisées.
11
12 #include <ESP8266WiFi.h> // A utiliser pour le D1 Mini
13 //#include <WiFi.h> // A utiliser pour l'ESP32
14
15 // Définition du point d'accès Wi-Fi et de son mot de passe ("clé de sécurité")
16 // A REMPLACER PAR LES VERITABLES VALEURS CORRESPONDANT A VOTRE EMPLACEMENT
17
18 const char* mySSID = "Livebox-45b4" ; // "MA_BOX_INTERNET";
19 const char* mySecKey = "A7E46C7762757D254AF4AF432A" ; // "MA_CLE_DE_SECURITE";
20
21 /* --------------------------------------------------------------------------------------------------------
22 * SETUP : Initialisation
23 * -------------------------------------------------------------------------------------------------------- */
24 void setup() {
25
26 // Initialisation de la liaison série, affichage 1er message
27
28 Serial.begin(115200);
29 delay(100) ;
30 Serial.println();
31 Serial.println("----------------------------------") ;
32 Serial.println("Exemple de connexion Wi-Fi basique") ;
33 Serial.println("----------------------------------") ;
34
35 // Initialisation de la bibliothèque avec le nom du point d'accès Wi-Fi et son mot de passe
36
37 WiFi.begin(mySSID, mySecKey) ;
38
39 // Essai de connexion au Wi-Fi, pendant 10 secondes (20 x 500 ms)
40
41 Serial.print("Connexion à "); Serial.print(mySSID) ; Serial.print(" ") ;
42 int tryNumber = 1 ;
43 while (WiFi.status() != WL_CONNECTED)
44 {
45 delay(500);
46 Serial.print(".");
47 if (++tryNumber > 20) {
48 Serial.println() ; Serial.println("Pas de connexion, abandon") ;
49 return ;
50 }
51 }
52
53 // La connexion a réussi ! On affiche l'adresse IP obtenue.
54
55 Serial.println(); Serial.print("Connecté ! Adresse IP : ");
56 Serial.println(WiFi.localIP());
57
58 }
59
60 /* --------------------------------------------------------------------------------------------------------------
61 * LOOP : fonction appelée régulièrement par le système
62 * ------------------------------------------------------------------------------------------------------------- */
63 void loop() {
64 /* On ne fait rien de particulier sur cet exemple */
65 }
Dans l'étape précédente on supposait que le Wi-Fi était permanent (cas où les cartes ne quittent pas notre labo, par exemple). Mais si on souhaite faire voyager nos cartes (démos dans des écoles, etc ...), on a deux possibilités
(... à suivre)
METTRE LIEN(S) vers description et exemples
Wifimanager | ||
Avant le Setup | Importation de la bibliothèque | |
Création de l’objet | ||
Dans le Setup | Démarrage de l’objet | |
Dans le Loop | Utilisation |
1 ////////////////////////
2 // *Code Minimal* //
3 // Wi-Fi Manager //
4 ////////////////////////
5 /*Les programmes "Code Minimal" des petits débrouillards sont conçu pour
6 permettre la prise en main rapide d'un composant électronique.
7 A retrouver sur https://www.wikidebrouillard.org
8
9 (...)
10
11 ___
12 / ___ \
13 |_| | |
14 /_/
15 _ ___ _
16 |_| |___|_| |_
17 ___|_ _|
18 |___| |_|
19
20 Les petits Débrouillards - décembre 2020 - CC-By-Sa http://creativecommons.org/licenses/by-nc-sa/3.0/
21
22 */
23
24 // Déclaration des variables constantes
25 (...)
26
27 // Boucle d'initialisation
28 void setup() {
29
30 (...)
31
32 }
33
34 //Boucle principale
35 void loop() {
36
37 (...)
38
39 }
... Site web pour allumer une led (à détailler)
METTRE LIEN(S) vers description et exemples
Site web | ||
Avant le Setup | Importation de la bibliothèque | |
Création de l’objet | ||
Dans le Setup | Démarrage de l’objet | |
Dans le Loop | Utilisation |
1 ////////////////////////
2 // *Code Minimal* //
3 // Wi-Fi de base //
4 ////////////////////////
5 /*Les programmes "Code Minimal" des petits débrouillards sont conçu pour
6 permettre la prise en main rapide d'un composant électronique.
7 A retrouver sur https://www.wikidebrouillard.org
8
9 (...)
10
11 ___
12 / ___ \
13 |_| | |
14 /_/
15 _ ___ _
16 |_| |___|_| |_
17 ___|_ _|
18 |___| |_|
19
20 Les petits Débrouillards - décembre 2020 - CC-By-Sa http://creativecommons.org/licenses/by-nc-sa/3.0/
21
22 */
23
24 // Déclaration des variables constantes
25 (...)
26
27 // Boucle d'initialisation
28 void setup() {
29
30 (...)
31
32 }
33
34 //Boucle principale
35 void loop() {
36
37 (...)
38
39 }
Une application plus complète, permettant d'actionner plusieurs leds et un moteur, et de récupérer des données d'un capteur, est disponible ici.
L'utilisation de notre carte en mode n'est qu'un exemple de ce qu'il est possible de faire, il existe plein d'autres possibilités, détaillées dans les étapes suivantes !
Dernière modification 6/02/2023 par user:Philby.
Draft
Vous avez entré un nom de page invalide, avec un ou plusieurs caractères suivants :
< > @ ~ : * € £ ` + = / \ | [ ] { } ; ? #