From fd694946e7888c049ac1bbb1f59ed7d356a09613 Mon Sep 17 00:00:00 2001 From: Vilem Zavodny Date: Mon, 6 Feb 2023 12:56:46 +0100 Subject: [PATCH] esp_lvgl_port: Disabled touch when not used. --- components/esp_lvgl_port/esp_lvgl_port.c | 14 +++++++++++++- components/esp_lvgl_port/idf_component.yml | 2 +- components/esp_lvgl_port/include/esp_lvgl_port.h | 11 +++++++++-- 3 files changed, 23 insertions(+), 4 deletions(-) diff --git a/components/esp_lvgl_port/esp_lvgl_port.c b/components/esp_lvgl_port/esp_lvgl_port.c index 9e54486b..5f2bdfe1 100644 --- a/components/esp_lvgl_port/esp_lvgl_port.c +++ b/components/esp_lvgl_port/esp_lvgl_port.c @@ -14,11 +14,15 @@ #include "freertos/semphr.h" #include "esp_lcd_panel_io.h" #include "esp_lcd_panel_ops.h" -#include "esp_lcd_touch.h" #include "esp_lvgl_port.h" #include "lvgl.h" + +#if __has_include ("esp_lcd_touch.h") +#include "esp_lcd_touch.h" +#endif + #if ESP_IDF_VERSION < ESP_IDF_VERSION_VAL(5, 0, 1) #define LVGL_PORT_HANDLE_FLUSH_READY 0 #else @@ -44,10 +48,12 @@ typedef struct { lv_disp_drv_t disp_drv; /* LVGL display driver */ } lvgl_port_display_ctx_t; +#if __has_include ("esp_lcd_touch.h") typedef struct { esp_lcd_touch_handle_t handle; /* LCD touch IO handle */ lv_indev_drv_t indev_drv; /* LVGL input device driver */ } lvgl_port_touch_ctx_t; +#endif /******************************************************************************* * Local variables @@ -68,7 +74,9 @@ static bool lvgl_port_flush_ready_callback(esp_lcd_panel_io_handle_t panel_io, e #endif static void lvgl_port_flush_callback(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_map); static void lvgl_port_update_callback(lv_disp_drv_t *drv); +#if __has_include ("esp_lcd_touch.h") static void lvgl_port_touchpad_read(lv_indev_drv_t *indev_drv, lv_indev_data_t *data); +#endif static void lvgl_port_pix_monochrome_callback(lv_disp_drv_t *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); /******************************************************************************* * Public API functions @@ -245,6 +253,7 @@ esp_err_t lvgl_port_remove_disp(lv_disp_t *disp) return ESP_OK; } +#if __has_include ("esp_lcd_touch.h") lv_indev_t *lvgl_port_add_touch(const lvgl_port_touch_cfg_t *touch_cfg) { assert(touch_cfg != NULL); @@ -281,6 +290,7 @@ esp_err_t lvgl_port_remove_touch(lv_indev_t *touch) return ESP_OK; } +#endif bool lvgl_port_lock(uint32_t timeout_ms) { @@ -420,6 +430,7 @@ static void lvgl_port_pix_monochrome_callback(lv_disp_drv_t *drv, uint8_t *buf, } } +#if __has_include ("esp_lcd_touch.h") static void lvgl_port_touchpad_read(lv_indev_drv_t *indev_drv, lv_indev_data_t *data) { assert(indev_drv); @@ -444,6 +455,7 @@ static void lvgl_port_touchpad_read(lv_indev_drv_t *indev_drv, lv_indev_data_t * data->state = LV_INDEV_STATE_RELEASED; } } +#endif static void lvgl_port_tick_increment(void *arg) { diff --git a/components/esp_lvgl_port/idf_component.yml b/components/esp_lvgl_port/idf_component.yml index 67f77d8e..65ee9a57 100644 --- a/components/esp_lvgl_port/idf_component.yml +++ b/components/esp_lvgl_port/idf_component.yml @@ -1,4 +1,4 @@ -version: "1.0.2" +version: "1.0.3" description: ESP LVGL port url: https://github.com/espressif/esp-bsp/tree/master/components/esp_lvgl_port dependencies: diff --git a/components/esp_lvgl_port/include/esp_lvgl_port.h b/components/esp_lvgl_port/include/esp_lvgl_port.h index c4b62aea..4672990e 100644 --- a/components/esp_lvgl_port/include/esp_lvgl_port.h +++ b/components/esp_lvgl_port/include/esp_lvgl_port.h @@ -14,9 +14,12 @@ #include "esp_err.h" #include "esp_lcd_panel_io.h" #include "esp_lcd_panel_ops.h" -#include "esp_lcd_touch.h" #include "lvgl.h" +#if __has_include ("esp_lcd_touch.h") +#include "esp_lcd_touch.h" +#endif + #ifdef __cplusplus extern "C" { #endif @@ -59,6 +62,7 @@ typedef struct { } flags; } lvgl_port_display_cfg_t; +#if __has_include ("esp_lcd_touch.h") /** * @brief Configuration touch structure */ @@ -66,9 +70,10 @@ typedef struct { lv_disp_t *disp; /*!< LVGL display handle (returned from lvgl_port_add_disp) */ esp_lcd_touch_handle_t handle; /*!< LCD touch IO handle */ } lvgl_port_touch_cfg_t; +#endif /** - * @brief Touch IO configuration structure + * @brief LVGL port configuration structure * */ #define ESP_LVGL_PORT_INIT_CONFIG() \ @@ -123,6 +128,7 @@ lv_disp_t *lvgl_port_add_disp(const lvgl_port_display_cfg_t *disp_cfg); */ esp_err_t lvgl_port_remove_disp(lv_disp_t *disp); +#if __has_include ("esp_lcd_touch.h") /** * @brief Add LCD touch as an input device * @@ -142,6 +148,7 @@ lv_indev_t *lvgl_port_add_touch(const lvgl_port_touch_cfg_t *touch_cfg); * - ESP_OK on success */ esp_err_t lvgl_port_remove_touch(lv_indev_t *touch); +#endif /** * @brief Take LVGL mutex