Setup epdiy_epaper generic driver REF: https://github.com/martinberlin/lv_port_esp32-epaper/issues/2 Flushing too often, drawing only 40 px on top of display
This commit is contained in:
parent
db51c38e63
commit
a0113e0d5c
|
@ -10,6 +10,8 @@ list(APPEND SOURCES "lvgl_tft/disp_driver.c")
|
||||||
# display controller.
|
# display controller.
|
||||||
if(CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9341)
|
if(CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9341)
|
||||||
list(APPEND SOURCES "lvgl_tft/ili9341.c")
|
list(APPEND SOURCES "lvgl_tft/ili9341.c")
|
||||||
|
elseif(CONFIG_LV_EPAPER_EPDIY_DISPLAY_CONTROLLER)
|
||||||
|
list(APPEND SOURCES "lvgl_tft/epdiy_epaper.cpp")
|
||||||
elseif(CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9481)
|
elseif(CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9481)
|
||||||
list(APPEND SOURCES "lvgl_tft/ili9481.c")
|
list(APPEND SOURCES "lvgl_tft/ili9481.c")
|
||||||
elseif(CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9486)
|
elseif(CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9486)
|
||||||
|
|
|
@ -27,6 +27,12 @@ For more information on the function callbacks check LVGL documentation: (Displa
|
||||||
|
|
||||||
Add your display functions on `disp_driver_init`, `disp_driver_flush`, `disp_driver_rounder` and `disp_driver_set_px` on the `disp_driver.c` file.
|
Add your display functions on `disp_driver_init`, `disp_driver_flush`, `disp_driver_rounder` and `disp_driver_set_px` on the `disp_driver.c` file.
|
||||||
|
|
||||||
|
**Additional notes**
|
||||||
|
|
||||||
|
New drivers should be also have some defines added in:
|
||||||
|
lvgl_helpers.h
|
||||||
|
(follow existing ones to add yours)
|
||||||
|
|
||||||
## Input device driver.
|
## Input device driver.
|
||||||
|
|
||||||
To enable LVGL to work with your touch controller you would need to implement an initialization function and one function to get the data out from your touch controller.
|
To enable LVGL to work with your touch controller you would need to implement an initialization function and one function to get the data out from your touch controller.
|
||||||
|
|
|
@ -123,6 +123,11 @@ void lvgl_driver_init(void)
|
||||||
DISP_I2C_SDA, DISP_I2C_SCL,
|
DISP_I2C_SDA, DISP_I2C_SCL,
|
||||||
DISP_I2C_SPEED_HZ);
|
DISP_I2C_SPEED_HZ);
|
||||||
|
|
||||||
|
disp_driver_init();
|
||||||
|
#elif defined (CONFIG_LV_EPAPER_DISPLAY_PROTOCOL_PARALLEL)
|
||||||
|
// Do not initialize SPI. Uses EPDiy
|
||||||
|
ESP_LOGI(TAG, "Initializing Parallel driver for display");
|
||||||
|
// Check how not to initialize SPI. disp_driver_init() call is needed:
|
||||||
disp_driver_init();
|
disp_driver_init();
|
||||||
#else
|
#else
|
||||||
#error "No protocol defined for display controller"
|
#error "No protocol defined for display controller"
|
||||||
|
|
|
@ -42,6 +42,8 @@ extern "C" {
|
||||||
#define DISP_BUF_SIZE (LV_HOR_RES_MAX * 40)
|
#define DISP_BUF_SIZE (LV_HOR_RES_MAX * 40)
|
||||||
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ST7796S
|
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ST7796S
|
||||||
#define DISP_BUF_SIZE (LV_HOR_RES_MAX * 40)
|
#define DISP_BUF_SIZE (LV_HOR_RES_MAX * 40)
|
||||||
|
#elif defined (CONFIG_LV_EPAPER_EPDIY_DISPLAY_CONTROLLER)
|
||||||
|
#define DISP_BUF_SIZE (LV_HOR_RES_MAX * 40)
|
||||||
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_HX8357
|
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_HX8357
|
||||||
#define DISP_BUF_SIZE (LV_HOR_RES_MAX * 40)
|
#define DISP_BUF_SIZE (LV_HOR_RES_MAX * 40)
|
||||||
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_SH1107
|
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_SH1107
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
# NOTES:
|
# NOTES:
|
||||||
# - default <> if <> work only when no prompt is available for the user
|
# - default <> if <> work only when no prompt is available for the user
|
||||||
|
|
||||||
menu "LVGL TFT Display controller"
|
menu "LVGL TFT/Epaper Display controller"
|
||||||
|
|
||||||
# Predefined display configurations for multiple
|
# Predefined display configurations for multiple
|
||||||
# evaluation/development boards.
|
# evaluation/development boards.
|
||||||
|
@ -85,6 +85,11 @@ menu "LVGL TFT Display controller"
|
||||||
#
|
#
|
||||||
# If you add support for a new display controller to the repository
|
# If you add support for a new display controller to the repository
|
||||||
# you must add a config option for it on this helper symbols section.
|
# you must add a config option for it on this helper symbols section.
|
||||||
|
config LV_EPAPER_EPDIY_DISPLAY_CONTROLLER
|
||||||
|
bool
|
||||||
|
help
|
||||||
|
EPDIY parallel epaper controller.
|
||||||
|
|
||||||
config LV_TFT_DISPLAY_CONTROLLER_ILI9341
|
config LV_TFT_DISPLAY_CONTROLLER_ILI9341
|
||||||
bool
|
bool
|
||||||
help
|
help
|
||||||
|
@ -173,6 +178,11 @@ menu "LVGL TFT Display controller"
|
||||||
# - Know what peripherals to initialize.
|
# - Know what peripherals to initialize.
|
||||||
# - Know if the touch and display controllers share the same peripheral.
|
# - Know if the touch and display controllers share the same peripheral.
|
||||||
# - Etc.
|
# - Etc.
|
||||||
|
config LV_EPAPER_DISPLAY_PROTOCOL_PARALLEL
|
||||||
|
bool
|
||||||
|
help
|
||||||
|
Epaper controller protocol Parallel based on EPDiy 8 data lines
|
||||||
|
|
||||||
config LV_TFT_DISPLAY_PROTOCOL_SPI
|
config LV_TFT_DISPLAY_PROTOCOL_SPI
|
||||||
bool
|
bool
|
||||||
help
|
help
|
||||||
|
@ -257,6 +267,11 @@ menu "LVGL TFT Display controller"
|
||||||
prompt "Select a display controller model." if LV_PREDEFINED_DISPLAY_NONE
|
prompt "Select a display controller model." if LV_PREDEFINED_DISPLAY_NONE
|
||||||
help
|
help
|
||||||
Select the controller for your display.
|
Select the controller for your display.
|
||||||
|
config LV_EPAPER_DISPLAY_USER_CONTROLLER_EPDIY
|
||||||
|
bool "EPDIY_GENERIC"
|
||||||
|
select LV_EPAPER_EPDIY_DISPLAY_CONTROLLER
|
||||||
|
select LV_EPAPER_DISPLAY_PROTOCOL_PARALLEL
|
||||||
|
#select LV_TFT_DISPLAY_PROTOCOL_SPI
|
||||||
|
|
||||||
config LV_TFT_DISPLAY_USER_CONTROLLER_ILI9341
|
config LV_TFT_DISPLAY_USER_CONTROLLER_ILI9341
|
||||||
bool "ILI9341"
|
bool "ILI9341"
|
||||||
|
|
|
@ -4,11 +4,15 @@
|
||||||
|
|
||||||
#include "disp_driver.h"
|
#include "disp_driver.h"
|
||||||
#include "disp_spi.h"
|
#include "disp_spi.h"
|
||||||
|
// This should be included with CMakeLists but is not
|
||||||
|
#include "lvgl_tft/epdiy_epaper.h"
|
||||||
|
|
||||||
void disp_driver_init(void)
|
void disp_driver_init(void)
|
||||||
{
|
{
|
||||||
#if defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9341
|
#if defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9341
|
||||||
ili9341_init();
|
ili9341_init();
|
||||||
|
#elif defined CONFIG_LV_EPAPER_EPDIY_DISPLAY_CONTROLLER
|
||||||
|
epdiy_init();
|
||||||
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9481
|
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9481
|
||||||
ili9481_init();
|
ili9481_init();
|
||||||
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9488
|
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9488
|
||||||
|
@ -46,6 +50,8 @@ void disp_driver_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t *
|
||||||
{
|
{
|
||||||
#if defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9341
|
#if defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9341
|
||||||
ili9341_flush(drv, area, color_map);
|
ili9341_flush(drv, area, color_map);
|
||||||
|
#elif defined CONFIG_LV_EPAPER_EPDIY_DISPLAY_CONTROLLER
|
||||||
|
epdiy_flush(drv, area, color_map);
|
||||||
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9481
|
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9481
|
||||||
ili9481_flush(drv, area, color_map);
|
ili9481_flush(drv, area, color_map);
|
||||||
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9488
|
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9488
|
||||||
|
@ -81,8 +87,11 @@ void disp_driver_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t *
|
||||||
|
|
||||||
void disp_driver_rounder(lv_disp_drv_t * disp_drv, lv_area_t * area)
|
void disp_driver_rounder(lv_disp_drv_t * disp_drv, lv_area_t * area)
|
||||||
{
|
{
|
||||||
|
// Does not apply so far to epdiy
|
||||||
#if defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_SSD1306
|
#if defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_SSD1306
|
||||||
ssd1306_rounder(disp_drv, area);
|
ssd1306_rounder(disp_drv, area);
|
||||||
|
#elif defined CONFIG_LV_EPAPER_EPDIY_DISPLAY_CONTROLLER
|
||||||
|
epdiy_rounder(disp_drv, area);
|
||||||
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_SH1107
|
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_SH1107
|
||||||
sh1107_rounder(disp_drv, area);
|
sh1107_rounder(disp_drv, area);
|
||||||
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_IL3820
|
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_IL3820
|
||||||
|
@ -99,6 +108,8 @@ void disp_driver_set_px(lv_disp_drv_t * disp_drv, uint8_t * buf, lv_coord_t buf_
|
||||||
{
|
{
|
||||||
#if defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_SSD1306
|
#if defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_SSD1306
|
||||||
ssd1306_set_px_cb(disp_drv, buf, buf_w, x, y, color, opa);
|
ssd1306_set_px_cb(disp_drv, buf, buf_w, x, y, color, opa);
|
||||||
|
#elif defined CONFIG_LV_EPAPER_EPDIY_DISPLAY_CONTROLLER
|
||||||
|
epdiy_set_px_cb(disp_drv, buf, buf_w, x, y, color, opa);
|
||||||
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_SH1107
|
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_SH1107
|
||||||
sh1107_set_px_cb(disp_drv, buf, buf_w, x, y, color, opa);
|
sh1107_set_px_cb(disp_drv, buf, buf_w, x, y, color, opa);
|
||||||
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_IL3820
|
#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_IL3820
|
||||||
|
|
62
lvgl_tft/epdiy_epaper.cpp
Normal file
62
lvgl_tft/epdiy_epaper.cpp
Normal file
|
@ -0,0 +1,62 @@
|
||||||
|
#include "esp_log.h"
|
||||||
|
#include "freertos/FreeRTOS.h"
|
||||||
|
#include "freertos/task.h"
|
||||||
|
|
||||||
|
#include "epdiy_epaper.h"
|
||||||
|
|
||||||
|
// NOTE: This needs Epdiy component https://github.com/vroland/epdiy
|
||||||
|
// Run idf.py menuconfig-> Component Config -> E-Paper driver and select:
|
||||||
|
// Display type: LILIGO 4.7 ED047TC1
|
||||||
|
// Board: LILIGO T5-4.7 Epaper
|
||||||
|
// In the same section Component Config -> ESP32 Specifics -> Enable PSRAM
|
||||||
|
#include "parallel/ED047TC1.h"
|
||||||
|
Ed047TC1 display;
|
||||||
|
|
||||||
|
/*********************
|
||||||
|
* DEFINES
|
||||||
|
*********************/
|
||||||
|
#define TAG "EPDIY"
|
||||||
|
|
||||||
|
uint16_t flushcalls = 0;
|
||||||
|
|
||||||
|
/* Display initialization routine */
|
||||||
|
void epdiy_init(void)
|
||||||
|
{
|
||||||
|
printf("epdiy_init\n");
|
||||||
|
display.init();
|
||||||
|
display.setRotation(0);
|
||||||
|
//display.clearScreen();
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Required by LVGL */
|
||||||
|
void epdiy_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_map)
|
||||||
|
{
|
||||||
|
++flushcalls;
|
||||||
|
printf("epdiy_flush %d\n", flushcalls);
|
||||||
|
display.update();
|
||||||
|
/* IMPORTANT!!!
|
||||||
|
* Inform the graphics library that you are ready with the flushing */
|
||||||
|
lv_disp_flush_ready(drv);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Called for each pixel */
|
||||||
|
void epdiy_set_px_cb(lv_disp_drv_t * disp_drv, uint8_t* buf,
|
||||||
|
lv_coord_t buf_w, lv_coord_t x, lv_coord_t y,
|
||||||
|
lv_color_t color, lv_opa_t opa)
|
||||||
|
{
|
||||||
|
// Is printing Y axis only till 40 px: And flushing too many times
|
||||||
|
//printf("%d ", (int16_t)y); // Works and prints "Hello world"
|
||||||
|
//printf("%d ",(int16_t)color.full); // Debug colors
|
||||||
|
// Test using RGB232
|
||||||
|
int16_t epd_color = EPD_WHITE;
|
||||||
|
|
||||||
|
// Color setting use: RGB232
|
||||||
|
if ((int16_t)color.full<250) {
|
||||||
|
epd_color = (int16_t)color.full;
|
||||||
|
}
|
||||||
|
display.drawPixel((int16_t)x, (int16_t)y, epd_color);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Required by LVGL. Not used in this implementation - deprecated, will be removed */
|
||||||
|
void epdiy_rounder(lv_disp_drv_t * disp_drv, lv_area_t *area) {
|
||||||
|
}
|
37
lvgl_tft/epdiy_epaper.h
Normal file
37
lvgl_tft/epdiy_epaper.h
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
/**
|
||||||
|
* Display class for generic e-Paper driven by EPDiy class
|
||||||
|
*/
|
||||||
|
#ifndef EPDIY_H
|
||||||
|
#define EPDIY_H
|
||||||
|
|
||||||
|
#define EPDIY_COLUMNS (LV_HOR_RES_MAX / 8)
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef LV_LVGL_H_INCLUDE_SIMPLE
|
||||||
|
#include "lvgl.h"
|
||||||
|
#else
|
||||||
|
#include "lvgl/lvgl.h"
|
||||||
|
#endif
|
||||||
|
#include "sdkconfig.h"
|
||||||
|
|
||||||
|
/* Configure your display */
|
||||||
|
void epdiy_init(void);
|
||||||
|
|
||||||
|
/* LVGL callbacks */
|
||||||
|
void epdiy_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_map);
|
||||||
|
|
||||||
|
/* Only for monochrome displays. But we use epdiy_set_px also for epapers */
|
||||||
|
//void epdiy_rounder(lv_disp_drv_t *disp_drv, lv_area_t *area);
|
||||||
|
void epdiy_set_px_cb(lv_disp_drv_t *disp_drv, uint8_t *buf, lv_coord_t buf_w, lv_coord_t x, lv_coord_t y, lv_color_t color, lv_opa_t opa);
|
||||||
|
|
||||||
|
void epdiy_rounder(lv_disp_drv_t * disp_drv, lv_area_t *area);
|
||||||
|
#ifdef __cplusplus
|
||||||
|
} /* extern "C" */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* EPDIY_H */
|
|
@ -160,7 +160,7 @@ void il3820_set_px_cb(lv_disp_drv_t * disp_drv, uint8_t* buf,
|
||||||
uint16_t byte_index = 0;
|
uint16_t byte_index = 0;
|
||||||
uint8_t bit_index = 0;
|
uint8_t bit_index = 0;
|
||||||
|
|
||||||
#if defined (CONFIG_LV_DISPLAY_ORIENTATION_PORTRAIT)
|
#if defined (CONFIG_DISPLAY_ORIENTATION_PORTRAIT)
|
||||||
byte_index = x + ((y >> 3) * EPD_PANEL_HEIGHT);
|
byte_index = x + ((y >> 3) * EPD_PANEL_HEIGHT);
|
||||||
bit_index = y & 0x7;
|
bit_index = y & 0x7;
|
||||||
|
|
||||||
|
@ -170,7 +170,7 @@ void il3820_set_px_cb(lv_disp_drv_t * disp_drv, uint8_t* buf,
|
||||||
uint16_t mirrored_idx = (EPD_PANEL_HEIGHT - x) + ((y >> 3) * EPD_PANEL_HEIGHT);
|
uint16_t mirrored_idx = (EPD_PANEL_HEIGHT - x) + ((y >> 3) * EPD_PANEL_HEIGHT);
|
||||||
BIT_CLEAR(buf[mirrored_idx], 7 - bit_index);
|
BIT_CLEAR(buf[mirrored_idx], 7 - bit_index);
|
||||||
}
|
}
|
||||||
#elif defined (CONFIG_LV_DISPLAY_ORIENTATION_LANDSCAPE)
|
#elif defined (CONFIG_DISPLAY_ORIENTATION_LANDSCAPE)
|
||||||
byte_index = y + ((x >> 3) * EPD_PANEL_HEIGHT);
|
byte_index = y + ((x >> 3) * EPD_PANEL_HEIGHT);
|
||||||
bit_index = x & 0x7;
|
bit_index = x & 0x7;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue