raster pushed a commit to branch master.
commit 0da4ab20c5e05ce6615710013216b3a051edef5b
Author: Carsten Haitzler (Rasterman) <[email protected]>
Date: Sun Jun 23 15:17:39 2013 +0900
genlist - fix some stacking issues when selecting items with group headers
stacking become a lot more complex when re-order mode was added, group
headers and more, so simple raise/lower wasn't enough, so this adds 2
stacking markers (rectangles) and objects are stacked above or below
these 2 markers. that basically provides 4 possible stacking slots
that are easy to address, and if you also still raise/lower you get 6
slots. use these markers for stacking so items go into a fixed
stacking layer when they stack around.
---
src/lib/elm_genlist.c | 53 ++++++++++++++++++++++++++++++--------------
src/lib/elm_widget_genlist.h | 1 +
2 files changed, 37 insertions(+), 17 deletions(-)
diff --git a/src/lib/elm_genlist.c b/src/lib/elm_genlist.c
index a15f8b5..2845b48 100644
--- a/src/lib/elm_genlist.c
+++ b/src/lib/elm_genlist.c
@@ -834,17 +834,19 @@ _item_tree_effect_finish(Elm_Genlist_Smart_Data *sd)
static void
_elm_genlist_item_odd_even_update(Elm_Gen_Item *it)
{
+ ELM_GENLIST_DATA_GET_FROM_ITEM(it, sd);
+
if (!it->item->nostacking)
{
if ((it->item->order_num_in & 0x1) ^ it->item->stacking_even)
{
- if (it->deco_all_view) evas_object_lower(it->deco_all_view);
- else evas_object_lower(VIEW(it));
+ if (it->deco_all_view) evas_object_stack_below(it->deco_all_view,
sd->stack[0]);
+ else evas_object_stack_below(VIEW(it), sd->stack[0]);
}
else
{
- if (it->deco_all_view) evas_object_raise(it->deco_all_view);
- else evas_object_raise(VIEW(it));
+ if (it->deco_all_view) evas_object_stack_above(it->deco_all_view,
sd->stack[0]);
+ else evas_object_stack_above(VIEW(it), sd->stack[0]);
}
}
@@ -1875,8 +1877,8 @@ _group_items_recalc(void *data)
if (!git->realized) _item_realize(git, 0, EINA_FALSE);
evas_object_resize(VIEW(git), sd->minw, git->item->h);
evas_object_move(VIEW(git), git->item->scrl_x, git->item->scrl_y);
+ evas_object_stack_above(VIEW(git), sd->stack[1]);
evas_object_show(VIEW(git));
- evas_object_raise(VIEW(git));
}
else if (!git->item->want_realize && git->realized)
{
@@ -2145,6 +2147,7 @@ _elm_genlist_pan_smart_calculate(Eo *obj EINA_UNUSED,
void *_pd, va_list *list E
{
_item_tree_effect_before(psd->wsd->expanded_item);
evas_object_raise(psd->wsd->alpha_bg);
+ evas_object_stack_below(psd->wsd->alpha_bg, psd->wsd->stack[1]);
evas_object_show(psd->wsd->alpha_bg);
psd->wsd->start_time = ecore_time_get();
psd->wsd->tree_effect_animator =
@@ -2179,6 +2182,7 @@ _elm_genlist_pan_smart_calculate(Eo *obj EINA_UNUSED,
void *_pd, va_list *list E
else psd->wsd->reorder_pan_move = EINA_FALSE;
evas_object_raise(psd->wsd->VIEW(reorder_it));
+ evas_object_stack_below(psd->wsd->VIEW(reorder_it),
psd->wsd->stack[1]);
psd->wsd->reorder_old_pan_y = psd->wsd->pan_y;
psd->wsd->start_time = ecore_loop_time_get();
}
@@ -2790,10 +2794,10 @@ _item_highlight(Elm_Gen_Item *it)
selectraise = edje_object_data_get(VIEW(it), "selectraise");
if ((selectraise) && (!strcmp(selectraise, "on")))
{
- if (it->deco_all_view) evas_object_raise(it->deco_all_view);
- else evas_object_raise(VIEW(it));
+ if (it->deco_all_view) evas_object_stack_below(it->deco_all_view,
sd->stack[1]);
+ else evas_object_stack_below(VIEW(it), sd->stack[1]);
if ((it->item->group_item) && (it->item->group_item->realized))
- evas_object_raise(it->item->VIEW(group_item));
+ evas_object_stack_above(it->item->VIEW(group_item), sd->stack[1]);
}
it->highlighted = EINA_TRUE;
}
@@ -2801,6 +2805,8 @@ _item_highlight(Elm_Gen_Item *it)
static void
_item_unhighlight(Elm_Gen_Item *it)
{
+ ELM_GENLIST_DATA_GET_FROM_ITEM(it, sd);
+
if ((it->generation < GL_IT(it)->wsd->generation) || (!it->highlighted))
return;
@@ -2814,13 +2820,13 @@ _item_unhighlight(Elm_Gen_Item *it)
{
if ((it->item->order_num_in & 0x1) ^ it->item->stacking_even)
{
- if (it->deco_all_view) evas_object_lower(it->deco_all_view);
- else evas_object_lower(VIEW(it));
+ if (it->deco_all_view) evas_object_stack_below(it->deco_all_view,
sd->stack[0]);
+ else evas_object_stack_below(VIEW(it), sd->stack[0]);
}
else
{
- if (it->deco_all_view) evas_object_raise(it->deco_all_view);
- else evas_object_raise(VIEW(it));
+ if (it->deco_all_view) evas_object_stack_above(it->deco_all_view,
sd->stack[0]);
+ else evas_object_stack_above(VIEW(it), sd->stack[0]);
}
}
it->highlighted = EINA_FALSE;
@@ -3255,9 +3261,9 @@ _long_press_cb(void *data)
sd->reorder_it = it;
sd->reorder_start_y = 0;
if (it->deco_all_view)
- evas_object_raise(it->deco_all_view);
+ evas_object_stack_below(it->deco_all_view, sd->stack[1]);
else
- evas_object_raise(VIEW(it));
+ evas_object_stack_below(VIEW(it), sd->stack[1]);
eo_do(sd->obj, elm_scrollable_interface_hold_set(EINA_TRUE));
eo_do(sd->obj, elm_scrollable_interface_bounce_allow_set
@@ -4285,7 +4291,7 @@ _decorate_item_finished_signal_cb(void *data,
it->item->nocache_once = EINA_FALSE;
_decorate_item_unrealize(it);
if (it->item->group_item)
- evas_object_raise(it->item->VIEW(group_item));
+ evas_object_stack_above(it->item->VIEW(group_item), sd->stack[1]);
snprintf(buf, sizeof(buf), "elm,state,%s,passive,finished",
sd->decorate_it_type);
@@ -4735,7 +4741,7 @@ _decorate_item_set(Elm_Gen_Item *it)
evas_event_freeze(evas_object_evas_get(sd->obj));
_decorate_item_realize(it);
if (it->item->group_item)
- evas_object_raise(it->item->VIEW(group_item));
+ evas_object_stack_above(it->item->VIEW(group_item), sd->stack[1]);
_item_position
(it, it->item->deco_it_view, it->item->scrl_x, it->item->scrl_y);
evas_event_thaw(evas_object_evas_get(sd->obj));
@@ -4771,6 +4777,7 @@ _elm_genlist_smart_add(Eo *obj, void *_pd, va_list *list
EINA_UNUSED)
{
Evas_Coord minw, minh;
Elm_Genlist_Pan_Smart_Data *pan_data;
+ int i;
Elm_Genlist_Smart_Data *priv = _pd;
Elm_Widget_Smart_Data *wd = eo_data_scope_get(obj, ELM_OBJ_WIDGET_CLASS);
@@ -4829,6 +4836,12 @@ _elm_genlist_smart_add(Eo *obj, void *_pd, va_list *list
EINA_UNUSED)
pan_data->wobj = obj;
pan_data->wsd = priv;
+ for (i = 0; i < 2; i++)
+ {
+ priv->stack[i] = evas_object_rectangle_add(evas_object_evas_get(obj));
+ evas_object_smart_member_add(priv->stack[i], priv->pan_obj);
+ }
+
eo_do(obj, elm_scrollable_interface_extern_pan_set(priv->pan_obj));
edje_object_size_min_calc(wd->resize_obj, &minw, &minh);
@@ -4843,11 +4856,17 @@ static void
_elm_genlist_smart_del(Eo *obj, void *_pd, va_list *list EINA_UNUSED)
{
Elm_Genlist_Smart_Data *sd = _pd;
+ int i;
if (sd->decorate_all_mode)
elm_genlist_decorate_mode_set(sd->obj, EINA_FALSE);
sd->queue = eina_list_free(sd->queue);
elm_genlist_clear(obj);
+ for (i = 0; i < 2; i++)
+ {
+ evas_object_del(sd->stack[i]);
+ sd->stack[i] = NULL;
+ }
eo_unref(sd->pan_obj);
evas_object_del(sd->pan_obj);
sd->pan_obj = NULL;
@@ -5968,7 +5987,7 @@ elm_genlist_item_subitems_clear(Elm_Object_Item *item)
{
sd->expanded_item = it;
_item_tree_effect_before(it);
- evas_object_raise(sd->alpha_bg);
+ evas_object_stack_below(sd->alpha_bg, sd->stack[1]);
evas_object_show(sd->alpha_bg);
sd->start_time = ecore_time_get();
sd->tree_effect_animator =
diff --git a/src/lib/elm_widget_genlist.h b/src/lib/elm_widget_genlist.h
index 4d450eb..20ba4c2 100644
--- a/src/lib/elm_widget_genlist.h
+++ b/src/lib/elm_widget_genlist.h
@@ -32,6 +32,7 @@ struct _Elm_Genlist_Smart_Data
Eina_Inlist_Sorted_State *state;
Evas_Object *hit_rect;
Evas_Object *pan_obj;
+ Evas_Object *stack[2]; // stacking markers in pan
Evas_Object *obj; // the object itself
Eina_List *selected; /* a list of
--
------------------------------------------------------------------------------
This SF.net email is sponsored by Windows:
Build for Windows Store.
http://p.sf.net/sfu/windows-dev2dev