======== MCP23017 ======== Le MCP23017 utilise 2 broches I2C (SCL SDA , qui peuvent être partagées avec d'autres périphériques I2C), et en échange, il fournit 16 broches E/S d'utilisation générale en plus. {{ :start:arduino:mcp23017-layout.jpg?direct&400 |}} {{ :start:arduino:capture_du_2020-12-04_00-36-10.jpg?direct&400 |}} [[https://wiki.mchobby.be/index.php?title=MCP23017| MCP23017 16 entrées/sorties sur un arduino ]] [[https://wiki.mchobby.be/index.php?title=MCP23017-Brancher-Entr%C3%A9e|MCP23017 En Entrée]] [[https://www.best-microcontroller-projects.com/mcp23017.html|MCP23017 EN]] [[https://wiki.dfrobot.com/Gravity:%20MCP23017%20IIC%20to%2016%20Digital%20IO%20Expansion%20Module%20SKU:%20DFR0626|MCP23017 Module SKU: DFR0626 DFrobot EN ]] [[https://github.com/topics/mcp23017|Librairies sur Github pour le MCP23017]] [[https://github.com/DFRobot/DFRobot_MCP23017| Librairie DFRobot MCP23017]] [[start:arduino:mcp23017:DFROBOT|MCP23017 DFROBOT FR]] {{ :start:arduino:mcp23017_breadboard.jpg.pagespeed.ce.b9lbqy7sil.jpg?direct&400 |}} // MCP23017 Example: Slow key press reaction. // // Toggle LEDs and detect keypress. // // Example code showing slow reaction of 'button' // LED to keypress. Leading into why interrupts // are useful (See next example). // // Copyright : John Main // Free for non commercial use. #include #include #define MCP_LED1 7 #define MCP_INPUTPIN 8 #define MCP_LEDTOG1 11 #define MCP_LEDTOG2 4 Adafruit_MCP23017 mcp; void setup() { mcp.begin(); // Default device address 0 mcp.pinMode(MCP_LEDTOG1, OUTPUT); // Toggle LED 1 mcp.pinMode(MCP_LEDTOG2, OUTPUT); // Toggle LED 2 mcp.pinMode(MCP_LED1, OUTPUT); // LED output mcp.digitalWrite(MCP_LED1, HIGH); mcp.pinMode(MCP_INPUTPIN,INPUT); // Button i/p to GND mcp.pullUp(MCP_INPUTPIN,HIGH); // Puled high to ~100k } // Alternate LEDTOG1 and LEDTOG2. // Transfer pin input to LED1. void loop() { delay(300); mcp.digitalWrite(MCP_LEDTOG1, HIGH); mcp.digitalWrite(MCP_LEDTOG2, LOW); delay(300); mcp.digitalWrite(MCP_LEDTOG1, LOW); mcp.digitalWrite(MCP_LEDTOG2, HIGH); // Transfer input pin state to LED1 if (mcp.digitalRead(MCP_INPUTPIN)) { mcp.digitalWrite(MCP_LED1,HIGH); } else { mcp.digitalWrite(MCP_LED1,LOW); } } ==== Bibliothèque de logiciels et versions==== Version IDE Arduino La dernière version: 1.8.13 ( 12/2020) Bibliothèque Adafruit Bibliothèque MCP23017 pour Arduino [[http://downloads.arduino.cc/libraries/github.com/blemasle/MCP23017-2.0.0.zip| Bibliothèque Adafruit MCP23017 2.0.0]] //Ceci est facilement installé à partir de l'IDE Arduino.// Si vous ne voyez pas la bibliothèque comme une entrée lorsque vous cliquez sur les menus, installez la bibliothèque comme suit: Esquisse -> Inclure la bibliothèque Sélectionnez ensuite gérer les bibliothèques: Esquisse -> Inclure la bibliothèque -> Gérer les bibliothèques ... Recherchez et installez en utilisant le formulaire "Filtrer votre recherche". __**Fonctionnement de la bibliothèque**__ Définition des broches pour la bibliothèque MCP23017 Remarque: dans la bibliothèque, les broches sont étiquetées de 0 à 15 où: --la broche 0 est le bit 0 du port A --la broche 7 est le bit 7 du port A --la broche 8 est le bit 0 du port B --la broche 15 est le bit 7 du port B **__Fonctions de contrôle E / S du MCP23017__** **E / S à bit unique** Des fonctions membres similaires aux commandes de broches sur l'Arduino sont utilisées pour contrôler les broches MCP23017: mcp.pinMode (0, SORTIE); mcp.digitalWrite (0, HAUT); mcp.digitalRead (0); **Connexions Netlist simples** La netlist et le diagramme suivants vous montrent comment la connexion du MCP23017 à l'Arduino est très simple. Connectez la broche n ° 12 de l'extenseur à Arduino Analog 5 (horloge i2c) Connectez la broche n ° 13 de l'extenseur à Arduino Analog 4 (données i2c) Connectez la broche n ° 19 de l'extension à la broche 3 d'Arduino (entrée d'interruption). Connectez les broches n ° 15, 16 et 17 de l'extension à la masse Arduino (sélection d'adresse) Connectez la broche n ° 9 de l'extenseur à Arduino 5V (alimentation) Connectez la broche n ° 10 de l'extenseur à la terre Arduino (masse commune) Connectez la broche n ° 18 de l'expanseur à travers une résistance ~ 10 kohm à 5 V (broche de réinitialisation, actif bas). Connectez la broche # 28 de l'extenseur à l'extrémité + ve d'une LED puis à une résistance ~ 1kohm à GND (MCP_LED1). Connectez la broche # 26 de l'extenseur à l'extrémité + ve d'une LED puis à une résistance ~ 1kohm à GND (MCP_LEDTOG1). Connectez la broche n ° 4 de l'extenseur à l'extrémité + ve d'une LED puis à une résistance ~ 1kohm à GND (MCP_LEDTOG2). Connectez la broche n ° 1 du module d'extension à un bouton-poussoir normalement ouvert qui se connecte ensuite à GND (MCP_INPUTPIN). **Remarque:** les pullups sont activés pour les broches I2C dans la bibliothèque "Wire" et ne sont donc pas affichés dans la connexion ou la disposition du circuit ci-dessus (ci-dessous). Ils ont une valeur élevée (probablement 50k ~ 100k), donc pour un front montant plus rapide sur les signaux I2C, utilisez des résistances d'extraction physiques de valeur inférieure qui remplaceront la valeur élevée.