Skip to content

MicroPython I2C library and example for Gravity: RGB LED button module

Notifications You must be signed in to change notification settings

Lupin3000/Micropython-I2C-RGB-Button

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MicroPython I2C library and example for Gravity: RGB LED Button

This repository contains the MicroPython I2C library for the Gravity: RGB LED Button from DFRobot, as well as a very simple example of how to use it. The original repository from DFRobot is located here (for Arduino and Raspberry Pi).

Why this repository?

The original version of DFRobot uses Python serial (UART) and Python SMBus (I2C), which are not compatible with MicroPython. Also, I was not so happy with the Python code style/quality. That's why I created this version.

Prerequisite

  • Gravity: RGB LED Button
  • ESP32 (MicroPython compatible device)
  • MicroPython firmware installed (min. 1.20.0.*)
  • USB cable (for connection between ESP32 and sensor)
  • latest VCP driver installed

RGB_LED_button.jpg

Installation

Clone this repository to your local computer.

# clone repository
$ git clone https://github.com/Lupin3000/Micropython-I2C-RGB-Button.git

# change into local repository folder
$ cd Micropython-I2C-RGB-Button/

You can optionally install other helpful Python packages.

  • esptool (to flash the MicroPython firmware to the ESP32)
  • rshell (to establish a serial connection between the local computer and the ESP32 and to transfer data)
  • micropython-esp32-stubs (to facilitate local development, for example: code completion)
# install python packages (optional)
$ pip install -r requirements.txt

Connect the sensor to the ESP32. Make sure that you have set the communication mode on the sensor to I2C and use the correct connections (ESP GPIO's/Button interface)! Only then connect the ESP32 to your local computer via USB.

In the example main.py, the GPIOs pins 21 (SDA) and 22 (SCL) are used. However, you can adapt these to your needs at any time.

Then start the serial connection and load the example and the library onto the ESP32 device.

# start rshell connection
$ rshell -p /dev/cu.usbserial-0001

# upload files and folder
/YOUR/LOCAL/PATH> cp main.py /pyboard/
/YOUR/LOCAL/PATH> cp -r lib/ /pyboard/

The example device/path /dev/cu.usbserial-0001 could be different for you! Please adapt before your execute the commands!

Usage

# start the Python REPL
/YOUR/LOCAL/PATH> repl

Now press the keys CTRL + d on your local device, to trigger the soft-reset of the ESP32. If there are no errors, you should see the following output in the terminal after a very short time.

Entering REPL. Use Control-X to exit.
>
MicroPython v1.20.0 on 2023-04-26; ESP32 module with ESP32
Type "help()" for more information.
>>> 
>>> 
MPY: soft reboot
Button initialized

Now press the button. On press the button should glow and on release the button color is black.

Additional information:

About

MicroPython I2C library and example for Gravity: RGB LED button module

Topics

Resources

Stars

Watchers

Forks

Languages