From: Marcel Hollerbach Date: Thu, 24 Jan 2019 13:09:42 +0000 (+0100) Subject: efl_ui_pan: implement content interface X-Git-Tag: accepted/tizen/unified/20190201.061426~68 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=7e58f26824a7ce3937a8c33212bec103200511f6;p=platform%2Fupstream%2Fefl.git efl_ui_pan: implement content interface the last two functions for the content interface have been missing. Now the pan object can also unset and set new content ref T5719 Reviewed-by: Cedric BAIL Differential Revision: https://phab.enlightenment.org/D7757 --- diff --git a/src/lib/elementary/efl_ui_pan.c b/src/lib/elementary/efl_ui_pan.c index 062e94c..b84e0ba 100644 --- a/src/lib/elementary/efl_ui_pan.c +++ b/src/lib/elementary/efl_ui_pan.c @@ -156,14 +156,7 @@ _efl_ui_pan_efl_content_content_set(Evas_Object *obj, Efl_Ui_Pan_Data *psd, Evas if (content == psd->content) return EINA_TRUE; if (psd->content) { - efl_canvas_group_member_del(obj, psd->content); - evas_object_event_callback_del_full - (psd->content, EVAS_CALLBACK_DEL, _efl_ui_pan_content_del_cb, obj); - evas_object_event_callback_del_full - (psd->content, EVAS_CALLBACK_RESIZE, _efl_ui_pan_content_resize_cb, - obj); - psd->content = NULL; - psd->content_w = psd->content_h = psd->px = psd->py = 0; + efl_content_unset(obj); } if (!content) goto end; @@ -189,6 +182,30 @@ end: return EINA_TRUE; } +EOLIAN static Efl_Gfx_Entity* +_efl_ui_pan_efl_content_content_get(const Eo *obj EINA_UNUSED, Efl_Ui_Pan_Data *pd) +{ + return pd->content; +} + +EOLIAN static Efl_Gfx_Entity* +_efl_ui_pan_efl_content_content_unset(Eo *obj EINA_UNUSED, Efl_Ui_Pan_Data *pd) +{ + Efl_Gfx_Stack *old_content = pd->content; + + efl_canvas_group_member_del(obj, pd->content); + evas_object_event_callback_del_full + (pd->content, EVAS_CALLBACK_DEL, _efl_ui_pan_content_del_cb, obj); + evas_object_event_callback_del_full + (pd->content, EVAS_CALLBACK_RESIZE, _efl_ui_pan_content_resize_cb, + obj); + pd->content = NULL; + pd->content_w = pd->content_h = pd->px = pd->py = 0; + efl_event_callback_call(obj, EFL_UI_PAN_EVENT_CONTENT_CHANGED, NULL); + + return old_content; +} + EOLIAN static void _efl_ui_pan_efl_canvas_group_group_calculate(Eo *obj EINA_UNUSED, Efl_Ui_Pan_Data *psd) { diff --git a/src/lib/elementary/efl_ui_pan.eo b/src/lib/elementary/efl_ui_pan.eo index bd47b60..907d50b 100644 --- a/src/lib/elementary/efl_ui_pan.eo +++ b/src/lib/elementary/efl_ui_pan.eo @@ -43,7 +43,8 @@ class Efl.Ui.Pan extends Efl.Canvas.Group implements Efl.Content Efl.Gfx.Entity.visible { set; } Efl.Gfx.Entity.position { set; } Efl.Gfx.Entity.size { set; } - Efl.Content.content { set; } + Efl.Content.content { set; get; } + Efl.Content.content_unset; Efl.Canvas.Group.group_calculate; } events {