fix up transitions dialog... :)
authorCarsten Haitzler <raster@rasterman.com>
Fri, 20 Oct 2006 14:31:51 +0000 (14:31 +0000)
committerCarsten Haitzler <raster@rasterman.com>
Fri, 20 Oct 2006 14:31:51 +0000 (14:31 +0000)
SVN revision: 26710

data/themes/default_transitions.edc
data/themes/images/Makefile.am
data/themes/images/e17_trans1.png [new file with mode: 0644]
data/themes/images/e17_trans2.png [new file with mode: 0644]
src/bin/e_int_config_transitions.c
src/bin/e_widget_preview.c
src/bin/e_widget_preview.h

index 6c4b2fd..56fdc94 100644 (file)
@@ -1,8 +1,46 @@
 images {
+   image: "e17_trans1.png" LOSSY 90;
+   image: "e17_trans2.png" LOSSY 90;
    image: "e17_transition_vswipe_gap.png" COMP;
 }
 
 group {
+   name: "e/transpreview/0";
+   parts {
+      part {
+        name: "bg";
+        mouse_events: 0;
+        description {
+           state: "default" 0.0;
+           aspect: 1.33333333333 1.33333333333;
+           aspect_preference: NONE;
+           image {
+              normal: "e17_trans1.png";
+           }
+        }
+      }
+   }
+}
+
+group {
+   name: "e/transpreview/1";
+   parts {
+      part {
+        name: "bg";
+        mouse_events: 0;
+        description {
+           state: "default" 0.0;
+           aspect: 1.33333333333 1.33333333333;
+           aspect_preference: NONE;
+           image {
+              normal: "e17_trans2.png";
+           }
+        }
+      }
+   }
+}
+
+group {
    name: "e/transitions/crossfade";
    parts {
       part {
index 44c69dd..df8fcc4 100644 (file)
@@ -505,4 +505,6 @@ e17_icon_logout.png \
 e17_icon_hibernate.png \
 e17_icon_suspend.png \
 e17_icon_halt.png \
-e17_icon_reboot.png
+e17_icon_reboot.png \
+e17_trans1.png \
+e17_trans2.png
diff --git a/data/themes/images/e17_trans1.png b/data/themes/images/e17_trans1.png
new file mode 100644 (file)
index 0000000..400c413
Binary files /dev/null and b/data/themes/images/e17_trans1.png differ
diff --git a/data/themes/images/e17_trans2.png b/data/themes/images/e17_trans2.png
new file mode 100644 (file)
index 0000000..bcdf1c3
Binary files /dev/null and b/data/themes/images/e17_trans2.png differ
index dda24cd..44829e4 100644 (file)
@@ -1,16 +1,8 @@
 #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 Evas_Object *_trans_preview_add(E_Config_Dialog_Data *cfdata, Evas *evas, int minw, int minh);
+static void         _e_wid_done(void *data, Evas_Object *obj, const char *emission, const char *source);
+static void         _trans_preview_trans_set(E_Config_Dialog_Data *cfdata, const char *trans);
 
 static void *_create_data(E_Config_Dialog *cfd);
 static void _free_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata);
@@ -29,6 +21,9 @@ struct _E_Config_Dialog_Data
    Evas_Object *event_list;
    Evas_Object *trans_list;
    Evas_Object *tp;
+   Evas_Object *o_trans;
+   Evas_Object *o_prev_bg;
+   Evas_Object *o_bg;
 };
 
 EAPI E_Config_Dialog *
@@ -157,7 +152,7 @@ _basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cf
    e_widget_table_object_append(ot, of, 1, 0, 1, 1, 1, 1, 1, 1);
 
    of = e_widget_framelist_add(evas, _("Preview"), 0);
-   ob = _trans_preview_add(evas, 300, ((300 * zone->h) / zone->w));
+   ob = _trans_preview_add(cfdata, 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);
@@ -246,132 +241,89 @@ _trans_cb_changed(void *data)
        break;
      }
    if (!t) return;
-   _trans_preview_trans_set(cfdata->tp, t);
+   _trans_preview_trans_set(cfdata, t);
 }
 
 Evas_Object *
-_trans_preview_add(Evas *evas, int minw, int minh) 
+_trans_preview_add(E_Config_Dialog_Data *cfdata, 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;
+   obj = e_widget_preview_add(evas, minw, minh);
 
-   o = edje_object_add(evas);
-   wd->o_frame = o;
-   e_theme_edje_object_set(o, "base/theme/widgets", "e/widgets/preview");
+   o = edje_object_add(e_widget_preview_evas_get(obj));
+   cfdata->o_prev_bg = o;
+   e_theme_edje_object_set(o, "base/theme/widgets", "e/transpreview/1");
    evas_object_show(o);
-   e_widget_sub_object_add(obj, o);
-   e_widget_resize_object_set(obj, o);
+   e_widget_preview_extern_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) 
+_trans_preview_trans_set(E_Config_Dialog_Data *cfdata, 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 (cfdata->o_trans)
+     evas_object_del(cfdata->o_trans);
+   if (cfdata->o_bg)
+     evas_object_del(cfdata->o_bg);
+   if (cfdata->o_prev_bg)
+     evas_object_del(cfdata->o_prev_bg);
    
-   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);
+   cfdata->o_trans = NULL;
+   cfdata->o_bg = NULL;
+   cfdata->o_prev_bg = NULL;
    
    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);
+   o = edje_object_add(e_widget_preview_evas_get(cfdata->tp));
+   cfdata->o_trans = o;
+   e_theme_edje_object_set(cfdata->o_trans, "base/theme/transitions", buf);
+   edje_object_signal_callback_add(o, "e,state,done", "*", _e_wid_done, cfdata);
    evas_object_show(o);
-   edje_object_part_swallow(wd->o_frame, "e.swallow.content", wd->o_trans);
+   e_widget_preview_extern_object_set(cfdata->tp, o);
 
-   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);
+   o = edje_object_add(e_widget_preview_evas_get(cfdata->tp));
+   cfdata->o_bg = o;
+   e_theme_edje_object_set(o, "base/theme/widgets", "e/transpreview/0");
    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);
+   o = edje_object_add(e_widget_preview_evas_get(cfdata->tp));
+   cfdata->o_prev_bg = o;
+   e_theme_edje_object_set(o, "base/theme/widgets", "e/transpreview/1");
    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_part_swallow(cfdata->o_trans, "e.swallow.bg.old", cfdata->o_prev_bg);
+   edje_object_part_swallow(cfdata->o_trans, "e.swallow.bg.new", cfdata->o_bg);
    
-   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);
+   edje_object_signal_emit(cfdata->o_trans, "e,action,start", "e");
 }
 
 static void 
 _e_wid_done(void *data, Evas_Object *obj, const char *emission, const char *source) 
 {
-   E_Widget_Data *wd;
+   E_Config_Dialog_Data *cfdata;
    Evas_Object *o;
-   Evas *evas;
    
-   wd = data;
-   evas = evas_object_evas_get(wd->o_frame);
+   cfdata = data;
+   
+   if (cfdata->o_trans) 
+     evas_object_del(cfdata->o_trans);
+   if (cfdata->o_bg)
+     evas_object_del(cfdata->o_bg);
+   if (cfdata->o_prev_bg)
+     evas_object_del(cfdata->o_prev_bg);
+
+   cfdata->o_trans = NULL;
+   cfdata->o_bg = NULL;
+   cfdata->o_prev_bg = NULL;
    
-   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);
+   o = edje_object_add(e_widget_preview_evas_get(cfdata->tp));
+   cfdata->o_prev_bg = o;
+   e_theme_edje_object_set(o, "base/theme/widgets", "e/transpreview/1");
    evas_object_show(o);
-   edje_object_part_swallow(wd->o_frame, "e.swallow.content", wd->prev_bg);
+   e_widget_preview_extern_object_set(cfdata->tp, o);
 }
index 5be1fc0..1b8cc67 100644 (file)
@@ -6,7 +6,7 @@
 typedef struct _E_Widget_Data E_Widget_Data;
 struct _E_Widget_Data
 {
-   Evas_Object *obj, *o_frame, *img, *o_thumb;
+   Evas_Object *obj, *o_frame, *img, *o_thumb, *o_extern;
 };
 
 static void _e_wid_del_hook(Evas_Object *obj);
@@ -52,6 +52,25 @@ e_widget_preview_add(Evas *evas, int minw, int minh)
    return obj;
 }
 
+EAPI Evas *
+e_widget_preview_evas_get(Evas_Object *obj)
+{
+   E_Widget_Data *wd;
+   
+   wd = e_widget_data_get(obj);
+   return e_livethumb_evas_get(wd->img);
+}
+
+EAPI void
+e_widget_preview_extern_object_set(Evas_Object *obj, Evas_Object *eobj)
+{
+   E_Widget_Data *wd;
+   
+   wd = e_widget_data_get(obj);
+   wd->o_extern = eobj;
+   e_livethumb_thumb_set(wd->img, wd->o_extern);
+}
+
 EAPI int
 e_widget_preview_file_set(Evas_Object *obj, const char *file, const char *key)
 {
index 1c18e61..7fbf594 100644 (file)
@@ -7,6 +7,8 @@
 #define E_WIDGET_PREVIEW_H
 
 EAPI Evas_Object     *e_widget_preview_add(Evas *evas, int minw, int minh);
+EAPI Evas            *e_widget_preview_evas_get(Evas_Object *obj);
+EAPI void             e_widget_preview_extern_object_set(Evas_Object *obj, Evas_Object *eobj);
 EAPI int              e_widget_preview_file_set(Evas_Object *obj, const char *file, const char *key);
 EAPI int             e_widget_preview_thumb_set(Evas_Object *obj, const char *file, const char *key, int w, int h);
 EAPI int              e_widget_preview_edje_set(Evas_Object *obj, const char *file, const char *group);