summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRafael Antognolli <rafael.antognolli@linux.intel.com>2013-03-21 20:45:44 -0300
committerRafael Antognolli <rafael.antognolli@linux.intel.com>2013-03-21 20:45:44 -0300
commit048c8f0b2547b5fef94141b100a25be61b55bfa4 (patch)
tree3e0f4ab78705dc86f0a8d00912c195f457249ccf
parenta8c63de55a13559a204793ee1ce425205e1d172c (diff)
downloadefl-048c8f0b2547b5fef94141b100a25be61b55bfa4.tar.gz
ecore_evas/wayland: Use clipped smart object for window decorations.
When creating windows directly with Ecore_Evas, instead of using Elementary, a default smart object is provided for the frame (client side window decorations). Now this smart object inherits from the clipped smart object, which means that all its member objects will be clipped to its main clipper, being skipped when the framespace clipper checks for objects without a clipper. Fix a ticket, which I don't remember the number because trac doesn't work.
-rw-r--r--src/modules/ecore_evas/engines/wayland/ecore_evas_wayland_common.c58
1 files changed, 32 insertions, 26 deletions
diff --git a/src/modules/ecore_evas/engines/wayland/ecore_evas_wayland_common.c b/src/modules/ecore_evas/engines/wayland/ecore_evas_wayland_common.c
index ee17249a21..7c2b4c6c5f 100644
--- a/src/modules/ecore_evas/engines/wayland/ecore_evas_wayland_common.c
+++ b/src/modules/ecore_evas/engines/wayland/ecore_evas_wayland_common.c
@@ -4,19 +4,29 @@
#include "ecore_evas_wayland_private.h"
+#define _smart_frame_type "ecore_evas_wl_frame"
+
static const char *interface_wl_name = "wayland";
static const int interface_wl_version = 1;
-/* local structures */
+/* local structures for the frame smart object */
typedef struct _EE_Wl_Smart_Data EE_Wl_Smart_Data;
struct _EE_Wl_Smart_Data
{
+ Evas_Object_Smart_Clipped_Data base;
Evas_Object *frame;
Evas_Object *text;
Evas_Coord x, y, w, h;
};
-static Evas_Smart *_ecore_evas_wl_common_smart = NULL;
+static const Evas_Smart_Cb_Description _smart_callbacks[] =
+{
+ {NULL, NULL}
+};
+
+EVAS_SMART_SUBCLASS_NEW(_smart_frame_type, _ecore_evas_wl_frame,
+ Evas_Smart_Class, Evas_Smart_Class,
+ evas_object_smart_clipped_class_get, _smart_callbacks);
/* local variables */
static int _ecore_evas_wl_init_count = 0;
@@ -228,6 +238,9 @@ _ecore_evas_wl_common_cb_window_configure(void *data EINA_UNUSED, int type EINA_
_ecore_evas_wayland_resize(ee, win->edges);
}
+
+ if (wdata->frame)
+ evas_object_resize(wdata->frame, ev->w, ev->h);
}
return ECORE_CALLBACK_PASS_ON;
@@ -451,7 +464,11 @@ _ecore_evas_wl_common_smart_add(Evas_Object *obj)
LOGFN(__FILE__, __LINE__, __FUNCTION__);
- if (!(sd = calloc(1, sizeof(EE_Wl_Smart_Data)))) return;
+ EVAS_SMART_DATA_ALLOC(obj, EE_Wl_Smart_Data);
+
+ _ecore_evas_wl_frame_parent_sc->add(obj);
+
+ sd = priv;
evas = evas_object_evas_get(obj);
@@ -470,8 +487,6 @@ _ecore_evas_wl_common_smart_add(Evas_Object *obj)
evas_object_text_font_set(sd->text, "Sans", 10);
evas_object_text_text_set(sd->text, "Smart Test");
evas_object_smart_member_add(sd->text, obj);
-
- evas_object_smart_data_set(obj, sd);
}
static void
@@ -484,7 +499,7 @@ _ecore_evas_wl_common_smart_del(Evas_Object *obj)
if (!(sd = evas_object_smart_data_get(obj))) return;
evas_object_del(sd->text);
evas_object_del(sd->frame);
- free(sd);
+ _ecore_evas_wl_frame_parent_sc->del(obj);
}
static void
@@ -511,6 +526,8 @@ _ecore_evas_wl_common_smart_show(Evas_Object *obj)
if (!(sd = evas_object_smart_data_get(obj))) return;
evas_object_show(sd->frame);
evas_object_show(sd->text);
+
+ _ecore_evas_wl_frame_parent_sc->show(obj);
}
static void
@@ -523,28 +540,18 @@ _ecore_evas_wl_common_smart_hide(Evas_Object *obj)
if (!(sd = evas_object_smart_data_get(obj))) return;
evas_object_hide(sd->text);
evas_object_hide(sd->frame);
+
+ _ecore_evas_wl_frame_parent_sc->hide(obj);
}
static void
-_ecore_evas_wl_common_smart_init(void)
+_ecore_evas_wl_frame_smart_set_user(Evas_Smart_Class *sc)
{
- LOGFN(__FILE__, __LINE__, __FUNCTION__);
-
- if (_ecore_evas_wl_common_smart) return;
- {
- static const Evas_Smart_Class sc =
- {
- "ecore_evas_wl_frame", EVAS_SMART_CLASS_VERSION,
- _ecore_evas_wl_common_smart_add,
- _ecore_evas_wl_common_smart_del,
- NULL,
- _ecore_evas_wl_common_smart_resize,
- _ecore_evas_wl_common_smart_show,
- _ecore_evas_wl_common_smart_hide,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL
- };
- _ecore_evas_wl_common_smart = evas_smart_class_new(&sc);
- }
+ sc->add = _ecore_evas_wl_common_smart_add;
+ sc->del = _ecore_evas_wl_common_smart_del;
+ sc->show = _ecore_evas_wl_common_smart_show;
+ sc->hide = _ecore_evas_wl_common_smart_hide;
+ sc->resize = _ecore_evas_wl_common_smart_resize;
}
Evas_Object *
@@ -552,8 +559,7 @@ _ecore_evas_wl_common_frame_add(Evas *evas)
{
LOGFN(__FILE__, __LINE__, __FUNCTION__);
- _ecore_evas_wl_common_smart_init();
- return evas_object_smart_add(evas, _ecore_evas_wl_common_smart);
+ return evas_object_smart_add(evas, _ecore_evas_wl_frame_smart_class_new());
}
void