e-modules/comp-scale: add gadgets for scale and pager action
SVN revision: 63011
This commit is contained in:
parent
081dd31c3d
commit
954e0a4f1d
|
@ -1,6 +1,7 @@
|
|||
images
|
||||
{
|
||||
image: "module_icon.png" COMP;
|
||||
image: "scale.png" COMP;
|
||||
image: "pager.png" COMP;
|
||||
image: "sh.png" COMP;
|
||||
image: "label.png" COMP;
|
||||
}
|
||||
|
@ -19,7 +20,7 @@ collections
|
|||
state: "default" 0.0;
|
||||
aspect: 1.0 1.0;
|
||||
aspect_preference: BOTH;
|
||||
image.normal: "module_icon.png";
|
||||
image.normal: "scale.png";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -38,7 +39,7 @@ collections
|
|||
aspect_preference: BOTH;
|
||||
rel1.offset: 2 2;
|
||||
rel2.offset: -3 -3;
|
||||
image.normal: "module_icon.png";
|
||||
image.normal: "scale.png";
|
||||
}
|
||||
description {
|
||||
state: "bigger" 0.0;
|
||||
|
@ -58,6 +59,7 @@ collections
|
|||
}
|
||||
}
|
||||
programs {
|
||||
#if 0
|
||||
program {
|
||||
name: "mouse_in";
|
||||
signal: "mouse,in";
|
||||
|
@ -74,6 +76,61 @@ collections
|
|||
transition: LINEAR 0.2;
|
||||
target: "icon";
|
||||
}
|
||||
#endif
|
||||
}
|
||||
}
|
||||
group {
|
||||
name: "modules/pager/main";
|
||||
max: 128 128;
|
||||
parts {
|
||||
part {
|
||||
name: "icon";
|
||||
mouse_events: 0;
|
||||
type: IMAGE;
|
||||
description {
|
||||
state: "default" 0.0;
|
||||
aspect: 1.0 1.0;
|
||||
aspect_preference: BOTH;
|
||||
rel1.offset: 2 2;
|
||||
rel2.offset: -3 -3;
|
||||
image.normal: "pager.png";
|
||||
}
|
||||
description {
|
||||
state: "bigger" 0.0;
|
||||
inherit: "default" 0.0;
|
||||
rel1.offset: -2 -2;
|
||||
rel2.offset: 3 3;
|
||||
}
|
||||
}
|
||||
part {
|
||||
name: "event";
|
||||
mouse_events: 1;
|
||||
type: RECT;
|
||||
description {
|
||||
state: "default" 0.0;
|
||||
color: 255 255 255 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
programs {
|
||||
#if 0
|
||||
program {
|
||||
name: "mouse_in";
|
||||
signal: "mouse,in";
|
||||
source: "event";
|
||||
action: STATE_SET "bigger" 0.0;
|
||||
transition: LINEAR 0.1;
|
||||
target: "icon";
|
||||
}
|
||||
program {
|
||||
name: "mouse_out";
|
||||
signal: "mouse,out";
|
||||
source: "event";
|
||||
action: STATE_SET "default" 0.0;
|
||||
transition: LINEAR 0.2;
|
||||
target: "icon";
|
||||
}
|
||||
#endif
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -408,7 +465,7 @@ collections
|
|||
type: RECT;
|
||||
description {
|
||||
state: "default" 0.0;
|
||||
visible: 0;
|
||||
visible: 0;
|
||||
color: 255 255 255 180;
|
||||
rel1 {
|
||||
relative: 0.0 0.0;
|
||||
|
|
Binary file not shown.
After Width: | Height: | Size: 987 B |
Binary file not shown.
After Width: | Height: | Size: 959 B |
218
src/e_mod_main.c
218
src/e_mod_main.c
|
@ -7,17 +7,23 @@
|
|||
// while scale is active?
|
||||
//
|
||||
|
||||
static E_Gadcon_Client *_gc_init(E_Gadcon *gc, const char *name, const char *id, const char *style);
|
||||
static E_Gadcon_Client *_gc_init_scale(E_Gadcon *gc, const char *name, const char *id, const char *style);
|
||||
static E_Gadcon_Client *_gc_init_scale_all(E_Gadcon *gc, const char *name, const char *id, const char *style);
|
||||
static E_Gadcon_Client *_gc_init_pager(E_Gadcon *gc, const char *name, const char *id, const char *style);
|
||||
static char *_gc_label_scale(E_Gadcon_Client_Class *client_class);
|
||||
static char *_gc_label_scale_all(E_Gadcon_Client_Class *client_class);
|
||||
static char *_gc_label_pager(E_Gadcon_Client_Class *client_class);
|
||||
static void _gc_shutdown(E_Gadcon_Client *gcc);
|
||||
static void _gc_orient(E_Gadcon_Client *gcc, E_Gadcon_Orient orient);
|
||||
static char *_gc_label(E_Gadcon_Client_Class *client_class);
|
||||
static const char *_gc_id_new(E_Gadcon_Client_Class *client_class);
|
||||
static Evas_Object *_gc_icon(E_Gadcon_Client_Class *client_class, Evas *evas);
|
||||
|
||||
static void _scale_conf_new(void);
|
||||
static void _scale_conf_free(void);
|
||||
static Config_Item *_scale_conf_item_get(const char *id);
|
||||
static void _scale_gc_cb_mouse_down(void *data, Evas *evas, Evas_Object *obj, void *event);
|
||||
static void _scale_gc_cb_mouse_down_scale(void *data, Evas *evas, Evas_Object *obj, void *event);
|
||||
static void _scale_gc_cb_mouse_down_scale_all(void *data, Evas *evas, Evas_Object *obj, void *event);
|
||||
static void _scale_gc_cb_mouse_down_pager(void *data, Evas *evas, Evas_Object *obj, void *event);
|
||||
static void _scale_gc_cb_menu_post(void *data, E_Menu *menu);
|
||||
static void _scale_gc_cb_menu_configure(void *data, E_Menu *mn, E_Menu_Item *mi);
|
||||
|
||||
|
@ -184,10 +190,26 @@ static E_Config_DD *conf_edd = NULL;
|
|||
static E_Config_DD *conf_item_edd = NULL;
|
||||
Config *scale_conf = NULL;
|
||||
|
||||
static const E_Gadcon_Client_Class _gc_class =
|
||||
static const E_Gadcon_Client_Class _gc_class_scale =
|
||||
{
|
||||
GADCON_CLIENT_CLASS_VERSION, "scale",
|
||||
{_gc_init, _gc_shutdown, _gc_orient, _gc_label, _gc_icon,
|
||||
{_gc_init_scale, _gc_shutdown, _gc_orient, _gc_label_scale, _gc_icon,
|
||||
_gc_id_new, NULL, NULL},
|
||||
E_GADCON_CLIENT_STYLE_PLAIN
|
||||
};
|
||||
|
||||
static const E_Gadcon_Client_Class _gc_class_scale_all =
|
||||
{
|
||||
GADCON_CLIENT_CLASS_VERSION, "scale-all",
|
||||
{_gc_init_scale_all, _gc_shutdown, _gc_orient, _gc_label_scale_all, _gc_icon,
|
||||
_gc_id_new, NULL, NULL},
|
||||
E_GADCON_CLIENT_STYLE_PLAIN
|
||||
};
|
||||
|
||||
static const E_Gadcon_Client_Class _gc_class_pager =
|
||||
{
|
||||
GADCON_CLIENT_CLASS_VERSION, "scale-pager",
|
||||
{_gc_init_pager, _gc_shutdown, _gc_orient, _gc_label_pager, _gc_icon,
|
||||
_gc_id_new, NULL, NULL},
|
||||
E_GADCON_CLIENT_STYLE_PLAIN
|
||||
};
|
||||
|
@ -268,7 +290,9 @@ e_modapi_init(E_Module *m)
|
|||
scale_conf->module->dir);
|
||||
scale_conf->theme_path = eina_stringshare_add(buf);
|
||||
|
||||
e_gadcon_provider_register(&_gc_class);
|
||||
e_gadcon_provider_register(&_gc_class_scale);
|
||||
e_gadcon_provider_register(&_gc_class_scale_all);
|
||||
e_gadcon_provider_register(&_gc_class_pager);
|
||||
|
||||
act = e_action_add("scale-windows");
|
||||
if (act)
|
||||
|
@ -323,7 +347,10 @@ e_modapi_shutdown(E_Module *m)
|
|||
scale_conf->cfd = NULL;
|
||||
|
||||
scale_conf->module = NULL;
|
||||
e_gadcon_provider_unregister(&_gc_class);
|
||||
|
||||
e_gadcon_provider_unregister(&_gc_class_scale);
|
||||
e_gadcon_provider_unregister(&_gc_class_scale_all);
|
||||
e_gadcon_provider_unregister(&_gc_class_pager);
|
||||
|
||||
while (scale_conf->conf_items)
|
||||
{
|
||||
|
@ -372,7 +399,7 @@ e_modapi_save(E_Module *m)
|
|||
return 1;
|
||||
}
|
||||
|
||||
static E_Gadcon_Client *
|
||||
static Instance *
|
||||
_gc_init(E_Gadcon *gc, const char *name, const char *id, const char *style)
|
||||
{
|
||||
Instance *inst = NULL;
|
||||
|
@ -382,17 +409,62 @@ _gc_init(E_Gadcon *gc, const char *name, const char *id, const char *style)
|
|||
|
||||
inst->o_scale = edje_object_add(gc->evas);
|
||||
|
||||
inst->gcc = e_gadcon_client_new(gc, name, id, style, inst->o_scale);
|
||||
inst->gcc->data = inst;
|
||||
|
||||
|
||||
instances = eina_list_append(instances, inst);
|
||||
|
||||
return inst;
|
||||
}
|
||||
|
||||
static E_Gadcon_Client *
|
||||
_gc_init_pager(E_Gadcon *gc, const char *name, const char *id, const char *style)
|
||||
{
|
||||
Instance *inst;
|
||||
|
||||
inst = _gc_init(gc, name, id, style);
|
||||
|
||||
if (!e_theme_edje_object_set(inst->o_scale, "base/theme/modules/scale",
|
||||
"modules/pager/main"))
|
||||
edje_object_file_set(inst->o_scale, scale_conf->theme_path, "modules/pager/main");
|
||||
|
||||
evas_object_event_callback_add(inst->o_scale, EVAS_CALLBACK_MOUSE_DOWN,
|
||||
_scale_gc_cb_mouse_down_pager, inst);
|
||||
|
||||
return inst->gcc;
|
||||
}
|
||||
|
||||
static E_Gadcon_Client *
|
||||
_gc_init_scale(E_Gadcon *gc, const char *name, const char *id, const char *style)
|
||||
{
|
||||
Instance *inst;
|
||||
|
||||
inst = _gc_init(gc, name, id, style);
|
||||
|
||||
if (!e_theme_edje_object_set(inst->o_scale, "base/theme/modules/scale",
|
||||
"modules/scale/main"))
|
||||
edje_object_file_set(inst->o_scale, scale_conf->theme_path, "modules/scale/main");
|
||||
|
||||
inst->gcc = e_gadcon_client_new(gc, name, id, style, inst->o_scale);
|
||||
inst->gcc->data = inst;
|
||||
evas_object_event_callback_add(inst->o_scale, EVAS_CALLBACK_MOUSE_DOWN,
|
||||
_scale_gc_cb_mouse_down_scale, inst);
|
||||
|
||||
return inst->gcc;
|
||||
}
|
||||
|
||||
static E_Gadcon_Client *
|
||||
_gc_init_scale_all(E_Gadcon *gc, const char *name, const char *id, const char *style)
|
||||
{
|
||||
Instance *inst;
|
||||
|
||||
inst = _gc_init(gc, name, id, style);
|
||||
|
||||
if (!e_theme_edje_object_set(inst->o_scale, "base/theme/modules/scale",
|
||||
"modules/scale/main"))
|
||||
edje_object_file_set(inst->o_scale, scale_conf->theme_path, "modules/scale/main");
|
||||
|
||||
evas_object_event_callback_add(inst->o_scale, EVAS_CALLBACK_MOUSE_DOWN,
|
||||
_scale_gc_cb_mouse_down, inst);
|
||||
|
||||
instances = eina_list_append(instances, inst);
|
||||
_scale_gc_cb_mouse_down_scale_all, inst);
|
||||
|
||||
return inst->gcc;
|
||||
}
|
||||
|
@ -413,8 +485,8 @@ _gc_shutdown(E_Gadcon_Client *gcc)
|
|||
}
|
||||
if (inst->o_scale)
|
||||
{
|
||||
evas_object_event_callback_del(inst->o_scale, EVAS_CALLBACK_MOUSE_DOWN,
|
||||
_scale_gc_cb_mouse_down);
|
||||
/* evas_object_event_callback_del(inst->o_scale, EVAS_CALLBACK_MOUSE_DOWN,
|
||||
* _scale_gc_cb_mouse_down); */
|
||||
evas_object_del(inst->o_scale);
|
||||
}
|
||||
E_FREE(inst);
|
||||
|
@ -428,9 +500,21 @@ _gc_orient(E_Gadcon_Client *gcc, E_Gadcon_Orient orient)
|
|||
}
|
||||
|
||||
static char *
|
||||
_gc_label(E_Gadcon_Client_Class *client_class)
|
||||
_gc_label_scale(E_Gadcon_Client_Class *client_class)
|
||||
{
|
||||
return D_("Scale");
|
||||
return D_("Scale Windows");
|
||||
}
|
||||
|
||||
static char *
|
||||
_gc_label_scale_all(E_Gadcon_Client_Class *client_class)
|
||||
{
|
||||
return D_("Scale all Windows");
|
||||
}
|
||||
|
||||
static char *
|
||||
_gc_label_pager(E_Gadcon_Client_Class *client_class)
|
||||
{
|
||||
return D_("Scale Pager");
|
||||
}
|
||||
|
||||
static const char *
|
||||
|
@ -514,7 +598,7 @@ _scale_conf_item_get(const char *id)
|
|||
|
||||
if (!id)
|
||||
{
|
||||
snprintf(buf, sizeof(buf), "%s.%d", _gc_class.name, ++uuid);
|
||||
snprintf(buf, sizeof(buf), "%s.%d", _gc_class_scale.name, ++uuid);
|
||||
id = buf;
|
||||
}
|
||||
else
|
||||
|
@ -534,49 +618,83 @@ _scale_conf_item_get(const char *id)
|
|||
}
|
||||
|
||||
static void
|
||||
_scale_gc_cb_mouse_down(void *data, Evas *evas, Evas_Object *obj, void *event)
|
||||
_scale_gc_menu(Instance *inst, Evas_Event_Mouse_Down *ev)
|
||||
{
|
||||
E_Menu *m;
|
||||
E_Menu_Item *mi;
|
||||
E_Zone *zone = NULL;
|
||||
int x, y;
|
||||
|
||||
m = e_menu_new();
|
||||
mi = e_menu_item_new(m);
|
||||
e_menu_item_label_set(mi, D_("Settings"));
|
||||
e_util_menu_item_theme_icon_set(mi, "preferences-system");
|
||||
e_menu_item_callback_set(mi, _scale_gc_cb_menu_configure, NULL);
|
||||
|
||||
m = e_gadcon_client_util_menu_items_append(inst->gcc, m, 0);
|
||||
inst->menu = m;
|
||||
|
||||
e_menu_post_deactivate_callback_set(m, _scale_gc_cb_menu_post, inst);
|
||||
|
||||
e_gadcon_canvas_zone_geometry_get(inst->gcc->gadcon, &x, &y,
|
||||
NULL, NULL);
|
||||
|
||||
zone = e_util_zone_current_get(e_manager_current_get());
|
||||
|
||||
e_menu_activate_mouse(m, zone, (x + ev->output.x),
|
||||
(y + ev->output.y), 1, 1,
|
||||
E_MENU_POP_DIRECTION_AUTO, ev->timestamp);
|
||||
evas_event_feed_mouse_up(inst->gcc->gadcon->evas, ev->button,
|
||||
EVAS_BUTTON_NONE, ev->timestamp, NULL);
|
||||
|
||||
}
|
||||
|
||||
static void
|
||||
_scale_gc_cb_mouse_down_scale(void *data, Evas *evas, Evas_Object *obj, void *event)
|
||||
{
|
||||
Instance *inst = NULL;
|
||||
Evas_Event_Mouse_Down *ev;
|
||||
E_Zone *zone = NULL;
|
||||
E_Menu_Item *mi = NULL;
|
||||
int x, y;
|
||||
|
||||
if (!(inst = data)) return;
|
||||
ev = event;
|
||||
|
||||
if (ev->button == 1)
|
||||
{
|
||||
_e_mod_action_cb(NULL, "go_scale_class:*");
|
||||
}
|
||||
_e_mod_action_cb(NULL, "go_scale");
|
||||
else if ((ev->button == 3) && (!inst->menu))
|
||||
{
|
||||
E_Menu *m;
|
||||
|
||||
m = e_menu_new();
|
||||
mi = e_menu_item_new(m);
|
||||
e_menu_item_label_set(mi, D_("Settings"));
|
||||
e_util_menu_item_theme_icon_set(mi, "preferences-system");
|
||||
e_menu_item_callback_set(mi, _scale_gc_cb_menu_configure, NULL);
|
||||
|
||||
m = e_gadcon_client_util_menu_items_append(inst->gcc, m, 0);
|
||||
inst->menu = m;
|
||||
|
||||
e_menu_post_deactivate_callback_set(m, _scale_gc_cb_menu_post, inst);
|
||||
|
||||
e_gadcon_canvas_zone_geometry_get(inst->gcc->gadcon, &x, &y,
|
||||
NULL, NULL);
|
||||
|
||||
zone = e_util_zone_current_get(e_manager_current_get());
|
||||
|
||||
e_menu_activate_mouse(m, zone, (x + ev->output.x),
|
||||
(y + ev->output.y), 1, 1,
|
||||
E_MENU_POP_DIRECTION_AUTO, ev->timestamp);
|
||||
evas_event_feed_mouse_up(inst->gcc->gadcon->evas, ev->button,
|
||||
EVAS_BUTTON_NONE, ev->timestamp, NULL);
|
||||
}
|
||||
_scale_gc_menu(inst, ev);
|
||||
}
|
||||
|
||||
static void
|
||||
_scale_gc_cb_mouse_down_scale_all(void *data, Evas *evas, Evas_Object *obj, void *event)
|
||||
{
|
||||
Instance *inst = NULL;
|
||||
Evas_Event_Mouse_Down *ev;
|
||||
|
||||
if (!(inst = data)) return;
|
||||
ev = event;
|
||||
|
||||
if (ev->button == 1)
|
||||
_e_mod_action_cb(NULL, "go_scale_class:*");
|
||||
else if ((ev->button == 3) && (!inst->menu))
|
||||
_scale_gc_menu(inst, ev);
|
||||
}
|
||||
|
||||
static void
|
||||
_scale_gc_cb_mouse_down_pager(void *data, Evas *evas, Evas_Object *obj, void *event)
|
||||
{
|
||||
Instance *inst = NULL;
|
||||
Evas_Event_Mouse_Down *ev;
|
||||
|
||||
if (!(inst = data)) return;
|
||||
ev = event;
|
||||
|
||||
if (ev->button == 1)
|
||||
_e_mod_action_cb(NULL, "go_pager");
|
||||
else if ((ev->button == 3) && (!inst->menu))
|
||||
_scale_gc_menu(inst, ev);
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
_scale_gc_cb_menu_post(void *data, E_Menu *menu)
|
||||
{
|
||||
|
|
Loading…
Reference in New Issue