Enlightenment CVS committal

Author  : devilhorns
Project : e17
Module  : apps/e

Dir     : e17/apps/e/src/bin


Modified Files:
        Makefile.am e_includes.h e_int_config_transitions.c 
Removed Files:
        e_widget_trans_preview.c e_widget_trans_preview.h 


Log Message:
Remove the transition preview widget and create it directly in the dialog
without having a seperate e_widget for it.

===================================================================
RCS file: /cvs/e/e17/apps/e/src/bin/Makefile.am,v
retrieving revision 1.158
retrieving revision 1.159
diff -u -3 -r1.158 -r1.159
--- Makefile.am 10 Oct 2006 16:26:29 -0000      1.158
+++ Makefile.am 12 Oct 2006 11:49:51 -0000      1.159
@@ -174,8 +174,7 @@
 e_int_config_transitions.h \
 e_fwin.h \
 e_widget_aspect.h \
-e_widget_desk_preview.h \
-e_widget_trans_preview.h
+e_widget_desk_preview.h
  
 enlightenment_src = \
 e_user.c \
@@ -326,7 +325,6 @@
 e_fwin.c \
 e_widget_aspect.c \
 e_widget_desk_preview.c \
-e_widget_trans_preview.c \
 $(ENLIGHTENMENTHEADERS)
 
 enlightenment_SOURCES = \
===================================================================
RCS file: /cvs/e/e17/apps/e/src/bin/e_includes.h,v
retrieving revision 1.135
retrieving revision 1.136
diff -u -3 -r1.135 -r1.136
--- e_includes.h        10 Oct 2006 16:26:29 -0000      1.135
+++ e_includes.h        12 Oct 2006 11:49:51 -0000      1.136
@@ -151,4 +151,4 @@
 #include "e_fwin.h"
 #include "e_widget_aspect.h"
 #include "e_widget_desk_preview.h"
-#include "e_widget_trans_preview.h"
+
===================================================================
RCS file: /cvs/e/e17/apps/e/src/bin/e_int_config_transitions.c,v
retrieving revision 1.6
retrieving revision 1.7
diff -u -3 -r1.6 -r1.7
--- e_int_config_transitions.c  10 Oct 2006 16:26:29 -0000      1.6
+++ e_int_config_transitions.c  12 Oct 2006 11:49:51 -0000      1.7
@@ -1,5 +1,17 @@
 #include "e.h"
 
+typedef struct _E_Widget_Data E_Widget_Data;
+struct _E_Widget_Data 
+{
+   Evas_Object *obj, *o_frame, *o_clip;
+   Evas_Object *prev_bg, *bg, *o_trans;
+};
+
+static void _e_wid_del_hook(Evas_Object *obj);
+static void _e_wid_done(void *data, Evas_Object *obj, const char *emission, 
const char *source);
+static Evas_Object *_trans_preview_add(Evas *evas, int minw, int minh);
+static void         _trans_preview_trans_set(Evas_Object *obj, const char 
*trans);
+
 static void *_create_data(E_Config_Dialog *cfd);
 static void _free_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata);
 static int _basic_apply_data(E_Config_Dialog *cfd, E_Config_Dialog_Data 
*cfdata);
@@ -145,7 +157,7 @@
    e_widget_table_object_append(ot, of, 1, 0, 1, 1, 1, 1, 1, 1);
 
    of = e_widget_framelist_add(evas, _("Preview"), 0);
-   ob = e_widget_trans_preview_add(evas, 300, ((300 * zone->h) / zone->w));
+   ob = _trans_preview_add(evas, 300, ((300 * zone->h) / zone->w));
    cfdata->tp = ob;
    e_widget_framelist_object_append(of, ob);
    e_widget_table_object_append(ot, of, 2, 0, 1, 1, 1, 1, 1, 1);
@@ -234,5 +246,132 @@
        break;
      }
    if (!t) return;
-   e_widget_trans_preview_trans_set(cfdata->tp, t);
+   _trans_preview_trans_set(cfdata->tp, t);
+}
+
+Evas_Object *
+_trans_preview_add(Evas *evas, int minw, int minh) 
+{
+   Evas_Object *obj, *o;
+   E_Widget_Data *wd;
+   
+   obj = e_widget_add(evas);
+   e_widget_del_hook_set(obj, _e_wid_del_hook);
+   
+   wd = calloc(1, sizeof(E_Widget_Data));
+   wd->obj = obj;
+
+   o = edje_object_add(evas);
+   wd->o_frame = o;
+   e_theme_edje_object_set(o, "base/theme/widgets", "e/widgets/preview");
+   evas_object_show(o);
+   e_widget_sub_object_add(obj, o);
+   e_widget_resize_object_set(obj, o);
+   
+   o = edje_object_add(evas);
+   wd->prev_bg = o;
+   e_theme_edje_object_set(o, "base/theme/backgrounds", 
"e/desktop/background");
+   evas_object_layer_set(o, -1);
+   evas_object_clip_set(o, wd->o_frame);
+   evas_object_show(o);
+   edje_object_part_swallow(wd->o_frame, "e.swallow.content", wd->prev_bg);
+   
+   e_widget_data_set(obj, wd);
+   e_widget_can_focus_set(obj, 0);
+   e_widget_min_size_set(obj, minw, minh);
+
+   return obj;
+}
+
+static void 
+_trans_preview_trans_set(Evas_Object *obj, const char *trans) 
+{
+   Evas *evas;
+   Evas_Object *o;
+   E_Widget_Data *wd;
+   char buf[4096];
+   
+   wd = e_widget_data_get(obj);
+   evas = evas_object_evas_get(wd->o_frame);
+   
+   if (wd->o_trans)
+     evas_object_del(wd->o_trans);
+   if (wd->bg)
+     evas_object_del(wd->bg);
+   if (wd->prev_bg)
+     evas_object_del(wd->prev_bg);
+   
+   snprintf(buf, sizeof(buf), "e/transitions/%s", trans);
+
+   o = edje_object_add(evas);
+   wd->o_trans = o;
+   e_theme_edje_object_set(wd->o_trans, "base/theme/transitions", buf);
+   edje_object_signal_callback_add(o, "e,state,done", "*", _e_wid_done, wd);
+   evas_object_layer_set(o, -1);
+   evas_object_clip_set(o, wd->o_frame);
+   evas_object_show(o);
+   edje_object_part_swallow(wd->o_frame, "e.swallow.content", wd->o_trans);
+
+   o = edje_object_add(evas);
+   wd->bg = o;
+   e_theme_edje_object_set(o, "base/theme/icons", "e/icons/enlightenment/e");
+   evas_object_layer_set(o, -1);
+   evas_object_clip_set(o, wd->o_frame);
+   evas_object_show(o);
+
+   o = edje_object_add(evas);
+   wd->prev_bg = o;
+   e_theme_edje_object_set(o, "base/theme/backgrounds", 
"e/desktop/background");
+   evas_object_layer_set(o, -1);
+   evas_object_clip_set(o, wd->o_frame);
+   evas_object_show(o);
+   
+   edje_object_part_swallow(wd->o_trans, "e.swallow.bg.old", wd->prev_bg);
+   edje_object_part_swallow(wd->o_trans, "e.swallow.bg.new", wd->bg);
+   edje_object_part_swallow(wd->o_frame, "e.swallow.content", wd->o_trans);
+   
+   edje_object_signal_emit(wd->o_trans, "e,action,start", "e");
+}
+
+static void 
+_e_wid_del_hook(Evas_Object *obj) 
+{
+   E_Widget_Data *wd;
+   
+   wd = e_widget_data_get(obj);
+   if (wd->o_frame)
+     evas_object_del(wd->o_frame);
+   if (wd->o_trans)
+     evas_object_del(wd->o_trans);
+   if (wd->bg)
+     evas_object_del(wd->bg);
+   if (wd->prev_bg)
+     evas_object_del(wd->prev_bg);
+   E_FREE(wd);
+}
+
+static void 
+_e_wid_done(void *data, Evas_Object *obj, const char *emission, const char 
*source) 
+{
+   E_Widget_Data *wd;
+   Evas_Object *o;
+   Evas *evas;
+   
+   wd = data;
+   evas = evas_object_evas_get(wd->o_frame);
+   
+   if (wd->o_trans) 
+     evas_object_del(wd->o_trans);
+   if (wd->bg)
+     evas_object_del(wd->bg);
+   if (wd->prev_bg)
+     evas_object_del(wd->prev_bg);
+
+   o = edje_object_add(evas);
+   wd->prev_bg = o;
+   e_theme_edje_object_set(o, "base/theme/backgrounds", 
"e/desktop/background");
+   evas_object_layer_set(o, -1);
+   evas_object_clip_set(o, wd->o_frame);
+   evas_object_show(o);
+   edje_object_part_swallow(wd->o_frame, "e.swallow.content", wd->prev_bg);
 }



-------------------------------------------------------------------------
Using Tomcat but need to do more? Need to support web services, security?
Get stuff done quickly with pre-integrated technology to make your job easier
Download IBM WebSphere Application Server v.1.0.1 based on Apache Geronimo
http://sel.as-us.falkag.net/sel?cmd=lnk&kid=120709&bid=263057&dat=121642
_______________________________________________
enlightenment-cvs mailing list
enlightenment-cvs@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/enlightenment-cvs

Reply via email to