Update helpers and drivers to handle LVGLv7 and v8 versions (#161)
* [lvgl_helpers] Cleanup and misc code cleanup Checks for SPI_HOST_MAX symbol before using it. Rename lvgl_driver_init to lvgl_interface_init because it now only initialize the interface bus for display drivers, we still need to remove the indev drivers from here. Use types defined in spi_types.h for spi host (spi_host_device_t) and spi dma channels (spi_dma_chan_t). Also add a couple of symbols to avoid using magic numbers * [lvgl_helpers] Reduce usage of if defined in lvgl_interface_init * [lvgl_helpers] Fix spi dma channel for ESP-IDF versions <= 4.2 * [examples] Update hello_world to call lvgl_interface_init * Add lvgl_get_display_buffer_size helper This helper will allow us to get the calculated display buffer size instead of using a global symbol. * Implement lvgl_get_display_buffer_size This API will be used to get the calculation of display buffer size. * Delete DISP_BUF_SIZE symbols The same functionality is handled by lvgl_get_display_buffer_size * Move SPI max transfer size calculation to helper Use calculate_spi_max_transfer_size to calculate the SPI max transfer size for the SPI master configuration * Remove SPI_BUS_MAX_TRANSFER_SZ definition Same functionality is now handled in calculate_spi_max_transfer_size * Update display buffer size calculation Use lvgl_get_display_buffer_size helper instead of DISP_BUF_SIZE symbol * Update example to LVGL v8 Add comments about changes from: - LVGL v7 to LVGL v8 - Configuration helpers and display drivers * Update lvgl_helpers.c * Update sh1107 driver * Update EVE driver Check for symbols used in previous implementations before trying to use them and add a fallback temporary implementation when not found. The falback implementation isn't tested with hardware. Symbols: - DISP_BUF_SIZE - SPI_TRANSFER_SIZE * Update uc8151d driver * Update jd79653a driver * Update ra8875 driver * Update il3820.h Check for LV_HOR_RES_MAX and LV_VER_RES_MAX before trying to use them * Update lvgl_helpers.c Check for ESP-IDF version before trying to use spi_dma_chan_t type
This commit is contained in:
parent
bb0e3a1f27
commit
17eb416ef8
14 changed files with 309 additions and 148 deletions
|
@ -267,7 +267,13 @@ void EVE_memWrite_buffer(uint32_t ftAddress, const uint8_t *data, uint32_t len,
|
|||
uint32_t bytes_left = len;
|
||||
while(bytes_left > 0)
|
||||
{
|
||||
uint32_t block_len = (bytes_left > SPI_TRANSER_SIZE ? SPI_TRANSER_SIZE : bytes_left);
|
||||
uint32_t block_len = 0;
|
||||
|
||||
#if defined (SPI_TRANSFER_SIZE)
|
||||
block_len = (bytes_left > SPI_TRANSER_SIZE ? SPI_TRANSER_SIZE : bytes_left);
|
||||
#else
|
||||
/* ToDo Update SPI_TRANSFER_SIZE calculation, it's based on the DISP_BUF_SIZE */
|
||||
#endif
|
||||
|
||||
// only send flush on last chunk
|
||||
disp_spi_send_flag_t flush_flag = 0;
|
||||
|
|
|
@ -51,7 +51,11 @@ TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR TH
|
|||
#define EVE_PDN CONFIG_LV_DISP_PIN_RST // grey
|
||||
#define EVE_USE_PDN CONFIG_LV_DISP_USE_RST
|
||||
|
||||
#if defined (DISP_BUF_SIZE)
|
||||
#define SPI_TRANSER_SIZE (DISP_BUF_SIZE * (LV_COLOR_DEPTH / 8))
|
||||
#else
|
||||
/* ToDo Update using new API */
|
||||
#endif
|
||||
|
||||
#define BYTES_PER_PIXEL (LV_COLOR_DEPTH / 8) // bytes per pixel for (16 for RGB565)
|
||||
#define BYTES_PER_LINE (EVE_HSIZE * BYTES_PER_PIXEL)
|
||||
|
|
|
@ -20,8 +20,19 @@ extern "C"
|
|||
|
||||
/* Values for Waveshare 2.9inch e-Paper Module, this values shouldn't be
|
||||
* swapped to change display orientation */
|
||||
#if defined (LV_HOR_RES_MAX)
|
||||
#define EPD_PANEL_WIDTH LV_HOR_RES_MAX /* 128 */
|
||||
#else
|
||||
/* Fallback to default value */
|
||||
#define EPD_PANEL_WIDTH 128u
|
||||
#endif
|
||||
|
||||
#if defined (LV_VER_RES_MAX)
|
||||
#define EPD_PANEL_HEIGHT LV_VER_RES_MAX /* 296 */
|
||||
#else
|
||||
/* Fallback to default value */
|
||||
#define EPD_PANEL_HEIGHT 296u
|
||||
#endif
|
||||
|
||||
/* 128 = panel width */
|
||||
#define IL3820_COLUMNS (EPD_PANEL_WIDTH / 8)
|
||||
|
|
|
@ -44,9 +44,24 @@ TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR TH
|
|||
#define PIN_BUSY CONFIG_LV_DISP_PIN_BUSY
|
||||
#define PIN_BUSY_BIT ((1ULL << (uint8_t)(CONFIG_LV_DISP_PIN_BUSY)))
|
||||
#define EVT_BUSY (1UL << 0UL)
|
||||
|
||||
#if defined (LV_HOR_RES_MAX)
|
||||
#define EPD_WIDTH LV_HOR_RES_MAX
|
||||
#else
|
||||
/* ToDo Remove magic number */
|
||||
#define EPD_WIDTH 256u
|
||||
#endif
|
||||
|
||||
#if defined (LV_VER_RES_MAX)
|
||||
#define EPD_HEIGHT LV_VER_RES_MAX
|
||||
#else
|
||||
/* ToDo Remove magic number */
|
||||
#define EPD_HEIGHT 128u
|
||||
#endif
|
||||
|
||||
#define EPD_ROW_LEN (EPD_HEIGHT / 8u)
|
||||
|
||||
/* ToDo Remove semicolon */
|
||||
#define EPD_PARTIAL_CNT 5;
|
||||
|
||||
#define BIT_SET(a, b) ((a) |= (1U << (b)))
|
||||
|
@ -200,21 +215,21 @@ static esp_err_t jd79653a_wait_busy(uint32_t timeout_ms)
|
|||
return ((bits & EVT_BUSY) != 0) ? ESP_OK : ESP_ERR_TIMEOUT;
|
||||
}
|
||||
|
||||
static void jd79653a_power_on()
|
||||
static void jd79653a_power_on(void)
|
||||
{
|
||||
jd79653a_spi_send_seq(power_on_seq, EPD_SEQ_LEN(power_on_seq));
|
||||
vTaskDelay(pdMS_TO_TICKS(10));
|
||||
jd79653a_wait_busy(0);
|
||||
}
|
||||
|
||||
static void jd79653a_power_off()
|
||||
static void jd79653a_power_off(void)
|
||||
{
|
||||
jd79653a_spi_send_seq(power_off_seq, EPD_SEQ_LEN(power_off_seq));
|
||||
vTaskDelay(pdMS_TO_TICKS(10));
|
||||
jd79653a_wait_busy(0);
|
||||
}
|
||||
|
||||
static void jd79653a_load_partial_lut()
|
||||
static void jd79653a_load_partial_lut(void)
|
||||
{
|
||||
jd79653a_spi_send_cmd(0x20); // LUT VCOM register
|
||||
jd79653a_spi_send_data((uint8_t *)lut_vcom_dc1, sizeof(lut_vcom_dc1));
|
||||
|
@ -232,7 +247,7 @@ static void jd79653a_load_partial_lut()
|
|||
jd79653a_spi_send_data((uint8_t *)lut_bb1, sizeof(lut_bb1));
|
||||
}
|
||||
|
||||
static void jd79653a_partial_in()
|
||||
static void jd79653a_partial_in(void)
|
||||
{
|
||||
LV_LOG_INFO("Partial in!");
|
||||
|
||||
|
@ -260,7 +275,7 @@ static void jd79653a_partial_in()
|
|||
jd79653a_spi_send_cmd(0x91);
|
||||
}
|
||||
|
||||
static void jd79653a_partial_out()
|
||||
static void jd79653a_partial_out(void)
|
||||
{
|
||||
LV_LOG_INFO("Partial out!");
|
||||
|
||||
|
@ -378,7 +393,7 @@ void jd79653a_fb_full_update(uint8_t *data, size_t len)
|
|||
jd79653a_power_off();
|
||||
}
|
||||
|
||||
void jd79653a_lv_set_fb_cb(struct _disp_drv_t *disp_drv, uint8_t *buf, lv_coord_t buf_w, lv_coord_t x, lv_coord_t y,
|
||||
void jd79653a_lv_set_fb_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)
|
||||
{
|
||||
uint16_t byte_index = (x >> 3u) + (y * EPD_ROW_LEN);
|
||||
|
@ -391,7 +406,7 @@ void jd79653a_lv_set_fb_cb(struct _disp_drv_t *disp_drv, uint8_t *buf, lv_coord_
|
|||
}
|
||||
}
|
||||
|
||||
void jd79653a_lv_rounder_cb(struct _disp_drv_t *disp_drv, lv_area_t *area)
|
||||
void jd79653a_lv_rounder_cb(lv_disp_drv_t *disp_drv, lv_area_t *area)
|
||||
{
|
||||
// Always send full framebuffer if it's not in partial mode
|
||||
area->x1 = 0;
|
||||
|
@ -419,7 +434,7 @@ void jd79653a_lv_fb_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t
|
|||
lv_disp_flush_ready(drv);
|
||||
}
|
||||
|
||||
void jd79653a_deep_sleep()
|
||||
void jd79653a_deep_sleep(void)
|
||||
{
|
||||
jd79653a_spi_send_seq(power_off_seq, EPD_SEQ_LEN(power_off_seq));
|
||||
jd79653a_wait_busy(1000);
|
||||
|
@ -429,7 +444,7 @@ void jd79653a_deep_sleep()
|
|||
jd79653a_spi_send_data(&check_code, sizeof(check_code));
|
||||
}
|
||||
|
||||
void jd79653a_init()
|
||||
void jd79653a_init(void)
|
||||
{
|
||||
// Initialise event group
|
||||
jd79653a_evts = xEventGroupCreate();
|
||||
|
|
|
@ -17,12 +17,12 @@ extern "C"
|
|||
#include "lvgl/lvgl.h"
|
||||
#endif
|
||||
|
||||
void jd79653a_init();
|
||||
void jd79653a_deep_sleep();
|
||||
void jd79653a_init(void);
|
||||
void jd79653a_deep_sleep(void);
|
||||
|
||||
void jd79653a_lv_set_fb_cb(struct _disp_drv_t * disp_drv, uint8_t* buf, lv_coord_t buf_w, lv_coord_t x, lv_coord_t y,
|
||||
void jd79653a_lv_set_fb_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 jd79653a_lv_rounder_cb(struct _disp_drv_t * disp_drv, lv_area_t *area);
|
||||
void jd79653a_lv_rounder_cb(lv_disp_drv_t * disp_drv, lv_area_t *area);
|
||||
void jd79653a_lv_fb_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_map);
|
||||
|
||||
void jd79653a_fb_set_full_color(uint8_t color);
|
||||
|
|
|
@ -26,8 +26,19 @@
|
|||
|
||||
#define BYTES_PER_PIXEL (LV_COLOR_DEPTH / 8)
|
||||
|
||||
#if defined (LV_HOR_RES_MAX)
|
||||
#define HDWR_VAL (LV_HOR_RES_MAX/8 - 1)
|
||||
#else
|
||||
/* ToDo Remove magic number 256u */
|
||||
#define HDWR_VAL (256u/8u - 1u)
|
||||
#endif
|
||||
|
||||
#if defined (LV_VER_RES_MAX)
|
||||
#define VDHR_VAL (LV_VER_RES_MAX - 1)
|
||||
#else
|
||||
/* ToDo Remove magic number 128u */
|
||||
#define VDHR_VAL (128u - 1u)
|
||||
#endif
|
||||
|
||||
#define VDIR_MASK (1 << 2)
|
||||
#define HDIR_MASK (1 << 3)
|
||||
|
@ -234,7 +245,16 @@ void ra8875_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * colo
|
|||
// Set window if needed
|
||||
if ((x1 != area->x1) || (x2 != area->x2)) {
|
||||
LV_LOG_INFO("flush: set window (x1,x2): %d,%d -> %d,%d", x1, x2, area->x1, area->x2);
|
||||
ra8875_set_window(area->x1, area->x2, 0, LV_VER_RES_MAX-1);
|
||||
unsigned int ye = 0;
|
||||
|
||||
#if LVGL_VERSION_MAJOR < 8
|
||||
ye = LV_VER_RES_MAX - 1;
|
||||
#else
|
||||
/* ToDo Get y end from driver information */
|
||||
#endif
|
||||
|
||||
ra8875_set_window(area->x1, area->x2, 0, ye);
|
||||
|
||||
x1 = area->x1;
|
||||
x2 = area->x2;
|
||||
}
|
||||
|
@ -248,7 +268,16 @@ void ra8875_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * colo
|
|||
|
||||
// Update to future cursor location
|
||||
y = area->y2 + 1;
|
||||
if (y >= LV_VER_RES_MAX) {
|
||||
lv_coord_t ver_max = 0;
|
||||
|
||||
#if LVGL_VERSION_MAJOR < 8
|
||||
ver_max = LV_VER_RES_MAX;
|
||||
#else
|
||||
/* ToDo Get vertical max from driver information */
|
||||
ver_max = lv_disp_get_ver_res((lv_disp_t *) drv);
|
||||
#endif
|
||||
|
||||
if (y >= ver_max) {
|
||||
y = 0;
|
||||
}
|
||||
|
||||
|
|
|
@ -35,6 +35,9 @@ static void sh1107_send_cmd(uint8_t cmd);
|
|||
static void sh1107_send_data(void * data, uint16_t length);
|
||||
static void sh1107_send_color(void * data, uint16_t length);
|
||||
|
||||
static lv_coord_t get_display_ver_res(lv_disp_drv_t *disp_drv);
|
||||
static lv_coord_t get_display_hor_res(lv_disp_drv_t *disp_drv);
|
||||
|
||||
/**********************
|
||||
* STATIC VARIABLES
|
||||
**********************/
|
||||
|
@ -117,7 +120,7 @@ void sh1107_init(void)
|
|||
}
|
||||
}
|
||||
|
||||
void sh1107_set_px_cb(struct _disp_drv_t * disp_drv, uint8_t * buf, lv_coord_t buf_w, lv_coord_t x, lv_coord_t y,
|
||||
void sh1107_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)
|
||||
{
|
||||
/* buf_w will be ignored, the configured CONFIG_LV_DISPLAY_HEIGHT and _WIDTH,
|
||||
|
@ -126,10 +129,10 @@ void sh1107_set_px_cb(struct _disp_drv_t * disp_drv, uint8_t * buf, lv_coord_t b
|
|||
uint8_t bit_index = 0;
|
||||
|
||||
#if defined CONFIG_LV_DISPLAY_ORIENTATION_LANDSCAPE
|
||||
byte_index = y + (( x>>3 ) * LV_VER_RES_MAX);
|
||||
byte_index = y + (( x>>3 ) * get_display_ver_res(disp_drv));
|
||||
bit_index = x & 0x7;
|
||||
#elif defined CONFIG_LV_DISPLAY_ORIENTATION_PORTRAIT
|
||||
byte_index = x + (( y>>3 ) * LV_HOR_RES_MAX);
|
||||
byte_index = x + (( y>>3 ) * get_display_hor_res(disp_drv));
|
||||
bit_index = y & 0x7;
|
||||
#endif
|
||||
|
||||
|
@ -161,9 +164,9 @@ void sh1107_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * colo
|
|||
sh1107_send_cmd(0xB0 | i); // Set Page Start Address for Page Addressing Mode
|
||||
size = area->y2 - area->y1 + 1;
|
||||
#if defined CONFIG_LV_DISPLAY_ORIENTATION_LANDSCAPE
|
||||
ptr = color_map + i * LV_VER_RES_MAX;
|
||||
ptr = color_map + i * get_display_ver_res(drv);
|
||||
#else
|
||||
ptr = color_map + i * LV_HOR_RES_MAX;
|
||||
ptr = color_map + i * get_display_hor_res(drv);
|
||||
#endif
|
||||
if(i != row2){
|
||||
sh1107_send_data( (void *) ptr, size);
|
||||
|
@ -174,21 +177,21 @@ void sh1107_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * colo
|
|||
}
|
||||
}
|
||||
|
||||
void sh1107_rounder(struct _disp_drv_t * disp_drv, lv_area_t *area)
|
||||
void sh1107_rounder(lv_disp_drv_t * disp_drv, lv_area_t *area)
|
||||
{
|
||||
// workaround: always send complete size display buffer
|
||||
area->x1 = 0;
|
||||
area->y1 = 0;
|
||||
area->x2 = LV_HOR_RES_MAX-1;
|
||||
area->y2 = LV_VER_RES_MAX-1;
|
||||
area->x2 = get_display_hor_res(disp_drv) - 1;
|
||||
area->y2 = get_display_ver_res(disp_drv) - 1;
|
||||
}
|
||||
|
||||
void sh1107_sleep_in()
|
||||
void sh1107_sleep_in(void)
|
||||
{
|
||||
sh1107_send_cmd(0xAE);
|
||||
}
|
||||
|
||||
void sh1107_sleep_out()
|
||||
void sh1107_sleep_out(void)
|
||||
{
|
||||
sh1107_send_cmd(0xAF);
|
||||
}
|
||||
|
@ -218,3 +221,39 @@ static void sh1107_send_color(void * data, uint16_t length)
|
|||
gpio_set_level(SH1107_DC, 1); /*Data mode*/
|
||||
disp_spi_send_colors(data, length);
|
||||
}
|
||||
|
||||
static lv_coord_t get_display_ver_res(lv_disp_drv_t *disp_drv)
|
||||
{
|
||||
lv_coord_t val = 0;
|
||||
|
||||
#if LVGL_VERSION_MAJOR < 8
|
||||
#if defined CONFIG_LV_DISPLAY_ORIENTATION_LANDSCAPE
|
||||
val = LV_VER_RES_MAX;
|
||||
#endif
|
||||
#else
|
||||
/* ToDo Use display rotation API to get vertical size */
|
||||
#if defined CONFIG_LV_DISPLAY_ORIENTATION_LANDSCAPE
|
||||
val = lv_disp_get_ver_res((lv_disp_t *) disp_drv);
|
||||
#endif
|
||||
#endif
|
||||
|
||||
return val;
|
||||
}
|
||||
|
||||
static lv_coord_t get_display_hor_res(lv_disp_drv_t *disp_drv)
|
||||
{
|
||||
lv_coord_t val = 0;
|
||||
|
||||
#if LVGL_VERSION_MAJOR < 8
|
||||
#if defined CONFIG_LV_DISPLAY_ORIENTATION_PORTRAIT
|
||||
val = LV_HOR_RES_MAX;
|
||||
#endif
|
||||
#else
|
||||
/* ToDo Use display rotation API to get horizontal size */
|
||||
#if defined CONFIG_LV_DISPLAY_ORIENTATION_PORTRAIT
|
||||
val = lv_disp_get_hor_res((lv_disp_t *) disp_drv);
|
||||
#endif
|
||||
#endif
|
||||
|
||||
return val;
|
||||
}
|
||||
|
|
|
@ -39,8 +39,8 @@ extern "C" {
|
|||
|
||||
void sh1107_init(void);
|
||||
void sh1107_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map);
|
||||
void sh1107_rounder(struct _disp_drv_t * disp_drv, lv_area_t *area);
|
||||
void sh1107_set_px_cb(struct _disp_drv_t * disp_drv, uint8_t * buf, lv_coord_t buf_w, lv_coord_t x, lv_coord_t y,
|
||||
void sh1107_rounder(lv_disp_drv_t * disp_drv, lv_area_t *area);
|
||||
void sh1107_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 sh1107_sleep_in(void);
|
||||
void sh1107_sleep_out(void);
|
||||
|
|
|
@ -45,8 +45,21 @@
|
|||
#define PIN_BUSY CONFIG_LV_DISP_PIN_BUSY
|
||||
#define PIN_BUSY_BIT ((1ULL << (uint8_t)(CONFIG_LV_DISP_PIN_BUSY)))
|
||||
#define EVT_BUSY (1UL << 0UL)
|
||||
|
||||
#if defined (LV_HOR_RES_MAX)
|
||||
#define EPD_WIDTH LV_HOR_RES_MAX
|
||||
#else
|
||||
/* ToDo Fix, 256 is just a magic number */
|
||||
#define EPD_WIDTH 256u
|
||||
#endif
|
||||
|
||||
#if defined (LV_VER_RES_MAX)
|
||||
#define EPD_HEIGHT LV_VER_RES_MAX
|
||||
#else
|
||||
/* ToDo Fix, 128 is just a magic number */
|
||||
#define EPD_HEIGHT 128u
|
||||
#endif
|
||||
|
||||
#define EPD_ROW_LEN (EPD_HEIGHT / 8u)
|
||||
|
||||
#define BIT_SET(a, b) ((a) |= (1U << (b)))
|
||||
|
@ -105,7 +118,7 @@ static esp_err_t uc8151d_wait_busy(uint32_t timeout_ms)
|
|||
return ((bits & EVT_BUSY) != 0) ? ESP_OK : ESP_ERR_TIMEOUT;
|
||||
}
|
||||
|
||||
static void uc8151d_sleep()
|
||||
static void uc8151d_sleep(void)
|
||||
{
|
||||
// Set VCOM to 0xf7
|
||||
uc8151d_spi_send_cmd(0x50);
|
||||
|
@ -122,7 +135,7 @@ static void uc8151d_sleep()
|
|||
|
||||
static void uc8151d_reset(void);
|
||||
|
||||
static void uc8151d_panel_init()
|
||||
static void uc8151d_panel_init(void)
|
||||
{
|
||||
// Hardware reset for 3 times - not sure why but it's from official demo code
|
||||
for (uint8_t cnt = 0; cnt < 3; cnt++) {
|
||||
|
@ -186,7 +199,7 @@ void uc8151d_lv_fb_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *
|
|||
LV_LOG_INFO("Ready");
|
||||
}
|
||||
|
||||
void uc8151d_lv_set_fb_cb(struct _disp_drv_t *disp_drv, uint8_t *buf, lv_coord_t buf_w, lv_coord_t x, lv_coord_t y,
|
||||
void uc8151d_lv_set_fb_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)
|
||||
{
|
||||
uint16_t byte_index = (x >> 3u) + (y * EPD_ROW_LEN);
|
||||
|
@ -200,7 +213,7 @@ void uc8151d_lv_set_fb_cb(struct _disp_drv_t *disp_drv, uint8_t *buf, lv_coord_t
|
|||
}
|
||||
}
|
||||
|
||||
void uc8151d_lv_rounder_cb(struct _disp_drv_t *disp_drv, lv_area_t *area)
|
||||
void uc8151d_lv_rounder_cb(lv_disp_drv_t *disp_drv, lv_area_t *area)
|
||||
{
|
||||
// Always send full framebuffer if it's not in partial mode
|
||||
area->x1 = 0;
|
||||
|
@ -209,7 +222,7 @@ void uc8151d_lv_rounder_cb(struct _disp_drv_t *disp_drv, lv_area_t *area)
|
|||
area->y2 = EPD_HEIGHT - 1;
|
||||
}
|
||||
|
||||
void uc8151d_init()
|
||||
void uc8151d_init(void)
|
||||
{
|
||||
// Initialise event group
|
||||
uc8151d_evts = xEventGroupCreate();
|
||||
|
|
|
@ -29,11 +29,11 @@
|
|||
|
||||
#include <lvgl.h>
|
||||
|
||||
void uc8151d_init();
|
||||
void uc8151d_lv_set_fb_cb(struct _disp_drv_t *disp_drv, uint8_t *buf, lv_coord_t buf_w, lv_coord_t x, lv_coord_t y,
|
||||
void uc8151d_init(void);
|
||||
void uc8151d_lv_set_fb_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 uc8151d_lv_rounder_cb(struct _disp_drv_t *disp_drv, lv_area_t *area);
|
||||
void uc8151d_lv_rounder_cb(lv_disp_drv_t *disp_drv, lv_area_t *area);
|
||||
void uc8151d_lv_fb_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_map);
|
||||
|
||||
#endif //LVGL_DEMO_UC8151D_H
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue