fix up transitions dialog... :)

SVN revision: 26710
This commit is contained in:
Carsten Haitzler 2006-10-20 14:31:51 +00:00
parent 04c44dd595
commit 67df17a573
7 changed files with 117 additions and 104 deletions

View File

@ -1,7 +1,45 @@
images { images {
image: "e17_trans1.png" LOSSY 90;
image: "e17_trans2.png" LOSSY 90;
image: "e17_transition_vswipe_gap.png" COMP; 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 { group {
name: "e/transitions/crossfade"; name: "e/transitions/crossfade";
parts { parts {

View File

@ -505,4 +505,6 @@ e17_icon_logout.png \
e17_icon_hibernate.png \ e17_icon_hibernate.png \
e17_icon_suspend.png \ e17_icon_suspend.png \
e17_icon_halt.png \ e17_icon_halt.png \
e17_icon_reboot.png e17_icon_reboot.png \
e17_trans1.png \
e17_trans2.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 58 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 51 KiB

View File

@ -1,16 +1,8 @@
#include "e.h" #include "e.h"
typedef struct _E_Widget_Data E_Widget_Data; static Evas_Object *_trans_preview_add(E_Config_Dialog_Data *cfdata, Evas *evas, int minw, int minh);
struct _E_Widget_Data 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);
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 *_create_data(E_Config_Dialog *cfd);
static void _free_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata); 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 *event_list;
Evas_Object *trans_list; Evas_Object *trans_list;
Evas_Object *tp; Evas_Object *tp;
Evas_Object *o_trans;
Evas_Object *o_prev_bg;
Evas_Object *o_bg;
}; };
EAPI E_Config_Dialog * 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); e_widget_table_object_append(ot, of, 1, 0, 1, 1, 1, 1, 1, 1);
of = e_widget_framelist_add(evas, _("Preview"), 0); 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; cfdata->tp = ob;
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
e_widget_table_object_append(ot, of, 2, 0, 1, 1, 1, 1, 1, 1); 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; break;
} }
if (!t) return; if (!t) return;
_trans_preview_trans_set(cfdata->tp, t); _trans_preview_trans_set(cfdata, t);
} }
Evas_Object * 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; Evas_Object *obj, *o;
E_Widget_Data *wd;
obj = e_widget_add(evas); obj = e_widget_preview_add(evas, minw, minh);
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); o = edje_object_add(e_widget_preview_evas_get(obj));
wd->o_frame = o; cfdata->o_prev_bg = o;
e_theme_edje_object_set(o, "base/theme/widgets", "e/widgets/preview"); e_theme_edje_object_set(o, "base/theme/widgets", "e/transpreview/1");
evas_object_show(o); evas_object_show(o);
e_widget_sub_object_add(obj, o); e_widget_preview_extern_object_set(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; return obj;
} }
static void 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; Evas_Object *o;
E_Widget_Data *wd;
char buf[4096]; char buf[4096];
wd = e_widget_data_get(obj); if (cfdata->o_trans)
evas = evas_object_evas_get(wd->o_frame); 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) cfdata->o_trans = NULL;
evas_object_del(wd->o_trans); cfdata->o_bg = NULL;
if (wd->bg) cfdata->o_prev_bg = NULL;
evas_object_del(wd->bg);
if (wd->prev_bg)
evas_object_del(wd->prev_bg);
snprintf(buf, sizeof(buf), "e/transitions/%s", trans); snprintf(buf, sizeof(buf), "e/transitions/%s", trans);
o = edje_object_add(evas); o = edje_object_add(e_widget_preview_evas_get(cfdata->tp));
wd->o_trans = o; cfdata->o_trans = o;
e_theme_edje_object_set(wd->o_trans, "base/theme/transitions", buf); e_theme_edje_object_set(cfdata->o_trans, "base/theme/transitions", buf);
edje_object_signal_callback_add(o, "e,state,done", "*", _e_wid_done, wd); edje_object_signal_callback_add(o, "e,state,done", "*", _e_wid_done, cfdata);
evas_object_layer_set(o, -1);
evas_object_clip_set(o, wd->o_frame);
evas_object_show(o); 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); o = edje_object_add(e_widget_preview_evas_get(cfdata->tp));
wd->bg = o; cfdata->o_bg = o;
e_theme_edje_object_set(o, "base/theme/icons", "e/icons/enlightenment/e"); e_theme_edje_object_set(o, "base/theme/widgets", "e/transpreview/0");
evas_object_layer_set(o, -1);
evas_object_clip_set(o, wd->o_frame);
evas_object_show(o); evas_object_show(o);
o = edje_object_add(evas); o = edje_object_add(e_widget_preview_evas_get(cfdata->tp));
wd->prev_bg = o; cfdata->o_prev_bg = o;
e_theme_edje_object_set(o, "base/theme/backgrounds", "e/desktop/background"); e_theme_edje_object_set(o, "base/theme/widgets", "e/transpreview/1");
evas_object_layer_set(o, -1);
evas_object_clip_set(o, wd->o_frame);
evas_object_show(o); evas_object_show(o);
edje_object_part_swallow(wd->o_trans, "e.swallow.bg.old", wd->prev_bg); edje_object_part_swallow(cfdata->o_trans, "e.swallow.bg.old", cfdata->o_prev_bg);
edje_object_part_swallow(wd->o_trans, "e.swallow.bg.new", wd->bg); edje_object_part_swallow(cfdata->o_trans, "e.swallow.bg.new", cfdata->o_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"); edje_object_signal_emit(cfdata->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 static void
_e_wid_done(void *data, Evas_Object *obj, const char *emission, const char *source) _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_Object *o;
Evas *evas;
wd = data; cfdata = data;
evas = evas_object_evas_get(wd->o_frame);
if (wd->o_trans) if (cfdata->o_trans)
evas_object_del(wd->o_trans); evas_object_del(cfdata->o_trans);
if (wd->bg) if (cfdata->o_bg)
evas_object_del(wd->bg); evas_object_del(cfdata->o_bg);
if (wd->prev_bg) if (cfdata->o_prev_bg)
evas_object_del(wd->prev_bg); evas_object_del(cfdata->o_prev_bg);
o = edje_object_add(evas); cfdata->o_trans = NULL;
wd->prev_bg = o; cfdata->o_bg = NULL;
e_theme_edje_object_set(o, "base/theme/backgrounds", "e/desktop/background"); cfdata->o_prev_bg = NULL;
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); 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);
} }

View File

@ -6,7 +6,7 @@
typedef struct _E_Widget_Data E_Widget_Data; typedef struct _E_Widget_Data E_Widget_Data;
struct _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); 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; 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 EAPI int
e_widget_preview_file_set(Evas_Object *obj, const char *file, const char *key) e_widget_preview_file_set(Evas_Object *obj, const char *file, const char *key)
{ {

View File

@ -7,6 +7,8 @@
#define E_WIDGET_PREVIEW_H #define E_WIDGET_PREVIEW_H
EAPI Evas_Object *e_widget_preview_add(Evas *evas, int minw, int minh); 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_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_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); EAPI int e_widget_preview_edje_set(Evas_Object *obj, const char *file, const char *group);