Allow gadgets to either be 1 per container (default) or 1 per zone (like the pager).

SVN revision: 19120
This commit is contained in:
rephorm 2005-12-18 21:06:37 +00:00 committed by rephorm
parent 59f99929e3
commit c597c6585c
3 changed files with 90 additions and 59 deletions

View File

@ -3,6 +3,7 @@
*/ */
#include "e.h" #include "e.h"
E_Gadget_Face *_e_gadget_face_new(E_Gadget *gad, E_Container *con, E_Zone *zone);
static void _e_gadget_menu_init(E_Gadget *gad); static void _e_gadget_menu_init(E_Gadget *gad);
static void _e_gadget_cb_menu_edit(void *data, E_Menu *m, E_Menu_Item *mi); static void _e_gadget_cb_menu_edit(void *data, E_Menu *m, E_Menu_Item *mi);
static void _e_gadget_free(E_Gadget *gad); static void _e_gadget_free(E_Gadget *gad);
@ -39,9 +40,7 @@ E_Gadget *
e_gadget_new(E_Gadget_Api *api) e_gadget_new(E_Gadget_Api *api)
{ {
E_Gadget *gad; E_Gadget *gad;
Evas_List *managers, *l = NULL, *l2 = NULL; Evas_List *managers, *l = NULL, *l2 = NULL, *l3 = NULL;
char buf[1024];
int gadget_count = 0;
if (!api || !api->module || !api->name) return NULL; if (!api || !api->module || !api->name) return NULL;
@ -72,66 +71,23 @@ e_gadget_new(E_Gadget_Api *api)
for(l2 = man->containers; l2; l2 = l2->next) for(l2 = man->containers; l2; l2 = l2->next)
{ {
E_Container *con; E_Container *con;
E_Gadget_Face *face;
E_Gadget_Change *change;
Evas_Object *o;
con = l2->data; con = l2->data;
face = E_NEW(E_Gadget_Face, 1);
if (!face) continue;
face->gad = gad;
face->con = con;
e_object_ref(E_OBJECT(con));
face->evas = con->bg_evas;
evas_event_freeze(face->evas);
/* create an event object */
o = evas_object_rectangle_add(con->bg_evas);
face->event_obj = o;
evas_object_layer_set(o, 2);
evas_object_repeat_events_set(o, 1);
evas_object_color_set(o, 0, 0, 0, 0);
evas_object_event_callback_add(o, EVAS_CALLBACK_MOUSE_DOWN, _e_gadget_cb_mouse_down, face);
evas_object_show(o);
/* create a gadman client */ if (api->per_zone)
snprintf(buf, sizeof(buf), "module.%s", gad->name);
face->gmc = e_gadman_client_new(con->gadman);
e_gadman_client_domain_set(face->gmc, buf, gadget_count++);
/* call the user init */
if (gad->funcs.face_init) (gad->funcs.face_init)(gad->data, face);
_e_gadget_face_menu_init(face);
change = E_NEW(E_Gadget_Change, 1);
if (change)
{ {
printf("set change func\n"); for(l3 = con->zones; l3; l3 = l3->next)
change->gadget = gad; {
change->face = face; E_Zone *zone;
zone = l3->data;
_e_gadget_face_new(gad, con, zone);
}
}
else
{
_e_gadget_face_new(gad, con, NULL);
} }
/* set up some gadman defaults */
e_gadman_client_policy_set(face->gmc,
E_GADMAN_POLICY_ANYWHERE |
E_GADMAN_POLICY_HMOVE |
E_GADMAN_POLICY_VMOVE |
E_GADMAN_POLICY_HSIZE |
E_GADMAN_POLICY_VSIZE );
e_gadman_client_min_size_set(face->gmc, 4, 4);
e_gadman_client_max_size_set(face->gmc, 128, 128);
e_gadman_client_auto_size_set(face->gmc, 40, 40);
e_gadman_client_align_set(face->gmc, 1.0, 1.0);
e_gadman_client_resize(face->gmc, 40, 40);
e_gadman_client_change_func_set(face->gmc, _e_gadget_face_cb_gmc_change, change);
e_gadman_client_load(face->gmc);
evas_event_thaw(face->evas);
gad->faces = evas_list_append(gad->faces, face);
} }
} }
_e_gadget_menu_init(gad); _e_gadget_menu_init(gad);
@ -139,6 +95,76 @@ e_gadget_new(E_Gadget_Api *api)
return gad; return gad;
} }
E_Gadget_Face *
_e_gadget_face_new(E_Gadget *gad, E_Container *con, E_Zone *zone)
{
E_Gadget_Face *face;
E_Gadget_Change *change;
Evas_Object *o;
char buf[1024];
face = E_NEW(E_Gadget_Face, 1);
if (!face) return NULL;
face->gad = gad;
face->con = con;
if (zone) face->zone = zone;
else face->zone = (E_Zone *)evas_list_data(con->zones);
e_object_ref(E_OBJECT(con));
face->evas = con->bg_evas;
evas_event_freeze(face->evas);
/* create an event object */
o = evas_object_rectangle_add(con->bg_evas);
face->event_obj = o;
evas_object_layer_set(o, 2);
evas_object_repeat_events_set(o, 1);
evas_object_color_set(o, 0, 0, 0, 0);
evas_object_event_callback_add(o, EVAS_CALLBACK_MOUSE_DOWN, _e_gadget_cb_mouse_down, face);
evas_object_show(o);
/* create a gadman client */
snprintf(buf, sizeof(buf), "module.%s", gad->name);
face->gmc = e_gadman_client_new(con->gadman);
e_gadman_client_zone_set(face->gmc, face->zone);
e_gadman_client_domain_set(face->gmc, buf, evas_list_count(gad->faces));
/* call the user init */
if (gad->funcs.face_init) (gad->funcs.face_init)(gad->data, face);
_e_gadget_face_menu_init(face);
change = E_NEW(E_Gadget_Change, 1);
if (change)
{
printf("set change func\n");
change->gadget = gad;
change->face = face;
}
/* set up some gadman defaults */
e_gadman_client_policy_set(face->gmc,
E_GADMAN_POLICY_ANYWHERE |
E_GADMAN_POLICY_HMOVE |
E_GADMAN_POLICY_VMOVE |
E_GADMAN_POLICY_HSIZE |
E_GADMAN_POLICY_VSIZE );
e_gadman_client_min_size_set(face->gmc, 4, 4);
e_gadman_client_max_size_set(face->gmc, 128, 128);
e_gadman_client_auto_size_set(face->gmc, 40, 40);
e_gadman_client_align_set(face->gmc, 1.0, 1.0);
e_gadman_client_resize(face->gmc, 40, 40);
e_gadman_client_change_func_set(face->gmc, _e_gadget_face_cb_gmc_change, change);
e_gadman_client_load(face->gmc);
evas_event_thaw(face->evas);
gad->faces = evas_list_append(gad->faces, face);
return face;
}
void void
e_gadget_face_theme_set(E_Gadget_Face *face, char *category, char *group) e_gadget_face_theme_set(E_Gadget_Face *face, char *category, char *group)
{ {

View File

@ -15,6 +15,7 @@ struct _E_Gadget_Api
{ {
E_Module *module; E_Module *module;
const char *name; const char *name;
int per_zone; /* 1 - one face per zone, 0 - one per container */
void (*func_face_init) (void *data, E_Gadget_Face *gadget_face); void (*func_face_init) (void *data, E_Gadget_Face *gadget_face);
void (*func_face_free) (void *data, E_Gadget_Face *gadget_face); void (*func_face_free) (void *data, E_Gadget_Face *gadget_face);
void (*func_change) (void *data, E_Gadget_Face *gadget_face, E_Gadman_Client *gmc, E_Gadman_Change change); void (*func_change) (void *data, E_Gadget_Face *gadget_face, E_Gadman_Client *gmc, E_Gadman_Change change);
@ -29,7 +30,7 @@ struct _E_Gadget
Evas_List *faces; Evas_List *faces;
E_Module *module; E_Module *module;
char *name; const char *name;
E_Menu *menu; E_Menu *menu;
struct { struct {
@ -47,6 +48,7 @@ struct _E_Gadget_Face
{ {
E_Gadget *gad; E_Gadget *gad;
E_Container *con; E_Container *con;
E_Zone *zone;
Evas *evas; Evas *evas;
E_Menu *menu; E_Menu *menu;

View File

@ -35,6 +35,7 @@ e_modapi_init(E_Module *m)
api->module = m; api->module = m;
api->name = "test_gadget"; api->name = "test_gadget";
api->per_zone = 1;
api->func_face_init = _test_face_init; api->func_face_init = _test_face_init;
api->func_face_free = _test_face_free; api->func_face_free = _test_face_free;
api->func_change = _test_face_change; api->func_change = _test_face_change;
@ -88,9 +89,11 @@ _test_face_init(void *data, E_Gadget_Face *face)
static void static void
_test_face_free(void *data, E_Gadget_Face *face) _test_face_free(void *data, E_Gadget_Face *face)
{ {
/* really, this should be done in a gadget_free callback, but that doesn't exist yet... */
Test *t; Test *t;
t = data; t = data;
if (t) free(t); if (t) free(t);
face->gad->data = NULL;
} }
static void static void