1
0
mirror of https://github.com/lvgl/lvgl.git synced 2025-01-21 06:53:01 +08:00

Merge branch 'dev-6.0' of https://github.com/GreyMS/lvgl into GreyMS-dev-6.0

This commit is contained in:
Gabor Kiss-Vamosi 2019-04-11 05:46:48 +02:00
commit 12125248c6
6 changed files with 174 additions and 0 deletions

View File

@ -427,6 +427,10 @@ typedef void * lv_obj_user_data_t;
/*Window (dependencies: lv_cont, lv_btn, lv_label, lv_img, lv_page)*/ /*Window (dependencies: lv_cont, lv_btn, lv_label, lv_img, lv_page)*/
#define LV_USE_WIN 1 #define LV_USE_WIN 1
/* Extended clickable area */
#define USE_LV_EXTENDED_CLICK_AREA 0 /* Enables obj extension to realize extended clickable area with additional extended coords (1: enabled) */
#define USE_LV_EXTENDED_CLICK_AREA_TINY 0 /* Enables obj extension to realize extended clickable area with calculation of the fly (1: enabled) */
/*================== /*==================
* Non-user section * Non-user section
*==================*/ *==================*/

View File

@ -991,7 +991,13 @@ static lv_obj_t * indev_search_obj(const lv_indev_proc_t * proc, lv_obj_t * obj)
/*If the point is on this object*/ /*If the point is on this object*/
/*Check its children too*/ /*Check its children too*/
#if USE_LV_EXTENDED_CLICK_AREA
if(lv_area_is_point_on(&obj->ext_coords, &proc->types.pointer.act_point)) {
#elif USE_LV_EXTENDED_CLICK_AREA_TINY
if(lv_area_ext_is_point_on(&obj->coords, &proc->types.pointer.act_point, obj->ext_padding_hor, obj->ext_padding_ver)) {
#else
if(lv_area_is_point_on(&obj->coords, &proc->types.pointer.act_point)) { if(lv_area_is_point_on(&obj->coords, &proc->types.pointer.act_point)) {
#endif
lv_obj_t * i; lv_obj_t * i;
LV_LL_READ(obj->child_ll, i) LV_LL_READ(obj->child_ll, i)

View File

@ -44,6 +44,9 @@ static void refresh_children_style(lv_obj_t * obj);
static void delete_children(lv_obj_t * obj); static void delete_children(lv_obj_t * obj);
static bool lv_obj_design(lv_obj_t * obj, const lv_area_t * mask_p, lv_design_mode_t mode); static bool lv_obj_design(lv_obj_t * obj, const lv_area_t * mask_p, lv_design_mode_t mode);
static lv_res_t lv_obj_signal(lv_obj_t * obj, lv_signal_t sign, void * param); static lv_res_t lv_obj_signal(lv_obj_t * obj, lv_signal_t sign, void * param);
#if USE_LV_EXTENDED_CLICK_AREA
static void update_ext_coords(lv_area_t *coords, lv_area_t *ext_coords, uint8_t hor_pad, uint8_t ver_pad);
#endif
/********************** /**********************
* STATIC VARIABLES * STATIC VARIABLES
@ -145,6 +148,14 @@ lv_obj_t * lv_obj_create(lv_obj_t * parent, const lv_obj_t * copy)
new_obj->coords.y2 = lv_disp_get_ver_res(NULL) - 1; new_obj->coords.y2 = lv_disp_get_ver_res(NULL) - 1;
new_obj->ext_size = 0; new_obj->ext_size = 0;
#if USE_LV_EXTENDED_CLICK_AREA
lv_area_copy(&(new_obj->ext_coords), &(new_obj->coords));
#endif
#if USE_LV_EXTENDED_CLICK_AREA || USE_LV_EXTENDED_CLICK_AREA_TINY
new_obj->ext_padding_hor = 0;
new_obj->ext_padding_ver = 0;
#endif
/*Init realign*/ /*Init realign*/
#if LV_OBJ_REALIGN #if LV_OBJ_REALIGN
new_obj->realign.align = LV_ALIGN_CENTER; new_obj->realign.align = LV_ALIGN_CENTER;
@ -213,6 +224,13 @@ lv_obj_t * lv_obj_create(lv_obj_t * parent, const lv_obj_t * copy)
new_obj->coords.y2 = parent->coords.y1 + LV_OBJ_DEF_HEIGHT; new_obj->coords.y2 = parent->coords.y1 + LV_OBJ_DEF_HEIGHT;
new_obj->ext_size = 0; new_obj->ext_size = 0;
#if USE_LV_EXTENDED_CLICK_AREA
lv_area_copy(&(new_obj->ext_coords), &(new_obj->coords));
#endif
#if USE_LV_EXTENDED_CLICK_AREA || USE_LV_EXTENDED_CLICK_AREA_TINY
new_obj->ext_padding_hor = 0;
new_obj->ext_padding_ver = 0;
#endif
/*Init realign*/ /*Init realign*/
#if LV_OBJ_REALIGN #if LV_OBJ_REALIGN
new_obj->realign.align = LV_ALIGN_CENTER; new_obj->realign.align = LV_ALIGN_CENTER;
@ -269,6 +287,14 @@ lv_obj_t * lv_obj_create(lv_obj_t * parent, const lv_obj_t * copy)
lv_area_copy(&new_obj->coords, &copy->coords); lv_area_copy(&new_obj->coords, &copy->coords);
new_obj->ext_size = copy->ext_size; new_obj->ext_size = copy->ext_size;
#if USE_LV_EXTENDED_CLICK_AREA
lv_area_copy(&new_obj->ext_coords, &copy->ext_coords);
#endif
#if USE_LV_EXTENDED_CLICK_AREA || USE_LV_EXTENDED_CLICK_AREA_TINY
new_obj->ext_padding_hor = copy->ext_padding_hor;
new_obj->ext_padding_ver = copy->ext_padding_ver;
#endif
/*Set free data*/ /*Set free data*/
#if LV_USE_USER_DATA_SINGLE #if LV_USE_USER_DATA_SINGLE
memcpy(&new_obj->user_data, &copy->user_data, sizeof(lv_obj_user_data_t)); memcpy(&new_obj->user_data, &copy->user_data, sizeof(lv_obj_user_data_t));
@ -554,6 +580,10 @@ void lv_obj_set_pos(lv_obj_t * obj, lv_coord_t x, lv_coord_t y)
obj->coords.x2 += diff.x; obj->coords.x2 += diff.x;
obj->coords.y2 += diff.y; obj->coords.y2 += diff.y;
#if USE_LV_EXTENDED_CLICK_AREA
update_ext_coords(&(obj->coords), &(obj->ext_coords), obj->hor_pad, obj->ver_pad);
#endif
refresh_children_position(obj, diff.x, diff.y); refresh_children_position(obj, diff.x, diff.y);
/*Inform the object about its new coordinates*/ /*Inform the object about its new coordinates*/
@ -613,6 +643,10 @@ void lv_obj_set_size(lv_obj_t * obj, lv_coord_t w, lv_coord_t h)
obj->coords.x2 = obj->coords.x1 + w - 1; obj->coords.x2 = obj->coords.x1 + w - 1;
obj->coords.y2 = obj->coords.y1 + h - 1; obj->coords.y2 = obj->coords.y1 + h - 1;
#if USE_LV_EXTENDED_CLICK_AREA
update_ext_coords(&(obj->coords), &(obj->ext_coords), obj->hor_pad, obj->ver_pad);
#endif
/*Send a signal to the object with its new coordinates*/ /*Send a signal to the object with its new coordinates*/
obj->signal_cb(obj, LV_SIGNAL_CORD_CHG, &ori); obj->signal_cb(obj, LV_SIGNAL_CORD_CHG, &ori);
@ -636,6 +670,24 @@ void lv_obj_set_size(lv_obj_t * obj, lv_coord_t w, lv_coord_t h)
#endif #endif
} }
#if USE_LV_EXTENDED_CLICK_AREA || USE_LV_EXTENDED_CLICK_AREA_TINY
/**
* Set the size of an extended clickable area
* @param obj pointer to an object
* @param w extended width to both sides
* @param h extended height to both sides
*/
void lv_obj_set_ext_paddings(lv_obj_t * obj, uint8_t w, uint8_t h)
{
obj->ext_padding_hor = w;
obj->ext_padding_ver = h;
#if USE_LV_EXTENDED_CLICK_AREA
update_ext_coords(&(obj->coords), &(obj->ext_coords), &(obj->ext_paddings));
#endif
}
#endif
/** /**
* Set the width of an object * Set the width of an object
* @param obj pointer to an object * @param obj pointer to an object
@ -1587,6 +1639,29 @@ lv_coord_t lv_obj_get_height_fit(lv_obj_t * obj)
return lv_obj_get_height(obj) - style->body.padding.top - style->body.padding.bottom; return lv_obj_get_height(obj) - style->body.padding.top - style->body.padding.bottom;
} }
#if USE_LV_EXTENDED_CLICK_AREA || USE_LV_EXTENDED_CLICK_AREA_TINY
/**
* Get the horizontal padding of extended clickable area
* @param obj pointer to an object
* @return the horizontal padding
*/
uint8_t lv_obj_get_ext_hor_padding(const lv_obj_t * obj)
{
return obj->ext_padding_hor;
}
/**
* Get the vertical padding of extended clickable area
* @param obj pointer to an object
* @return the vertical padding
*/
uint8_t lv_obj_get_ext_ver_padding(const lv_obj_t * obj)
{
return obj->ext_padding_ver;
}
#endif
/** /**
* Get the extended size attribute of an object * Get the extended size attribute of an object
* @param obj pointer to an object * @param obj pointer to an object
@ -2006,6 +2081,9 @@ static void refresh_children_position(lv_obj_t * obj, lv_coord_t x_diff, lv_coor
i->coords.x2 += x_diff; i->coords.x2 += x_diff;
i->coords.y2 += y_diff; i->coords.y2 += y_diff;
#if USE_LV_EXTENDED_CLICK_AREA
update_ext_coords(&(i->coords), &(i->ext_coords), i->hor_pad, i->ver_pad);
#endif
refresh_children_position(i, x_diff, y_diff); refresh_children_position(i, x_diff, y_diff);
} }
} }
@ -2116,3 +2194,19 @@ static void delete_children(lv_obj_t * obj)
if(obj->ext_attr != NULL) lv_mem_free(obj->ext_attr); if(obj->ext_attr != NULL) lv_mem_free(obj->ext_attr);
lv_mem_free(obj); /*Free the object itself*/ lv_mem_free(obj); /*Free the object itself*/
} }
#if USE_LV_EXTENDED_CLICK_AREA
/**
* Update coordinates of extended clickable area from object's coordinates and ext_paddings
* @param coords coordinates of an object
* @param ext_coords extended coordinates, which will be updated
* @param paddings paddings of extended clickable area
*/
static void update_ext_coords(lv_area_t *coords, lv_area_t *ext_coords, uint8_t hor_pad, uint8_t ver_pad)
{
ext_coords->x1 = hor_pad > coords->x1 ? 0 : coords->x1 - hor_pad;
ext_coords->x2 = coords->x2 + hor_pad;
ext_coords->y1 = ver_pad > coords->y1 ? 0 : coords->y1 - ver_pad;
ext_coords->y2 = coords->y2 + ver_pad;
}
#endif

View File

@ -183,6 +183,13 @@ typedef struct _lv_obj_t
lv_ll_t child_ll; /*Linked list to store the children objects*/ lv_ll_t child_ll; /*Linked list to store the children objects*/
lv_area_t coords; /*Coordinates of the object (x1, y1, x2, y2)*/ lv_area_t coords; /*Coordinates of the object (x1, y1, x2, y2)*/
#if USE_LV_EXTENDED_CLICK_AREA
lv_area_t ext_coords;
#endif
#if USE_LV_EXTENDED_CLICK_AREA || USE_LV_EXTENDED_CLICK_AREA_TINY
uint8_t ext_padding_hor;
uint8_t ext_padding_ver;
#endif
lv_event_cb_t event_cb; lv_event_cb_t event_cb;
lv_signal_cb_t signal_cb; /*Object type specific signal function*/ lv_signal_cb_t signal_cb; /*Object type specific signal function*/
@ -348,6 +355,16 @@ void lv_obj_set_y(lv_obj_t * obj, lv_coord_t y);
*/ */
void lv_obj_set_size(lv_obj_t * obj, lv_coord_t w, lv_coord_t h); void lv_obj_set_size(lv_obj_t * obj, lv_coord_t w, lv_coord_t h);
#if USE_LV_EXTENDED_CLICK_AREA || USE_LV_EXTENDED_CLICK_AREA_TINY
/**
* Set the size of an extended clickable area
* @param obj pointer to an object
* @param w extended width to both sides
* @param h extended height to both sides
*/
void lv_obj_set_ext_paddings(lv_obj_t * obj, uint8_t w, uint8_t h);
#endif
/** /**
* Set the width of an object * Set the width of an object
* @param obj pointer to an object * @param obj pointer to an object
@ -695,6 +712,23 @@ lv_coord_t lv_obj_get_width_fit(lv_obj_t * obj);
*/ */
lv_coord_t lv_obj_get_height_fit(lv_obj_t * obj); lv_coord_t lv_obj_get_height_fit(lv_obj_t * obj);
#if USE_LV_EXTENDED_CLICK_AREA || USE_LV_EXTENDED_CLICK_AREA_TINY
/**
* Get the horizontal padding of extended clickable area
* @param obj pointer to an object
* @return the horizontal padding
*/
uint8_t lv_obj_get_ext_hor_padding(const lv_obj_t * obj);
/**
* Get the vertical padding of extended clickable area
* @param obj pointer to an object
* @return the vertical padding
*/
uint8_t lv_obj_get_ext_ver_padding(const lv_obj_t * obj);
#endif
/** /**
* Get the extended size attribute of an object * Get the extended size attribute of an object
* @param obj pointer to an object * @param obj pointer to an object

View File

@ -6,6 +6,7 @@
/********************* /*********************
* INCLUDES * INCLUDES
*********************/ *********************/
#include "lv_conf.h"
#include "lv_area.h" #include "lv_area.h"
#include "lv_math.h" #include "lv_math.h"
@ -153,6 +154,29 @@ bool lv_area_is_point_on(const lv_area_t * a_p, const lv_point_t * p_p)
return is_on; return is_on;
} }
#if USE_LV_EXTENDED_CLICK_AREA_TINY
/**
* Check if a point is on an area
* @param a_p pointer to an area
* @param p_p pointer to a point
* @param ext_hor extended horizontal padding
* @param ext_ver extended horizontal padding
* @return false:the point is out of the area
*/
bool lv_area_ext_is_point_on(const lv_area_t * a_p, const lv_point_t * p_p, uint8_t ext_hor, uint8_t ext_ver)
{
bool is_on = false;
if(( (p_p->x + ext_hor) >= a_p->x1 && p_p->x <= (a_p->x2 + ext_hor) ) &&
( (p_p->y + ext_ver) >= a_p->y1 && p_p->y <= (a_p->y2 + ext_ver)) ) {
is_on = true;
}
return is_on;
}
#endif
/** /**
* Check if two area has common parts * Check if two area has common parts
* @param a1_p pointer to an area. * @param a1_p pointer to an area.

View File

@ -140,6 +140,18 @@ void lv_area_join(lv_area_t * a_res_p, const lv_area_t * a1_p, const lv_area_t *
*/ */
bool lv_area_is_point_on(const lv_area_t * a_p, const lv_point_t * p_p); bool lv_area_is_point_on(const lv_area_t * a_p, const lv_point_t * p_p);
#if USE_LV_EXTENDED_CLICK_AREA_TINY
/**
* Check if a point is on an area
* @param a_p pointer to an area
* @param p_p pointer to a point
* @param ext_hor extended horizontal padding
* @param ext_ver extended horizontal padding
* @return false:the point is out of the area
*/
bool lv_area_ext_is_point_on(const lv_area_t * a_p, const lv_point_t * p_p, uint8_t ext_hor, uint8_t ext_ver);
#endif
/** /**
* Check if two area has common parts * Check if two area has common parts
* @param a1_p pointer to an area. * @param a1_p pointer to an area.