======== 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 |}}




<code c mcp23017.ino>



// 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 <Wire.h>
#include <Adafruit_MCP23017.h>

#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);
  }

}

</code>


==== 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 <nom de la bibliothèque> 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. 