forked from enlightenment/efl
elm/gengrid: handle gengrid finding of nearest visible item when not realized
Summary: FIXME-- @fix Depends on D8960 Reviewers: cedric Reviewed By: cedric Subscribers: cedric, #reviewers, #committers Tags: #efl Differential Revision: https://phab.enlightenment.org/D8961
This commit is contained in:
parent
5292729e37
commit
ca5b68a620
|
@ -3505,7 +3505,7 @@ _elm_gengrid_nearest_visible_item_get(Evas_Object *obj, Elm_Object_Item *eo_it)
|
|||
Evas_Coord ix = 0, iy = 0, iw = 0, ih = 0; // given item geometry
|
||||
Evas_Coord cx = 0, cy = 0, cw = 0, ch = 0; // candidate item geometry
|
||||
Eina_List *item_list = NULL, *l = NULL;
|
||||
Elm_Object_Item *eo_item = NULL;
|
||||
Elm_Object_Item *first_item, *eo_item = NULL;
|
||||
ELM_GENGRID_DATA_GET(obj, sd);
|
||||
Eina_Bool search_next = EINA_FALSE;
|
||||
|
||||
|
@ -3513,19 +3513,26 @@ _elm_gengrid_nearest_visible_item_get(Evas_Object *obj, Elm_Object_Item *eo_it)
|
|||
ELM_GENGRID_ITEM_DATA_GET(eo_it, it);
|
||||
|
||||
evas_object_geometry_get(sd->pan_obj, &vx, &vy, &vw, &vh);
|
||||
evas_object_geometry_get(VIEW(it), &ix, &iy, &iw, &ih); // FIXME: check if the item is realized or not
|
||||
|
||||
if (ELM_RECTS_INCLUDE(vx, vy, vw, vh, ix, iy, iw, ih))
|
||||
if (it->realized)
|
||||
{
|
||||
if (!elm_object_item_disabled_get(eo_it))
|
||||
return eo_it;
|
||||
else
|
||||
search_next = EINA_TRUE;
|
||||
evas_object_geometry_get(VIEW(it), &ix, &iy, &iw, &ih);
|
||||
|
||||
if (ELM_RECTS_INCLUDE(vx, vy, vw, vh, ix, iy, iw, ih))
|
||||
{
|
||||
if (!elm_object_item_disabled_get(eo_it))
|
||||
return eo_it;
|
||||
else
|
||||
search_next = EINA_TRUE;
|
||||
}
|
||||
}
|
||||
|
||||
item_list = elm_gengrid_realized_items_get(obj);
|
||||
/* if first realized item is before parameter item then parameter item is
|
||||
* off viewport towards bottom: start at end of list */
|
||||
first_item = eina_list_data_get(item_list);
|
||||
ELM_GENGRID_ITEM_DATA_GET(first_item, first_it);
|
||||
|
||||
if ((iy < vy) || search_next)
|
||||
if ((iy < vy) || search_next || (!first_it) || (first_it->position > it->position))
|
||||
{
|
||||
EINA_LIST_FOREACH(item_list, l, eo_item)
|
||||
{
|
||||
|
@ -3555,7 +3562,7 @@ _elm_gengrid_nearest_visible_item_get(Evas_Object *obj, Elm_Object_Item *eo_it)
|
|||
}
|
||||
eina_list_free(item_list);
|
||||
|
||||
return eo_it;
|
||||
return it->realized ? eo_it : NULL;
|
||||
}
|
||||
|
||||
EOLIAN static Eina_Rect
|
||||
|
|
Loading…
Reference in New Issue