Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jminjares4/esp32-lcd-1602-driver
ESP32 LCD device driver using esp-idf
https://github.com/jminjares4/esp32-lcd-1602-driver
esp32 esp32-idf lcd-display lcd1602
Last synced: about 1 month ago
JSON representation
ESP32 LCD device driver using esp-idf
- Host: GitHub
- URL: https://github.com/jminjares4/esp32-lcd-1602-driver
- Owner: jminjares4
- License: mit
- Created: 2022-07-25T02:02:44.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-10-10T21:23:31.000Z (over 2 years ago)
- Last Synced: 2024-11-11T15:43:40.867Z (3 months ago)
- Topics: esp32, esp32-idf, lcd-display, lcd1602
- Language: C
- Homepage:
- Size: 12.8 MB
- Stars: 6
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
![]()
[![esp-idf build](https://github.com/jminjares4/ESP32-LCD-1602-Driver/actions/workflows/build.yml/badge.svg?branch=main)](https://github.com/jminjares4/ESP32-LCD-1602-Driver/actions/workflows/build.yml)[![Documentation](https://github.com/jminjares4/ESP32-LCD-1602-Driver/actions/workflows/documentation.yml/badge.svg)](https://github.com/jminjares4/ESP32-LCD-1602-Driver/actions/workflows/documentation.yml)
[![pages-build-deployment](https://github.com/jminjares4/ESP32-LCD-1602-Driver/actions/workflows/pages/pages-build-deployment/badge.svg)](https://github.com/jminjares4/ESP32-LCD-1602-Driver/actions/workflows/pages/pages-build-deployment)[![GitHub Page](https://img.shields.io/badge/active-34c855.svg?style=flat&logo=github&logoColor=949da5&label=GitHub%20Page&labelColor=3f4851)](https://jminjares4.github.io/ESP32-LCD-1602-Driver/)## **Description**
This repository contains a custom lcd driver for *16x02 lcd*. The driver has the most common function calls
that are use for LCDs. ESP32 have limited GPIO pins, therefore **4-bit mode** was use as it requires a total of **6** `GPIO` pins. However, there are two configurations for the driver: default and custom. The default configurations uses [this](#lcd-16x02-pinout) pinout while the custom allows the user to select whichever `GPIO` are avaiable simple by using `lcdCtor()`.### **ESP32 Pinout**
~~~
+-----------------------+
| O | USB | O |
| ------- |
3V3 | [ ] [ ] | VIN
GND | [ ] [ ] | GND
Touch3 / HSPI_CS0 / ADC2_3 / GPIO15 | [ ] [ ] | GPIO13 / ADC2_4 / HSPI_ID / Touch4
CS / Touch2 / HSPI_WP / ADC2_2 / GPIO2 | [ ] [ ] | GPIO12 / ADC2_5 / HSPI_Q / Touch5
Touch0 / HSPI_HD / ADC2_0 / GPIO4 | [ ] [ ] | GPIO14 / ADC2_6 / HSPI_CLK / Touch6
U2_RXD / GPIO16 | [ ] [ ] | GPIO27 / ADC2_7 / Touch7
U2_TXD / GPIO17 | [ ] [ ] | GPIO26 / ADC2_9 / DAC2
V_SPI_CS0 / GPIO5 | [ ] ___________ [ ] | GPIO25 / ADC2_8 / DAC1
SCK / V_SPI_CLK / GPIO18 | [ ] | | [ ] | GPIO33 / ADC1_5 / Touch8 / XTAL32
U0_CTS / MSIO / V_SPI_Q / GPIO19 | [ ] | | [ ] | GPIO32 / ADC1_4 / Touch9 / XTAL32
SDA / V_SPI_HD / GPIO21 | [ ] | | [ ] | GPIO35 / ADC1_7
CLK2 / U0_RXD / GPIO3 | [ ] | | [ ] | GPIO34 / ADC1_6
CLK3 / U0_TXD / GPIO1 | [ ] | | [ ] | GPIO39 / ADC1_3 / SensVN
SCL / U0_RTS / V_SPI_WP / GPIO22 | [ ] | | [ ] | GPIO36 / ADC1_0 / SensVP
MOSI / V_SPI_WP / GPIO23 | [ ] |___________| [ ] | EN
| |
| | | ____ ____ | |
| | | | | | | | |
| |__|__| |__| |__| |
| O O |
+-----------------------+
~~~## **LCD 16x02 Pinout**
The following pinout is the default configuration of the ESP-LCD driver. However, the driver
is customizable to allow users to change GPIO pins if necessary.| **ESP32 Pins** | **LCD Pin** | **Description** |
| :---: | :--: | :---: |
| `GND`, 10k Potentiometer Output (V±) | 1 | GND |
| `VCC`, 10k Potentiometer Output (V±) | 2 | VCC |
| 10k Potentiometer Output (Vo) | 3 | Contrast |
| `GPIO23` | 4 | RS (Register Select): 0–Command, 1-Data |
| `GND` | 5 | R/W (Read/Write): 0 – Write, 1 - Read |
| `GPIO22` | 6 | Clock Enable |
| `NC` | 7 | Data 0 |
| `NC` | 8 | Data 1 |
| `NC` | 9 | Data 2 |
| `NC` | 10 | Data 3 |
| `GPIO19` | 11 | Data 4 |
| `GPIO18` | 12 | Data 5 |
| `GPIO17` | 13 | Data 6 |
| `GPIO16` | 14 | Data 7 |
| 100Ω to `VCC` | 15 | Backlight Anode (+) |
| `GND` | 16 | Backlight Cathode (-)|
* LCD default pin configuration
## **LCD Main Functions**| **Function** | **Description** |
| :--- | :--- |
| lcdDefault | Default pinout |
| lcdCtor | Customizable pinout constructor |
| lcdSetText | Set text |
| lcdSetInt | Set integer |
| lcdClear | Clear previous data |
| lcdFree | Free LCD pins |
| assert_lcd | Check lcd status |## **Simple Example Code**
The follow section of code demostrate how to use the lcd driver with default configuration.
~~~c
#include
#include "freertos/FreeRTOS.h"
#include "freertos/task.h"
#include "driver/esp_lcd.h"/* LCD task */
void lcd_task(void *pvParameters){/* Create LCD object */
lcd_t lcd;/* Set lcd to default pins */
lcdDefault(&lcd);/* Initialize LCD object */
lcdInit(&lcd);/* Clear previous data on LCD */
lcdClear(&lcd);while(1){
/* Display text */
lcdSetText(&lcd,"Hello World!", 0,0);
/* 1 second delay */
vTaskDelay(1000 / portTICK_PERIOD_MS);
}}
void app_main(void)
{
/* Create LCD task */
xTaskCreate(lcd_task, "LCD task", 2048, NULL, 4, NULL);}
~~~## **ESP32 LCD Driver Test**
![]()
## **Add ESP-LCD to ESP32 Project**
1) Copy driver folder
2) Paste into esp project
3) Edit project CMakeLists.txt to use esp_lcd:
```cmake
idf_component_register(SRCS "main.c"
"driver/esp_lcd.c"
INCLUDE_DIRS ".")
```## **Development**
|Microcontroller|Software|Enviroment|Operating System|
| :---| :---| :---| :---|
| ![ESP32](https://img.shields.io/static/v1?label=&logo=espressif&message=Espressif+ESP32&&color=000000) | ![C Language](https://img.shields.io/badge/Code-C-informational?style=flat&logo=C&color=003B57)| ![Visual Studio Code](https://img.shields.io/badge/Visual_Studio_Code-0078D4?style=flat&logo=visual%20studio%20code&logoColor=white&logoHeight=50&logoWidht=50) | ![FreeRTOS](https://img.shields.io/static/v1?label=OS&message=FreeRTOS&color=white&labelColor=green&logo=%2Bztbe7vcHDz9Pb293f4fHz9fX3%2Bf1wHG5lAAACEklEQVR42pXWhWKjWhgE4Km7u7u7u7u3cSU08%2F7PcO%2Fuz8HJEr5KdHDmHPjMHj%2FG8yWylI8%2FHs8ixOhNki7Jm1FUNv2sk9rX7fbScEvr8NL27ZdG6k8zCNZ%2Br5Pf%2B11w6Nr7JvX7dgRYTZHvqwHvv5OpgPf3NWY3EWgzS20fHtfkWz8q6Hsjr33fv6tBRfV3nsQ%2BeYl%2FuiT3Hful8Q4h7qgZe06iPcW3OjgN6CTdZ7n%2Bjal2Fbhntg8uxyR5A5f%2BLO%2BNwIzOTZgm%2Fv5rTJJkrlO9oWxSn5HAE99h2v2N7QyufFD8rPVufZYPYXrnkwR0rtrfp4%2BdWKU%2BCpD8hjKkM0B5Dso3bwAqaqUBEjDtMekJbDDAnn3tapyFS3OZfhOwfPEYLgs06C9nR49FGtZhueUjnBreKdKLcv8lKWJtMG0zDtvIeYridxliqkCRuRqHYYl52ApUXqE8UCn3QAyzBJtG5QLKAU2DEK0kyNaqA6LE4ao3SeS5VPVOizi3qz6s4pG3gSfuxH%2FiDMf8Crk0xuAyS03KMeziowIkjXfCLm87cBN6A81D%2BZbAaJRblATgKYHtnpV3itha96a7BJ4l4KqZyb%2F%2FmirVzLQE%2FhZZf3iR9f0tMglIVdaHVWWdVCUZuYyj1709oNSjolpjQIk%2BZEUfFKMPu%2F6BfS9oYO9AsJkna%2BrQ2hI%2BdYg%2BOfFPf05n4fU%2FmeU4udThUscAAAAASUVORK5CYII%3D)|# **License and Release**
| **License** | **Release** |
| :--- | :--- |
| [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT) | [![Release](https://img.shields.io/github/v/release/jminjares4/ESP32-LCD-1602-Driver)](https://github.com/jminjares4/ESP32-LCD-1602-Driver/releases) |## **Author**
* [**Jesus Minjares** :zap:](https://github.com/jminjares4)
* Master of Science in Computer Engineering
[![Outlook](https://img.shields.io/badge/Microsoft_Outlook-0078D4?style=for-the-badge&logo=microsoft-outlook&logoColor=white&style=flat)](mailto:[email protected])
[![LinkedIn](https://img.shields.io/badge/LinkedIn-0077B5?style=for-the-badge&logo=linkedin&logoColor=white&style=flat)](https://www.linkedin.com/in/jesusminjares/) [![GitHub](https://img.shields.io/badge/GitHub-100000?style=for-the-badge&logo=github&logoColor=white&style=flat)](https://github.com/jminjares4)