From 5665ea1ea8571fe07f58d615332d47797d53d2f0 Mon Sep 17 00:00:00 2001 From: Carsten Haitzler Date: Sun, 25 Jan 2009 23:18:25 +0000 Subject: [PATCH] make inwin a bit bigger make list track sub icon/end for deletion and so on. SVN revision: 38787 --- data/themes/default.edc | 4 ++-- src/lib/elm_list.c | 50 +++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 52 insertions(+), 2 deletions(-) diff --git a/data/themes/default.edc b/data/themes/default.edc index 88005ec..5eef091 100644 --- a/data/themes/default.edc +++ b/data/themes/default.edc @@ -4945,8 +4945,8 @@ collections { part { name: "elm.swallow.content"; type: SWALLOW; description { state: "default" 0.0; - rel1.relative: 0.2 0.2; - rel2.relative: 0.8 0.8; + rel1.relative: 0.1 0.1; + rel2.relative: 0.9 0.9; } } } diff --git a/src/lib/elm_list.c b/src/lib/elm_list.c index 8ff38fb..7256f5c 100644 --- a/src/lib/elm_list.c +++ b/src/lib/elm_list.c @@ -34,6 +34,10 @@ struct _Item static void _del_hook(Evas_Object *obj); static void _sizing_eval(Evas_Object *obj); static void _on_focus_hook(void *data, Evas_Object *obj); +static void _changed_size_hints(void *data, Evas *e, Evas_Object *obj, void *event_info); +static void _sub_del(void *data, Evas_Object *obj, void *event_info); + +static void _fix_items(Evas_Object *obj); static void _del_hook(Evas_Object *obj) @@ -77,6 +81,38 @@ _on_focus_hook(void *data, Evas_Object *obj) } static void +_changed_size_hints(void *data, Evas *e, Evas_Object *obj, void *event_info) +{ + Widget_Data *wd = elm_widget_data_get(data); + _fix_items(data); + _sizing_eval(data); +} + +static void +_sub_del(void *data, Evas_Object *obj, void *event_info) +{ + Widget_Data *wd = elm_widget_data_get(obj); + Evas_Object *sub = event_info; + Eina_List *l; + + for (l = wd->items; l; l = l->next) + { + Item *it = l->data; + + if ((sub == it->icon) || (sub == it->end)) + { + if (it->icon == sub) it->icon = NULL; + if (it->end == sub) it->end = NULL; + evas_object_event_callback_del + (sub, EVAS_CALLBACK_CHANGED_SIZE_HINTS, _changed_size_hints); + _fix_items(obj); + _sizing_eval(obj); + break; + } + } +} + +static void _mouse_down(void *data, Evas *evas, Evas_Object *obj, void *event_info) { Item *it = data; @@ -173,6 +209,18 @@ _item_new(Evas_Object *obj, const char *label, Evas_Object *icon, Evas_Object *e _mouse_up, it); evas_object_size_hint_weight_set(it->base, 1.0, 1.0); evas_object_size_hint_align_set(it->base, -1.0, -1.0); + if (it->icon) + { + elm_widget_sub_object_add(obj, it->icon); + evas_object_event_callback_add(it->icon, EVAS_CALLBACK_CHANGED_SIZE_HINTS, + _changed_size_hints, obj); + } + if (it->end) + { + elm_widget_sub_object_add(obj, it->end); + evas_object_event_callback_add(it->end, EVAS_CALLBACK_CHANGED_SIZE_HINTS, + _changed_size_hints, obj); + } return it; } @@ -312,6 +360,8 @@ elm_list_add(Evas_Object *parent) evas_object_show(wd->box); wd->mode = ELM_LIST_SCROLL; + + evas_object_smart_callback_add(obj, "sub-object-del", _sub_del, obj); _sizing_eval(obj); return obj; -- 2.7.4