X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=src%2Flib%2Felm_factory.c;h=123f67f0ded2e2abcb4962865a542e395e0f8638;hb=f8c7c0cf477b77aa52664e0cdf7d059372433980;hp=ecb5b5cefbe27f550d52c4a3fb38c4a139a8be86;hpb=ed39ad7b1ba18eb132cbc0a3ab7d745ff75379b6;p=framework%2Fuifw%2Felementary.git diff --git a/src/lib/elm_factory.c b/src/lib/elm_factory.c index ecb5b5c..123f67f 100644 --- a/src/lib/elm_factory.c +++ b/src/lib/elm_factory.c @@ -26,8 +26,9 @@ static void _move(void *data __UNUSED__, Evas *e __UNUSED__, Evas_Object *obj, v static void _resize(void *data __UNUSED__, Evas *e __UNUSED__, Evas_Object *obj, void *event_info __UNUSED__); static void _child_change(void *data __UNUSED__, Evas *e __UNUSED__, Evas_Object *obj, void *event_info __UNUSED__); static void _child_del(void *data, Evas *e __UNUSED__, Evas_Object *obj, void *event_info __UNUSED__); -static void _content_set_hook(Evas_Object *obj, const char *part __UNUSED__, Evas_Object *content); -static Evas_Object *_content_get_hook(const Evas_Object *obj, const char *part __UNUSED__); +static void _content_set_hook(Evas_Object *obj, const char *part, Evas_Object *content); +static Evas_Object *_content_get_hook(const Evas_Object *obj, const char *part); +static Evas_Object *_content_unset_hook(Evas_Object *obj, const char *part); static const char SIG_REALIZE[] = "realize"; static const char SIG_UNREALIZE[] = "unrealize"; @@ -131,16 +132,16 @@ _eval(Evas_Object *obj) if (evas_object_smart_data_get(wd->content)) evas_object_smart_calculate(wd->content); } - wd->last_calc_count = - evas_smart_objects_calculate_count_get(evas_object_evas_get(obj)); + //wd->last_calc_count = + //evas_smart_objects_calculate_count_get(evas_object_evas_get(obj)); } } else { if (wd->content) { - if (wd->last_calc_count != - evas_smart_objects_calculate_count_get(evas_object_evas_get(obj))) + //if (wd->last_calc_count != + //evas_smart_objects_calculate_count_get(evas_object_evas_get(obj))) evas_object_smart_callback_call(obj, SIG_UNREALIZE, NULL); } } @@ -211,49 +212,65 @@ _child_del(void *data, Evas *e __UNUSED__, Evas_Object *obj, void *event_info __ // printf("FAC-- = %i\n", fac); } +static Evas_Object * +_content_unset_hook(Evas_Object *obj, const char *part) +{ + ELM_CHECK_WIDTYPE(obj, widtype) NULL; + Widget_Data *wd; + Evas_Object *content; + + if (part && strcmp(part, "default")) return NULL; + wd = elm_widget_data_get(obj); + if (!wd || !wd->content) return NULL; + + content = wd->content; + evas_object_event_callback_del_full(content, + EVAS_CALLBACK_CHANGED_SIZE_HINTS, + _child_change, obj); + evas_object_event_callback_del_full(content, + EVAS_CALLBACK_DEL, + _child_del, obj); + wd->content = NULL; + fac--; +// printf("FAC-- = %i\n", fac); + return content; +} + static void -_content_set_hook(Evas_Object *obj, const char *part __UNUSED__, Evas_Object *content) +_content_set_hook(Evas_Object *obj, const char *part, Evas_Object *content) { ELM_CHECK_WIDTYPE(obj, widtype); - Widget_Data *wd = elm_widget_data_get(obj); + Widget_Data *wd; + Evas_Object *prev_content; + + if (part && strcmp(part, "default")) return; + wd = elm_widget_data_get(obj); if (!wd) return; if (wd->content == content) return; - if (wd->content) - { - Evas_Object *o = wd->content; - - evas_object_event_callback_del_full(wd->content, - EVAS_CALLBACK_CHANGED_SIZE_HINTS, - _child_change, obj); - evas_object_event_callback_del_full(wd->content, - EVAS_CALLBACK_DEL, - _child_del, obj); - wd->content = NULL; - evas_object_del(o); - fac--; -// printf("FAC-- = %i\n", fac); - } + + prev_content = _content_unset_hook(obj, part); + if (prev_content) evas_object_del(prev_content); + wd->content = content; - if (wd->content) - { - fac++; -// printf("FAC++ = %i\n", fac); - elm_widget_resize_object_set(obj, wd->content); - evas_object_event_callback_add(wd->content, EVAS_CALLBACK_DEL, - _child_del, obj); - evas_object_event_callback_add(wd->content, EVAS_CALLBACK_CHANGED_SIZE_HINTS, - _child_change, obj); - wd->eval = EINA_TRUE; - wd->szeval = EINA_TRUE; - evas_object_smart_changed(obj); - } + if (!content) return; + + elm_widget_resize_object_set(obj, content); + evas_object_event_callback_add(content, EVAS_CALLBACK_DEL, _child_del, obj); + evas_object_event_callback_add(content, EVAS_CALLBACK_CHANGED_SIZE_HINTS, + _child_change, obj); + wd->eval = EINA_TRUE; + wd->szeval = EINA_TRUE; + evas_object_smart_changed(obj); + fac++; } static Evas_Object * -_content_get_hook(const Evas_Object *obj, const char *part __UNUSED__) +_content_get_hook(const Evas_Object *obj, const char *part) { ELM_CHECK_WIDTYPE(obj, widtype) NULL; - Widget_Data *wd = elm_widget_data_get(obj); + Widget_Data *wd; + if (part && strcmp(part, "default")) return NULL; + wd = elm_widget_data_get(obj); if (!wd) return NULL; return wd->content; } @@ -275,6 +292,7 @@ elm_factory_add(Evas_Object *parent) elm_widget_focus_next_hook_set(obj, _focus_next_hook); elm_widget_content_set_hook_set(obj, _content_set_hook); elm_widget_content_get_hook_set(obj, _content_get_hook); + elm_widget_content_unset_hook_set(obj, _content_unset_hook); elm_widget_can_focus_set(obj, EINA_FALSE); elm_widget_changed_hook_set(obj, _changed); @@ -289,18 +307,6 @@ elm_factory_add(Evas_Object *parent) } EAPI void -elm_factory_content_set(Evas_Object *obj, Evas_Object *content) -{ - _content_set_hook(obj, NULL, content); -} - -EAPI Evas_Object * -elm_factory_content_get(const Evas_Object *obj) -{ - return _content_get_hook(obj, NULL); -} - -EAPI void elm_factory_maxmin_mode_set(Evas_Object *obj, Eina_Bool enabled) { ELM_CHECK_WIDTYPE(obj, widtype);