forked from enlightenment/enlightenment
ading "livethumb" - it uses the ecore evas buffer engine stuff to make a
canvas withni a canvas as a smart obj where ucan set 1 object as the base. going to be handy for some stuff... SVN revision: 18334
This commit is contained in:
parent
1232fd0109
commit
99dafd01e7
|
@ -62,7 +62,7 @@ group {
|
|||
state: "default" 0.0;
|
||||
color: 0 0 0 0;
|
||||
rel1 {
|
||||
offset: 3 3;
|
||||
offset: 4 4;
|
||||
}
|
||||
rel2 {
|
||||
relative: 0.0 0.0;
|
||||
|
|
|
@ -109,7 +109,8 @@ e_scrollframe.h \
|
|||
e_file_selector.h \
|
||||
e_file_dialog.h \
|
||||
e_int_border_menu.h \
|
||||
e_ilist.h
|
||||
e_ilist.h \
|
||||
e_livethumb.h
|
||||
|
||||
enlightenment_src = \
|
||||
e_user.c \
|
||||
|
@ -200,6 +201,7 @@ e_file_selector.c \
|
|||
e_file_dialog.c \
|
||||
e_int_border_menu.c \
|
||||
e_ilist.c \
|
||||
e_livethumb.c \
|
||||
$(ENLIGHTENMENTHEADERS)
|
||||
|
||||
enlightenment_SOURCES = \
|
||||
|
|
|
@ -295,6 +295,16 @@ static void
|
|||
_e_smart_del(Evas_Object *obj)
|
||||
{
|
||||
INTERNAL_ENTRY;
|
||||
while (sd->items)
|
||||
{
|
||||
E_Smart_Item *si;
|
||||
|
||||
si = sd->items->data;
|
||||
sd->items = evas_list_remove_list(sd->items, sd->items);
|
||||
if (si->icon_obj) evas_object_del(si->icon_obj);
|
||||
evas_object_del(si->base_obj);
|
||||
free(si);
|
||||
}
|
||||
evas_object_del(sd->box_obj);
|
||||
free(sd);
|
||||
}
|
||||
|
|
|
@ -7,6 +7,7 @@
|
|||
#define E_ILIST_H
|
||||
|
||||
EAPI Evas_Object *e_ilist_add (Evas *evas);
|
||||
EAPI void e_ilist_icon_size_set (Evas_Object *obj, Evas_Coord w, Evas_Coord h);
|
||||
EAPI void e_ilist_append (Evas_Object *obj, Evas_Object *icon, char *label, void (*func) (void *data, void *data2), void *data, void *data2);
|
||||
EAPI void e_ilist_select_set (Evas_Object *obj, int n);
|
||||
EAPI int e_ilist_select_get (Evas_Object *obj);
|
||||
|
|
|
@ -90,3 +90,4 @@
|
|||
#include "e_widget_fileman.h"
|
||||
#include "e_int_border_menu.h"
|
||||
#include "e_ilist.h"
|
||||
#include "e_livethumb.h"
|
||||
|
|
|
@ -0,0 +1,218 @@
|
|||
/*
|
||||
* vim:ts=8:sw=3:sts=8:noexpandtab:cino=>5n-3f0^-2{2
|
||||
*/
|
||||
#include "e.h"
|
||||
|
||||
#define SMART_NAME "e_livethumb"
|
||||
#define API_ENTRY E_Smart_Data *sd; sd = evas_object_smart_data_get(obj); if ((!obj) || (!sd) || (evas_object_type_get(obj) && strcmp(evas_object_type_get(obj), SMART_NAME)))
|
||||
#define INTERNAL_ENTRY E_Smart_Data *sd; sd = evas_object_smart_data_get(obj); if (!sd) return;
|
||||
typedef struct _E_Smart_Data E_Smart_Data;
|
||||
typedef struct _E_Smart_Item E_Smart_Item;
|
||||
|
||||
struct _E_Smart_Data
|
||||
{
|
||||
Evas_Coord x, y, w, h;
|
||||
|
||||
Evas_Object *smart_obj;
|
||||
Evas_Object *evas_obj;
|
||||
Evas_Object *thumb_obj;
|
||||
Evas *evas;
|
||||
Evas_Coord vw, vh;
|
||||
};
|
||||
|
||||
/* local subsystem functions */
|
||||
static void _e_smart_reconfigure(E_Smart_Data *sd);
|
||||
static void _e_smart_add(Evas_Object *obj);
|
||||
static void _e_smart_del(Evas_Object *obj);
|
||||
static void _e_smart_move(Evas_Object *obj, Evas_Coord x, Evas_Coord y);
|
||||
static void _e_smart_resize(Evas_Object *obj, Evas_Coord w, Evas_Coord h);
|
||||
static void _e_smart_show(Evas_Object *obj);
|
||||
static void _e_smart_hide(Evas_Object *obj);
|
||||
static void _e_smart_color_set(Evas_Object *obj, int r, int g, int b, int a);
|
||||
static void _e_smart_clip_set(Evas_Object *obj, Evas_Object * clip);
|
||||
static void _e_smart_clip_unset(Evas_Object *obj);
|
||||
static void _e_smart_init(void);
|
||||
|
||||
/* local subsystem globals */
|
||||
static Evas_Smart *_e_smart = NULL;
|
||||
|
||||
/* externally accessible functions */
|
||||
Evas_Object *
|
||||
e_livethumb_add(Ecore_Evas *ee)
|
||||
{
|
||||
Evas_Object *obj;
|
||||
E_Smart_Data *sd;
|
||||
|
||||
|
||||
_e_smart_init();
|
||||
obj = evas_object_smart_add(ecore_evas_get(ee), _e_smart);
|
||||
sd = evas_object_smart_data_get(obj);
|
||||
sd->evas_obj = ecore_evas_object_image_new(ee);
|
||||
evas_object_smart_member_add(sd->evas_obj, obj);
|
||||
evas_object_image_size_set(sd->evas_obj, sd->vw, sd->vh);
|
||||
sd->evas = ecore_evas_get(evas_object_data_get(sd->evas_obj, "Ecore_Evas"));
|
||||
e_canvas_add(evas_object_data_get(sd->evas_obj, "Ecore_Evas"));
|
||||
return obj;
|
||||
}
|
||||
|
||||
Evas *
|
||||
e_livethumb_evas_get(Evas_Object *obj)
|
||||
{
|
||||
API_ENTRY return NULL;
|
||||
return sd->evas;
|
||||
}
|
||||
|
||||
void
|
||||
e_livethumb_vsize_set(Evas_Object *obj, Evas_Coord w, Evas_Coord h)
|
||||
{
|
||||
API_ENTRY return;
|
||||
if ((w == sd->vw) && (h == sd->vh)) return;
|
||||
sd->vw = w;
|
||||
sd->vh = h;
|
||||
evas_object_image_size_set(sd->evas_obj, sd->vw, sd->vh);
|
||||
if (sd->thumb_obj) evas_object_resize(sd->thumb_obj, sd->vw, sd->vh);
|
||||
}
|
||||
|
||||
void
|
||||
e_livethumb_vsize_get(Evas_Object *obj, Evas_Coord *w, Evas_Coord *h)
|
||||
{
|
||||
API_ENTRY return;
|
||||
if (w) *w = sd->vw;
|
||||
if (h) *h = sd->vh;
|
||||
}
|
||||
|
||||
void
|
||||
e_livethumb_thumb_set(Evas_Object *obj, Evas_Object *thumb)
|
||||
{
|
||||
API_ENTRY return;
|
||||
if (!thumb)
|
||||
{
|
||||
sd->thumb_obj = NULL;
|
||||
return;
|
||||
}
|
||||
sd->thumb_obj = thumb;
|
||||
evas_object_show(sd->thumb_obj);
|
||||
evas_object_move(sd->thumb_obj, 0, 0);
|
||||
evas_object_resize(sd->thumb_obj, sd->vw, sd->vh);
|
||||
}
|
||||
|
||||
Evas_Object *
|
||||
e_livethumb_thumb_get(Evas_Object *obj)
|
||||
{
|
||||
API_ENTRY return NULL;
|
||||
return sd->thumb_obj;
|
||||
}
|
||||
|
||||
/* local subsystem functions */
|
||||
|
||||
static void
|
||||
_e_smart_reconfigure(E_Smart_Data *sd)
|
||||
{
|
||||
evas_object_move(sd->evas_obj, sd->x, sd->y);
|
||||
evas_object_resize(sd->evas_obj, sd->w, sd->h);
|
||||
evas_object_image_fill_set(sd->evas_obj, 0, 0, sd->w, sd->h);
|
||||
}
|
||||
|
||||
static void
|
||||
_e_smart_add(Evas_Object *obj)
|
||||
{
|
||||
E_Smart_Data *sd;
|
||||
Evas_Object *o;
|
||||
|
||||
sd = calloc(1, sizeof(E_Smart_Data));
|
||||
if (!sd) return;
|
||||
evas_object_smart_data_set(obj, sd);
|
||||
|
||||
sd->smart_obj = obj;
|
||||
sd->x = 0;
|
||||
sd->y = 0;
|
||||
sd->w = 0;
|
||||
sd->h = 0;
|
||||
sd->vw = 1;
|
||||
sd->vh = 1;
|
||||
}
|
||||
|
||||
static void
|
||||
_e_smart_del(Evas_Object *obj)
|
||||
{
|
||||
INTERNAL_ENTRY;
|
||||
e_canvas_del(evas_object_data_get(sd->evas_obj, "Ecore_Evas"));
|
||||
evas_object_del(sd->evas_obj);
|
||||
free(sd);
|
||||
}
|
||||
|
||||
static void
|
||||
_e_smart_move(Evas_Object *obj, Evas_Coord x, Evas_Coord y)
|
||||
{
|
||||
INTERNAL_ENTRY;
|
||||
if ((sd->x == x) && (sd->y == y)) return;
|
||||
sd->x = x;
|
||||
sd->y = y;
|
||||
_e_smart_reconfigure(sd);
|
||||
}
|
||||
|
||||
static void
|
||||
_e_smart_resize(Evas_Object *obj, Evas_Coord w, Evas_Coord h)
|
||||
{
|
||||
INTERNAL_ENTRY;
|
||||
if ((sd->w == w) && (sd->h == h)) return;
|
||||
sd->w = w;
|
||||
sd->h = h;
|
||||
_e_smart_reconfigure(sd);
|
||||
}
|
||||
|
||||
static void
|
||||
_e_smart_show(Evas_Object *obj)
|
||||
{
|
||||
INTERNAL_ENTRY;
|
||||
evas_object_show(sd->evas_obj);
|
||||
}
|
||||
|
||||
static void
|
||||
_e_smart_hide(Evas_Object *obj)
|
||||
{
|
||||
INTERNAL_ENTRY;
|
||||
evas_object_hide(sd->evas_obj);
|
||||
}
|
||||
|
||||
static void
|
||||
_e_smart_color_set(Evas_Object *obj, int r, int g, int b, int a)
|
||||
{
|
||||
INTERNAL_ENTRY;
|
||||
evas_object_color_set(sd->evas_obj, r, g, b, a);
|
||||
}
|
||||
|
||||
static void
|
||||
_e_smart_clip_set(Evas_Object *obj, Evas_Object * clip)
|
||||
{
|
||||
INTERNAL_ENTRY;
|
||||
evas_object_clip_set(sd->evas_obj, clip);
|
||||
}
|
||||
|
||||
static void
|
||||
_e_smart_clip_unset(Evas_Object *obj)
|
||||
{
|
||||
INTERNAL_ENTRY;
|
||||
evas_object_clip_unset(sd->evas_obj);
|
||||
}
|
||||
|
||||
/* never need to touch this */
|
||||
|
||||
static void
|
||||
_e_smart_init(void)
|
||||
{
|
||||
if (_e_smart) return;
|
||||
_e_smart = evas_smart_new(SMART_NAME,
|
||||
_e_smart_add,
|
||||
_e_smart_del,
|
||||
NULL, NULL, NULL, NULL, NULL,
|
||||
_e_smart_move,
|
||||
_e_smart_resize,
|
||||
_e_smart_show,
|
||||
_e_smart_hide,
|
||||
_e_smart_color_set,
|
||||
_e_smart_clip_set,
|
||||
_e_smart_clip_unset,
|
||||
NULL);
|
||||
}
|
||||
|
|
@ -0,0 +1,17 @@
|
|||
/*
|
||||
* vim:ts=8:sw=3:sts=8:noexpandtab:cino=>5n-3f0^-2{2
|
||||
*/
|
||||
#ifdef E_TYPEDEFS
|
||||
#else
|
||||
#ifndef E_LIVETHUMB_H
|
||||
#define E_LIVETHUMB_H
|
||||
|
||||
EAPI Evas_Object *e_livethumb_add (Ecore_Evas *ee);
|
||||
EAPI Evas *e_livethumb_evas_get (Evas_Object *obj);
|
||||
EAPI void e_livethumb_vsize_set (Evas_Object *obj, Evas_Coord w, Evas_Coord h);
|
||||
EAPI void e_livethumb_vsize_get (Evas_Object *obj, Evas_Coord *w, Evas_Coord *h);
|
||||
EAPI void e_livethumb_thumb_set (Evas_Object *obj, Evas_Object *thumb);
|
||||
EAPI Evas_Object *e_livethumb_thumb_get (Evas_Object *obj);
|
||||
|
||||
#endif
|
||||
#endif
|
|
@ -205,10 +205,18 @@ e_scrollframe_child_region_show(Evas_Object *obj, Evas_Coord x, Evas_Coord y, Ev
|
|||
|
||||
nx = px;
|
||||
if (x < px) nx = x;
|
||||
else if ((x + w) > (px + (cw - mx))) nx = x + w - (cw - mx);
|
||||
else if ((x + w) > (px + (cw - mx)))
|
||||
{
|
||||
nx = x + w - (cw - mx);
|
||||
if (nx > x) nx = x;
|
||||
}
|
||||
ny = py;
|
||||
if (y < py) ny = y;
|
||||
else if ((y + h) > (py + (ch - my))) ny = y + h - (ch - my);
|
||||
else if ((y + h) > (py + (ch - my)))
|
||||
{
|
||||
ny = y + h - (ch - my);
|
||||
if (ny > y) ny = y;
|
||||
}
|
||||
if ((nx == px) && (ny == py)) return;
|
||||
e_scrollframe_child_pos_set(obj, nx, ny);
|
||||
}
|
||||
|
|
|
@ -429,15 +429,20 @@ _e_test_internal(E_Container *con)
|
|||
{
|
||||
E_Dialog *dia;
|
||||
Evas_Coord mw, mh, vw, vh;
|
||||
Evas_Object *o, *o2, *o3;
|
||||
Evas_Object *o, *o2, *o3, *o4;
|
||||
|
||||
dia = e_dialog_new(con);
|
||||
e_dialog_title_set(dia, "A Test Dialog");
|
||||
|
||||
o = e_ilist_add(dia->win->evas);
|
||||
e_ilist_icon_size_set(o, 80, 48);
|
||||
|
||||
o3 = e_icon_add(dia->win->evas);
|
||||
e_icon_file_set(o3, "/home/raster/C/stuff/icons/star_office.png");
|
||||
o3 = e_livethumb_add(dia->win->ecore_evas);
|
||||
e_livethumb_vsize_set(o3, 160, 96);
|
||||
o4 = edje_object_add(e_livethumb_evas_get(o3));
|
||||
e_theme_edje_object_set(o4, "base/theme/borders",
|
||||
"widgets/border/default/border");
|
||||
e_livethumb_thumb_set(o3, o4);
|
||||
e_ilist_append(o, o3, "Item 1", _e_test_sel, NULL, NULL);
|
||||
|
||||
o3 = e_icon_add(dia->win->evas);
|
||||
|
|
Loading…
Reference in New Issue