Gravity: I2C级联扩展器

简介

Gravity: I2C扩展器专门用于解决I2C器件地址的冲突,通过这款扩展器的转接,连接到主控板同一个I2C口上的多个相同地址的I2C器件就可以正常通信并使用了。

当你辛辛苦苦找到了所需的传感器,并且想在主控板的I2C口上级联2个或者更多的传感器,但不久你发现传感器的I2C地址竟然是固定的!也就是说,不能在同一个I2C口上使用多个传感器!天啊,这可怎么办啊?我不想再换传感器了。别慌!DFRobot的Gravity: I2C扩展器就是专门解决I2C地址的冲突。通过这个扩展器的转接,你可以在同一个I2C口上接多个相同地址的I2C器件并且正常使用啦。

这个扩展器易于使用,即插即用,无需焊接。1个扩展器上有8个I2C接口,这就意味着:1个扩展器转接后,可以在同一个I2C口上接8个相同地址的器件并正常使用。这个扩展器默认的地址为0x70,地址是可以改变的,根据你的需要,可以在0x70~0x77之内做设定。理论上,在0x70~0x77的地址内可以级联8个扩展器,每个扩展器又可以接8个相同地址的器件,这就实现了同一个I2C口接64个相同地址的器件并正常使用,非常的强大!

warning_yellow.png注意:如果只是I2C(SCL、SDA)接口不够用(例如想同时接3个I2C模块而扩展板只有2个接口时)应选择I2C分线模块 [点击跳转]

技术规格

  • 工作电压:3.3~5.0V
  • 接口类型:PH2.0-4P
  • 接口电平:高电平3.3V,低电平0V
  • 接口协议:I2C
  • I2C时钟频率:100K,400K
  • I2C端口数量:8
  • 默认I2C地址:0x70(拨码开关全部拨向0)
  • I2C地址范围:0x70~0x77
  • 产品尺寸:32*32mm

引脚说明

标号 名称 功能描述
+ VCC 电源正极(3.3~5V)
- GND 电源负极(0V)
C SCL I2C时钟信号线SCL
D SDA I2C数据信号线SDA
R RESET 复位,低电平有效

引脚说明

拨码开关说明:
如上图所示,拨码开关默认全部拨向右端,即标有‘0’的一端,此时A2A1A0全部为低电平,因此模块的默认地址为0x70。如拨码开关全部拨向左端,即标有‘1’的一端,此时A2A1A0全部为高电平,此时地址为0x77。您可以根据需要,调节拨码开关来设定地址,可在0x70~0x77内做设定。

使用教程

本教程以两块OLED显示屏为例来演示如何使用这款I2C扩展器。
本例中采用的OLED显示屏,I2C地址是固定的,因此这两块OLED屏幕不能直接同时级联到同一个I2C口上使用。但通过I2C扩展器的转接,主控板的一个I2C口就能正常的同时使用这2块OLED显示屏了。

准备

' 硬件'

  • 1 x Arduino UNO(或类似的控制板)
  • 1 x Gravity: I2C扩展器
  • 2 x Gravity I2C OLED-2864 显示屏(或类似的2块I2C地址一样的模块)
  • 3 x Gravity 4pin传感器连接线(或若干杜邦线)

软件

接线图

操作步骤

  • 将I2C扩展器的I2C接口(PH2.0-4P贴片座子)连接到Arduino主控板的I2C接口上

  • 将两块OLED显示屏的I2C接口分别连接到I2C扩展器的0端口和1端口(彩色排针)

  • Arduino主控板通过USB线与电脑连接,打开Arduino IDE,安装好库文件后,编译Multi_SSD1306.ino并上传到Arduino主控板即可看到样例代码的运行效果

样例代码

请先下载[https://github.com/DFRobot/DFRobot_I2C_MultiplexerDFRobot_I2C_Multiplexer库][https://github.com/DFRobot/DFRobot_SSD1306/archive/master.zipDFRobot_SSD1306库] [https://github.com/DFRobot/DFRobot_Display/archive/master.zipDFRobot_Display库]并安装。 如何安装库?

 /*!
 * @file multiSsd1306.ino
 * @brief Connect two SSD1306 devices to the port 0 and  port 1 on the i2c multiplexer respectively 
 * @n     and then connect the I2c multiplexer and Arduino, download this sample. The address of I2C and
 * @n     the name of SSD1306 display module can be seen.
 * @n     Download Display library https://github.com/DFRobot/DFRobot_Display.git
 * @n     Download SSD1306 library https://github.com/DFRobot/DFRobot_SSD1306.git
 * @detail  I2C address selection
 * @n       A2  A1  A0  I2C_addr
 * @n       0   0   0   0x70(default)
 * @n       0   0   1   0x71
 * @n       0   1   0   0x72
 * @n       0   1   1   0x73
 * @n       1   0   0   0x74
 * @n       1   0   1   0x75
 * @n       1   1   0   0x76
 * @n       1   1   1   0x77
 * @copyright   Copyright (c) 2010 DFRobot Co.Ltd (http://www.dfrobot.com)
 * @license     The MIT License (MIT)
 * @author      PengKaixing(kaixing.peng@dfrobot.com)
 * @maintainer  [qsjhyy](yihuan.huang@dfrobot.com)
 * @version  V1.0
 * @date  2022-12-06
 * @url https://github.com/DFRobot/DFRobot_I2C_Multiplexer
 */
#include "DFRobot_SSD1306_I2C.h"
#include "DFRobot_I2C_Multiplexer.h"

/*Create an OLED object, the address is 0x3c*/ 
DFRobot_SSD1306_I2C OLED(0x3c);

/*Create an I2C Multiplexer object, the address of I2C Multiplexer is 0X70*/
DFRobot_I2C_Multiplexer I2CMulti(&Wire, 0x70);

void setup(void){
  I2CMultiplexer.begin();
  /*Let the OLED on port 0 display characters*/
  /**
   * @brief Enable a specific channel on the I2C multiplexer or disable all channels
   * @param port - Select channel, range: 0 - 8
   * @n 0-7 for enabling the corresponding channel separately, 8 for disabling all channels 
   * @note When“multiple multiplexer modules” are used on one I2C bus to connect “sensors with same I2C address”, to avoid conflicts,  
   * @n it is necessary to ensure that “the currently used channel”is the only enabled one among “all channels in all multiplexers” 
   * @n For instance, when one of the channels in the first multiplexer is enabled, in order to use any channel in the second multiplexer,  
   * @n please make sure that the channels in the first multiplexer are all disabled.
   */
  I2CMulti.selectPort(0);
  // Initialize OLED
  OLED.begin();                
  OLED.setTextColor(1);
  OLED.setTextSize(2);

  // Set the corrdianate of characters
  OLED.setCursor(0,0);
  // Display characters
  OLED.print("device A");       
  OLED.setCursor(0,30);
  OLED.print("addr:0x3C");
  /**
   * Disable all channels to avoid interference when using multiple multiplexer.
   * If only one multiplexer is used, you don't need to do that.
   */
  // I2CMulti.selectPort(8);

  /*Let OLED on port 1 display characters */
  I2CMulti.selectPort(1);
  OLED.begin();
  OLED.setTextColor(1);
  OLED.setTextSize(2);
  
  OLED.setCursor(0,0);
  OLED.print("device B");
  OLED.setCursor(0,30);
  OLED.print("addr:0x3C");
  /**
   * Disable all channels to avoid interference when using multiple multiplexer.
   * If only one multiplexer is used, you don't need to do that.
   */
  // I2CMulti.selectPort(8);
}

void loop(void){
}

结果

如下图所示,虽然两个OLED屏幕的I2C地址是一样的,但通过I2C扩展器的转接后,都能正常显示了。

程序框架

通过上述的案例,我们已经了解了这款I2C扩展器的硬件和软件是怎么使用的。现在对软件进一步概括,可得出如下的软件框架,该框架可更好的帮助你理解软件库并应用到您的项目中。


    #include "DFRobot_I2CMultiplexer.h"
    #include <Wire.h>

    DFRobot_I2C_Multiplexer I2CMulti(&Wire, 0x70);   //Create an I2C Multiplexer Object;Default Address: 0x70

    void setup(void)
    {
      I2CMulti.selectPort(0);       //Select Port 0
      ...                           //Initialize the I2C Device on Port 0

      I2CMulti.selectPort(1);      //Select Port 1
      ...                          //Initialize the I2C Device on Port 1

       .
       .
       .

      I2CMulti.selectPort(7);      //Select Port 7
      ...                          //Initialize the I2C Device on Port 7
    }

    void loop(void)
    {
      I2CMulti.selectPort(0);       //Select Port 0
      ...                           //Communicate with the I2C Device on Port 0

      I2CMulti.selectPort(1);      //Select Port 1
      ...                          //Communicate with the I2C Device on Port 1

       .
       .
       .

      I2CMulti.selectPort(7);      //Select Port 7
      ...                          //Communicate with the I2C Device on Port 7
    }

Mind+图形化编程

1、下载及安装软件。下载地址:http://www.mindplus.cc 详细教程:Mind+基础wiki教程-软件下载安装
2、切换到“上传模式”。 详细教程:Mind+基础wiki教程-上传模式编程流程
3、“扩展”中选择“主控板”中的“Arduino Uno”,“显示器”中选择“OLED2864显示屏”,“功能模块”选择“I2C级联扩展器”。 详细教程:Mind+基础wiki教程-加载扩展库流程
4、进行编程,程序如下图:
5、菜单“连接设备”,“上传到设备”
6、程序上传完毕后,即可看到效果。详细教程:Mind+基础wiki教程-串口打印

warning_yellow.png注意:如果只是I2C(SCL、SDA)接口不够用(例如想同时接3个I2C模块而扩展板只有2个接口时)应选择I2C分线模块 [点击跳转]

warning_yellow.png**注意:**此级联模块仅Mind+内置I2C模块可级联,其他第三方库如未进行适配则可能无法正常使用。

Gravity:I2C扩展器mind+示例程序

常见问题

还没有客户对此产品有任何问题,欢迎通过qq或者论坛联系我们!

更多问题及有趣的应用,可以 访问论坛 进行查阅或发帖。 |

更多

DFshopping_car1.png DFRobot商城购买链接