raster pushed a commit to branch master.

commit e0e513f457866042c0099dd6927e1784738bdb91
Author: Carsten Haitzler (Rasterman) <[email protected]>
Date:   Tue Apr 16 20:06:47 2013 +0900

    add zoomap so we get back our zooming comp client things with.. menu
    for today. popups need doing... anything that bypasses the comp native
    surface stuff needs this. :)
---
 src/bin/Makefile.am  |   2 +
 src/bin/e_includes.h |   1 +
 src/bin/e_menu.c     |  29 ++++-
 src/bin/e_menu.h     |   1 +
 src/bin/e_zoomap.c   | 323 +++++++++++++++++++++++++++++++++++++++++++++++++++
 src/bin/e_zoomap.h   |  17 +++
 6 files changed, 367 insertions(+), 6 deletions(-)

diff --git a/src/bin/Makefile.am b/src/bin/Makefile.am
index 675bccf..710112b 100644
--- a/src/bin/Makefile.am
+++ b/src/bin/Makefile.am
@@ -201,6 +201,7 @@ e_win.h \
 e_xinerama.h \
 e_xkb.h \
 e_xsettings.h \
+e_zoomap.h \
 e_zone.h
 
 if HAVE_WAYLAND_CLIENTS
@@ -371,6 +372,7 @@ e_win.c \
 e_xinerama.c \
 e_xkb.c \
 e_xsettings.c \
+e_zoomap.c \
 e_zone.c \
 $(ENLIGHTENMENTHEADERS)
 
diff --git a/src/bin/e_includes.h b/src/bin/e_includes.h
index 5863b22..70b5ceb 100644
--- a/src/bin/e_includes.h
+++ b/src/bin/e_includes.h
@@ -55,6 +55,7 @@
 #include "e_remember.h"
 #include "e_win.h"
 #include "e_pan.h"
+#include "e_zoomap.h"
 #include "e_dialog.h"
 #include "e_configure.h"
 #include "e_configure_option.h"
diff --git a/src/bin/e_menu.c b/src/bin/e_menu.c
index e333eb8..0c37fad 100644
--- a/src/bin/e_menu.c
+++ b/src/bin/e_menu.c
@@ -1170,6 +1170,8 @@ e_menu_idler_before(void)
                   m->prev.h = m->cur.h;
                   w = m->cur.w;
                   h = m->cur.h;
+                  evas_object_resize(m->bg_object, w, h);
+                  evas_object_resize(m->bg_object_wrap, w, h);
                   if (m->cw)
                     e_comp_win_resize(m->cw, w, h);
                }
@@ -1210,9 +1212,10 @@ e_menu_idler_before(void)
              m->prev.visible = m->cur.visible;
              if (!m->cw)
                {
-                  evas_object_move(m->bg_object, m->cur.x, m->cur.y);
                   evas_object_resize(m->bg_object, m->cur.w, m->cur.h);
-                  E_LAYER_SET(m->bg_object, E_COMP_CANVAS_LAYER_MENU);
+                  evas_object_move(m->bg_object_wrap, m->cur.x, m->cur.y);
+                  evas_object_resize(m->bg_object_wrap, m->cur.w, m->cur.h);
+                  E_LAYER_SET(m->bg_object_wrap, E_COMP_CANVAS_LAYER_MENU);
                }
              e_comp_win_show(m->cw);
           }
@@ -1284,7 +1287,8 @@ _e_menu_free(E_Menu *m)
    if (m->parent_item)
      m->parent_item->submenu = NULL;
    /* del callback causes this to unrealize the menu */
-   if (m->bg_object) evas_object_del(m->bg_object);
+   if (m->bg_object_wrap) evas_object_del(m->bg_object_wrap);
+   m->bg_object_wrap = NULL;
    EINA_LIST_FOREACH_SAFE(m->items, l, l_next, mi)
      e_object_del(E_OBJECT(mi));
    if (m->in_active_list)
@@ -1393,6 +1397,8 @@ _e_menu_del_cb(void *data, Evas *e EINA_UNUSED, 
Evas_Object *obj EINA_UNUSED, vo
    E_Menu *m = data;
 
    m->bg_object = NULL;
+   evas_object_del(m->bg_object_wrap);
+   m->bg_object_wrap = NULL;
    _e_menu_unrealize(m);
 }
 
@@ -1688,6 +1694,7 @@ _e_menu_realize(E_Menu *m)
    Evas_Object *o;
    Eina_List *l;
    E_Menu_Item *mi;
+   const char *s;
 
    if (m->realized || (!m->items)) return;
    m->realized = 1;
@@ -1701,9 +1708,6 @@ _e_menu_realize(E_Menu *m)
    o = edje_object_add(m->evas);
    evas_object_event_callback_add(o, EVAS_CALLBACK_DEL, _e_menu_del_cb, m);
    m->bg_object = o;
-   evas_object_name_set(o, "menu->bg_object");
-   evas_object_data_set(o, "e_menu", m);
-   evas_object_data_set(o, "eobj", m);
    e_theme_edje_object_set(o, "base/theme/menus", 
"e/widgets/menu/default/background");
    if (m->header.title)
      {
@@ -1712,6 +1716,17 @@ _e_menu_realize(E_Menu *m)
         edje_object_message_signal_process(o);
      }
 
+   o = e_zoomap_add(m->evas);
+   evas_object_name_set(o, "menu->bg_object_wrap");
+   evas_object_data_set(o, "e_menu", m);
+   evas_object_data_set(o, "eobj", m);
+   m->bg_object_wrap = o;
+   s = edje_object_data_get(m->bg_object, "argb");
+   if (!s) s = edje_object_data_get(m->bg_object, "shaped");
+   if ((s) && (s[0] == '1')) e_zoomap_solid_set(o, EINA_FALSE);
+   else e_zoomap_solid_set(o, EINA_TRUE);
+   e_zoomap_child_set(o, m->bg_object);
+
    o = e_box_add(m->evas);
    evas_object_name_set(o, "menu->container_object");
    m->container_object = o;
@@ -1981,6 +1996,8 @@ _e_menu_unrealize(E_Menu *m)
    m->header.icon = NULL;
    if (m->bg_object) evas_object_del(m->bg_object);
    m->bg_object = NULL;
+   if (m->bg_object_wrap) evas_object_del(m->bg_object_wrap);
+   m->bg_object_wrap = NULL;
    if (m->container_object) evas_object_del(m->container_object);
    m->container_object = NULL;
    m->cur.visible = 0;
diff --git a/src/bin/e_menu.h b/src/bin/e_menu.h
index 8c4d05c..36f22cc 100644
--- a/src/bin/e_menu.h
+++ b/src/bin/e_menu.h
@@ -56,6 +56,7 @@ struct _E_Menu
    E_Container_Shape  *shape;
    Ecore_Job           *dangling_job;
    Evas                 *evas;
+   Evas_Object         *bg_object_wrap;
    Evas_Object         *bg_object;
    Evas_Object         *container_object;
    Evas_Coord           container_x, container_y, container_w, container_h;
diff --git a/src/bin/e_zoomap.c b/src/bin/e_zoomap.c
new file mode 100644
index 0000000..8084076
--- /dev/null
+++ b/src/bin/e_zoomap.c
@@ -0,0 +1,323 @@
+#include "e.h"
+
+#define SMART_NAME     "e_zoomap"
+#define API_ENTRY      E_Smart_Data * sd; sd = 
evas_object_smart_data_get(obj); if ((!obj) || (!sd) || 
(evas_object_type_get(obj) && strcmp(evas_object_type_get(obj), SMART_NAME)))
+#define INTERNAL_ENTRY E_Smart_Data * sd; sd = 
evas_object_smart_data_get(obj); if (!sd) return;
+typedef struct _E_Smart_Data E_Smart_Data;
+
+struct _E_Smart_Data
+{
+   Evas_Object *smart_obj, *child_obj;
+   Evas_Coord   x, y, w, h;
+   Evas_Coord   child_w, child_h;
+   Eina_Bool    solid : 1;
+   Eina_Bool    smooth : 1;
+   Eina_Bool    always : 1;
+};
+
+/* local subsystem functions */
+static void _e_smart_child_del_hook(void *data, Evas *e, Evas_Object *obj, 
void *event_info);
+static void _e_smart_child_resize_hook(void *data, Evas *e, Evas_Object *obj, 
void *event_info);
+
+static void _e_smart_reconfigure(E_Smart_Data *sd);
+static void _e_smart_add(Evas_Object *obj);
+static void _e_smart_del(Evas_Object *obj);
+static void _e_smart_move(Evas_Object *obj, Evas_Coord x, Evas_Coord y);
+static void _e_smart_resize(Evas_Object *obj, Evas_Coord w, Evas_Coord h);
+static void _e_smart_show(Evas_Object *obj);
+static void _e_smart_hide(Evas_Object *obj);
+static void _e_smart_color_set(Evas_Object *obj, int r, int g, int b, int a);
+static void _e_smart_clip_set(Evas_Object *obj, Evas_Object *clip);
+static void _e_smart_clip_unset(Evas_Object *obj);
+static void _e_smart_init(void);
+
+/* local subsystem globals */
+static Evas_Smart *_e_smart = NULL;
+
+/* externally accessible functions */
+EAPI Evas_Object *
+e_zoomap_add(Evas *evas)
+{
+   _e_smart_init();
+   return evas_object_smart_add(evas, _e_smart);
+}
+
+EAPI void
+e_zoomap_child_set(Evas_Object *obj, Evas_Object *child)
+{
+   API_ENTRY return;
+   if (child == sd->child_obj) return;
+   if (sd->child_obj)
+     {
+        evas_object_clip_unset(sd->child_obj);
+        evas_object_smart_member_del(sd->child_obj);
+        evas_object_event_callback_del(sd->child_obj, EVAS_CALLBACK_DEL,
+                                       _e_smart_child_del_hook);
+        evas_object_event_callback_del(sd->child_obj, EVAS_CALLBACK_RESIZE,
+                                       _e_smart_child_resize_hook);
+        sd->child_obj = NULL;
+     }
+   if (child)
+     {
+        int r, g, b, a;
+
+        sd->child_obj = child;
+        evas_object_smart_member_add(sd->child_obj, sd->smart_obj);
+        evas_object_geometry_get(sd->child_obj, NULL, NULL,
+                                 &sd->child_w, &sd->child_h);
+        evas_object_event_callback_add(child, EVAS_CALLBACK_DEL,
+                                       _e_smart_child_del_hook, sd);
+        evas_object_event_callback_add(child, EVAS_CALLBACK_RESIZE,
+                                       _e_smart_child_resize_hook, sd);
+        if (evas_object_visible_get(obj)) evas_object_show(sd->child_obj);
+        else evas_object_hide(sd->child_obj);
+        evas_object_color_get(sd->smart_obj, &r, &g, &b, &a);
+        evas_object_color_set(sd->child_obj, r, g, b, a);
+        evas_object_clip_set(sd->child_obj, 
evas_object_clip_get(sd->smart_obj));
+        _e_smart_reconfigure(sd);
+     }
+}
+
+EAPI Evas_Object *
+e_zoomap_child_get(Evas_Object *obj)
+{
+   API_ENTRY return NULL;
+   return sd->child_obj;
+}
+
+EAPI void
+e_zoomap_smooth_set(Evas_Object *obj, Eina_Bool smooth)
+{
+   API_ENTRY return;
+   smooth = !!smooth;
+   if (sd->smooth == smooth) return;
+   sd->smooth = smooth;
+   _e_smart_reconfigure(sd);
+}
+
+EAPI Eina_Bool
+e_zoomap_smooth_get(Evas_Object *obj)
+{
+   API_ENTRY return EINA_FALSE;
+   return sd->smooth;
+}
+
+EAPI void
+e_zoomap_solid_set(Evas_Object *obj, Eina_Bool solid)
+{
+   API_ENTRY return;
+   solid = !!solid;
+   if (sd->solid == solid) return;
+   sd->solid = solid;
+   _e_smart_reconfigure(sd);
+}
+
+EAPI Eina_Bool
+e_zoomap_solid_get(Evas_Object *obj)
+{
+   API_ENTRY return EINA_FALSE;
+   return sd->solid;
+}
+
+EAPI void
+e_zoomap_always_set(Evas_Object *obj, Eina_Bool always)
+{
+   API_ENTRY return;
+   always = !!always;
+   if (sd->always == always) return;
+   sd->always = always;
+   _e_smart_reconfigure(sd);
+}
+
+EAPI Eina_Bool
+e_zoomap_always_get(Evas_Object *obj)
+{
+   API_ENTRY return EINA_FALSE;
+   return sd->always;
+}
+
+/* local subsystem functions */
+static void
+_e_smart_child_del_hook(void *data, Evas *e __UNUSED__, Evas_Object *obj 
__UNUSED__, void *event_info __UNUSED__)
+{
+   E_Smart_Data *sd;
+
+   sd = data;
+   sd->child_obj = NULL;
+}
+
+static void
+_e_smart_child_resize_hook(void *data, Evas *e __UNUSED__, Evas_Object *obj 
__UNUSED__, void *event_info __UNUSED__)
+{
+   E_Smart_Data *sd;
+   Evas_Coord w, h;
+
+   sd = data;
+   if (!sd->child_obj) return;
+   evas_object_geometry_get(sd->child_obj, NULL, NULL, &w, &h);
+   if ((w != sd->child_w) || (h != sd->child_h))
+     {
+        sd->child_w = w;
+        sd->child_h = h;
+        _e_smart_reconfigure(sd);
+     }
+}
+
+static void
+_e_smart_reconfigure(E_Smart_Data *sd)
+{
+   if (!sd->child_obj) return;
+   if ((!sd->always) &&
+       ((sd->w == sd->child_w) && (sd->h == sd->child_h)))
+     {
+        evas_object_map_set(sd->child_obj, NULL);
+        evas_object_map_enable_set(sd->child_obj, EINA_FALSE);
+        evas_object_move(sd->child_obj, sd->x, sd->y);
+        evas_object_resize(sd->child_obj, sd->w, sd->h);
+     }
+   else
+     {
+        Evas_Map *m;
+        Evas *e = evas_object_evas_get(sd->child_obj);
+        Evas_Coord cx = 0, cy = 0;
+        int r = 0, g = 0, b = 0, a = 0;
+        
+        evas_object_geometry_get(sd->child_obj, &cx, &cy, NULL, NULL);
+        evas_object_color_get(sd->child_obj, &r, &g, &b, &a);
+        if ((cx != sd->x) || (cy != sd->y))
+          {
+             evas_smart_objects_calculate(e);
+             evas_nochange_push(e);
+             evas_object_move(sd->child_obj, sd->x, sd->y);
+             evas_smart_objects_calculate(e);
+             evas_nochange_pop(e);
+          }
+        m = evas_map_new(4);
+        evas_map_util_points_populate_from_geometry(m, sd->x, sd->y, 
+                                                    sd->w, sd->h, 0);
+        evas_map_point_image_uv_set(m, 0, 0,           0);
+        evas_map_point_image_uv_set(m, 1, sd->child_w, 0);
+        evas_map_point_image_uv_set(m, 2, sd->child_w, sd->child_h);
+        evas_map_point_image_uv_set(m, 3, 0,           sd->child_h);
+        evas_map_smooth_set(m, sd->smooth);
+        evas_map_point_color_set(m, 0, r, g, b, a);
+        evas_map_point_color_set(m, 1, r, g, b, a);
+        evas_map_point_color_set(m, 2, r, g, b, a);
+        evas_map_point_color_set(m, 3, r, g, b, a);
+        //if (a >= 255) evas_map_alpha_set(m, !sd->solid);
+        //else evas_map_alpha_set(m, EINA_TRUE); 
+        evas_map_alpha_set(m, EINA_TRUE);
+        evas_object_map_set(sd->child_obj, m);
+        evas_object_map_enable_set(sd->child_obj, EINA_TRUE);
+        evas_map_free(m);
+     }
+}
+
+static void
+_e_smart_add(Evas_Object *obj)
+{
+   E_Smart_Data *sd;
+
+   sd = E_NEW(E_Smart_Data, 1);
+   if (!sd) return;
+   sd->smart_obj = obj;
+   sd->x = sd->y = sd->w = sd->h = 0;
+   sd->solid = EINA_TRUE;
+   sd->always = EINA_TRUE;
+   sd->smooth = EINA_TRUE;
+   evas_object_smart_data_set(obj, sd);
+}
+
+static void
+_e_smart_del(Evas_Object *obj)
+{
+   INTERNAL_ENTRY;
+   if (sd->child_obj)
+     {
+        evas_object_event_callback_del(sd->child_obj, EVAS_CALLBACK_DEL,
+                                       _e_smart_child_del_hook);
+        evas_object_event_callback_del(sd->child_obj, EVAS_CALLBACK_RESIZE,
+                                       _e_smart_child_resize_hook);
+        evas_object_del(sd->child_obj);
+        sd->child_obj = NULL;
+     }
+   E_FREE(sd);
+}
+
+static void
+_e_smart_move(Evas_Object *obj, Evas_Coord x, Evas_Coord y)
+{
+   INTERNAL_ENTRY;
+   sd->x = x;
+   sd->y = y;
+   _e_smart_reconfigure(sd);
+}
+
+static void
+_e_smart_resize(Evas_Object *obj, Evas_Coord w, Evas_Coord h)
+{
+   INTERNAL_ENTRY;
+   sd->w = w;
+   sd->h = h;
+   _e_smart_reconfigure(sd);
+}
+
+static void
+_e_smart_show(Evas_Object *obj)
+{
+   INTERNAL_ENTRY;
+   if (sd->child_obj) evas_object_show(sd->child_obj);
+   if (!evas_object_map_enable_get(sd->child_obj)) _e_smart_reconfigure(sd);
+}
+
+static void
+_e_smart_hide(Evas_Object *obj)
+{
+   INTERNAL_ENTRY;
+   if ((!sd->always) &&
+       (evas_object_map_enable_get(sd->child_obj)))
+     {
+        evas_object_map_set(sd->child_obj, NULL);
+        evas_object_map_enable_set(sd->child_obj, EINA_FALSE);
+        evas_object_move(sd->child_obj, sd->x, sd->y);
+        evas_object_resize(sd->child_obj, sd->w, sd->h);
+     }
+   if (sd->child_obj) evas_object_hide(sd->child_obj);
+}
+
+static void
+_e_smart_color_set(Evas_Object *obj, int r, int g, int b, int a)
+{
+   INTERNAL_ENTRY;
+   if (sd->child_obj) evas_object_color_set(sd->child_obj, r, g, b, a);
+}
+
+static void
+_e_smart_clip_set(Evas_Object *obj, Evas_Object *clip)
+{
+   INTERNAL_ENTRY;
+   if (sd->child_obj) evas_object_clip_set(sd->child_obj, clip);
+}
+
+static void
+_e_smart_clip_unset(Evas_Object *obj)
+{
+   INTERNAL_ENTRY;
+   if (sd->child_obj) evas_object_clip_unset(sd->child_obj);
+}
+
+/* never need to touch this */
+static void
+_e_smart_init(void)
+{
+   static const Evas_Smart_Class sc =
+     {
+        SMART_NAME, EVAS_SMART_CLASS_VERSION,
+        _e_smart_add, _e_smart_del, _e_smart_move, _e_smart_resize,
+        _e_smart_show, _e_smart_hide, _e_smart_color_set, _e_smart_clip_set,
+        _e_smart_clip_unset, NULL, NULL, NULL, NULL, NULL, NULL, NULL
+     };
+   if (_e_smart) return;
+   _e_smart = evas_smart_class_new(&sc);
+}
+
diff --git a/src/bin/e_zoomap.h b/src/bin/e_zoomap.h
new file mode 100644
index 0000000..31ee694
--- /dev/null
+++ b/src/bin/e_zoomap.h
@@ -0,0 +1,17 @@
+#ifdef E_TYPEDEFS
+#else
+#ifndef E_ZOOMAP_H
+#define E_ZOOMAP_H
+
+EAPI Evas_Object *e_zoomap_add            (Evas *evas);
+EAPI void         e_zoomap_child_set      (Evas_Object *obj, Evas_Object 
*child);
+EAPI Evas_Object *e_zoomap_child_get      (Evas_Object *obj);
+EAPI void         e_zoomap_smooth_set     (Evas_Object *obj, Eina_Bool smooth);
+EAPI Eina_Bool    e_zoomap_smooth_get     (Evas_Object *obj);
+EAPI void         e_zoomap_solid_set      (Evas_Object *obj, Eina_Bool solid);
+EAPI Eina_Bool    e_zoomap_solid_get      (Evas_Object *obj);
+EAPI void         e_zoomap_always_set     (Evas_Object *obj, Eina_Bool always);
+EAPI Eina_Bool    e_zoomap_always_get     (Evas_Object *obj);
+
+#endif
+#endif

-- 

------------------------------------------------------------------------------
Precog is a next-generation analytics platform capable of advanced
analytics on semi-structured data. The platform includes APIs for building
apps and a phenomenal toolset for data science. Developers can use
our toolset for easy data analysis & visualization. Get a free account!
http://www2.precog.com/precogplatform/slashdotnewsletter

Reply via email to