From 6fdf9c9ae9f6c7e717a5cc71f6f9a68e2a9b9f5e Mon Sep 17 00:00:00 2001 From: Fabian Blatz Date: Thu, 21 Mar 2024 09:06:17 +0100 Subject: [PATCH] modules: lvgl: Fix coordinate handling for invert-{x,y} and swap-xy This patch fixes two issues in the coordinate handling of the `zephyr,lvgl-pointer-input` compatible: - If the swap-xy flag is set the coordinates need to be swapped even before the sync event is received. - The coordinates are stored into an additional variable instead of the pending_event. This is done to prevent the double inversion for touch release events. Resolves issue #70539. Signed-off-by: Fabian Blatz --- modules/lvgl/input/lvgl_keypad_input.c | 3 +- modules/lvgl/input/lvgl_pointer_input.c | 68 +++++++++++++------------ 2 files changed, 37 insertions(+), 34 deletions(-) diff --git a/modules/lvgl/input/lvgl_keypad_input.c b/modules/lvgl/input/lvgl_keypad_input.c index 92066478f5..fb131f47a2 100644 --- a/modules/lvgl/input/lvgl_keypad_input.c +++ b/modules/lvgl/input/lvgl_keypad_input.c @@ -40,8 +40,7 @@ static void lvgl_keypad_process_event(const struct device *dev, struct input_eve } data->pending_event.state = evt->value ? LV_INDEV_STATE_PR : LV_INDEV_STATE_REL; - if (k_msgq_put(cfg->common_config.event_msgq, &data->pending_event, - K_NO_WAIT) != 0) { + if (k_msgq_put(cfg->common_config.event_msgq, &data->pending_event, K_NO_WAIT) != 0) { LOG_WRN("Could not put input data into keypad queue"); } } diff --git a/modules/lvgl/input/lvgl_pointer_input.c b/modules/lvgl/input/lvgl_pointer_input.c index 1abfd69d29..e1b1224375 100644 --- a/modules/lvgl/input/lvgl_pointer_input.c +++ b/modules/lvgl/input/lvgl_pointer_input.c @@ -21,24 +21,39 @@ struct lvgl_pointer_input_config { bool invert_y; }; +struct lvgl_pointer_input_data { + struct lvgl_common_input_data common_data; + uint32_t point_x; + uint32_t point_y; +}; + static void lvgl_pointer_process_event(const struct device *dev, struct input_event *evt) { const struct lvgl_pointer_input_config *cfg = dev->config; - struct lvgl_common_input_data *data = dev->data; + struct lvgl_pointer_input_data *data = dev->data; lv_disp_t *disp = lv_disp_get_default(); struct lvgl_disp_data *disp_data = disp->driver->user_data; struct display_capabilities *cap = &disp_data->cap; - lv_point_t *point = &data->pending_event.point; + lv_point_t *point = &data->common_data.pending_event.point; switch (evt->code) { case INPUT_ABS_X: - point->x = evt->value; + if (cfg->swap_xy) { + data->point_y = evt->value; + } else { + data->point_x = evt->value; + } break; case INPUT_ABS_Y: - point->y = evt->value; + if (cfg->swap_xy) { + data->point_x = evt->value; + } else { + data->point_y = evt->value; + } break; case INPUT_BTN_TOUCH: - data->pending_event.state = evt->value ? LV_INDEV_STATE_PR : LV_INDEV_STATE_REL; + data->common_data.pending_event.state = + evt->value ? LV_INDEV_STATE_PR : LV_INDEV_STATE_REL; break; } @@ -46,49 +61,37 @@ static void lvgl_pointer_process_event(const struct device *dev, struct input_ev return; } - /* adjust coordinates */ - if (cfg->swap_xy) { - lv_coord_t tmp; - - tmp = point->x; - point->x = point->y; - point->y = tmp; - } + point->x = data->point_x; + point->y = data->point_y; if (cfg->invert_x) { if (cap->current_orientation == DISPLAY_ORIENTATION_NORMAL || cap->current_orientation == DISPLAY_ORIENTATION_ROTATED_180) { - point->x = cap->x_resolution - point->x; + point->x = cap->x_resolution - data->point_x; } else { - point->x = cap->y_resolution - point->x; + point->x = cap->y_resolution - data->point_x; } } if (cfg->invert_y) { if (cap->current_orientation == DISPLAY_ORIENTATION_NORMAL || cap->current_orientation == DISPLAY_ORIENTATION_ROTATED_180) { - point->y = cap->y_resolution - point->y; + point->y = cap->y_resolution - data->point_y; } else { - point->y = cap->x_resolution - point->y; + point->y = cap->x_resolution - data->point_y; } } /* rotate touch point to match display rotation */ if (cap->current_orientation == DISPLAY_ORIENTATION_ROTATED_90) { - lv_coord_t tmp; - - tmp = point->x; - point->x = point->y; - point->y = cap->y_resolution - tmp; + point->x = data->point_y; + point->y = cap->y_resolution - data->point_x; } else if (cap->current_orientation == DISPLAY_ORIENTATION_ROTATED_180) { - point->x = cap->x_resolution - point->x; - point->y = cap->y_resolution - point->y; + point->x = cap->x_resolution - data->point_x; + point->y = cap->y_resolution - data->point_y; } else if (cap->current_orientation == DISPLAY_ORIENTATION_ROTATED_270) { - lv_coord_t tmp; - - tmp = point->x; - point->x = cap->x_resolution - point->y; - point->y = tmp; + point->x = cap->x_resolution - data->point_y; + point->y = data->point_x; } /* filter readings within display */ @@ -104,7 +107,8 @@ static void lvgl_pointer_process_event(const struct device *dev, struct input_ev point->y = cap->y_resolution - 1; } - if (k_msgq_put(cfg->common_config.event_msgq, &data->pending_event, K_NO_WAIT) != 0) { + if (k_msgq_put(cfg->common_config.event_msgq, &data->common_data.pending_event, + K_NO_WAIT) != 0) { LOG_WRN("Could not put input data into queue"); } } @@ -123,8 +127,8 @@ int lvgl_pointer_input_init(const struct device *dev) .invert_x = DT_INST_PROP(inst, invert_x), \ .invert_y = DT_INST_PROP(inst, invert_y), \ }; \ - static struct lvgl_common_input_data lvgl_common_input_data_##inst; \ - DEVICE_DT_INST_DEFINE(inst, NULL, NULL, &lvgl_common_input_data_##inst, \ + static struct lvgl_pointer_input_data lvgl_pointer_input_data_##inst; \ + DEVICE_DT_INST_DEFINE(inst, NULL, NULL, &lvgl_pointer_input_data_##inst, \ &lvgl_pointer_input_config_##inst, POST_KERNEL, \ CONFIG_INPUT_INIT_PRIORITY, NULL);