Remove need for extra variables. Use E_NEW & E_FREE.

Cleanup Formatting. Remove Whitespace.


SVN revision: 40682
This commit is contained in:
Christopher Michael 2009-05-15 19:53:25 +00:00
parent 898b6f3cae
commit e56d841f6a
1 changed files with 125 additions and 99 deletions

View File

@ -25,8 +25,8 @@ struct _E_Smart_Data
Evas_Coord sx, sy;
Evas_Coord dx, dy;
struct {
Evas_Coord x, y;
double timestamp;
Evas_Coord x, y;
double timestamp;
} history[20];
double anim_start;
Ecore_Animator *momentum_animator;
@ -38,22 +38,26 @@ struct _E_Smart_Data
unsigned char locked : 1;
} down;
struct {
Evas_Coord w, h;
} child;
struct {
Evas_Coord x, y;
} step, page;
struct
{
Evas_Coord w, h;
} child;
struct
{
Evas_Coord x, y;
} step, page;
struct {
void (*set) (Evas_Object *obj, Evas_Coord x, Evas_Coord y);
void (*get) (Evas_Object *obj, Evas_Coord *x, Evas_Coord *y);
void (*max_get) (Evas_Object *obj, Evas_Coord *x, Evas_Coord *y);
void (*child_size_get) (Evas_Object *obj, Evas_Coord *x, Evas_Coord *y);
} pan_func;
struct {
Evas_Bool forced : 1;
} thumbscroll;
struct
{
void (*set) (Evas_Object *obj, Evas_Coord x, Evas_Coord y);
void (*get) (Evas_Object *obj, Evas_Coord *x, Evas_Coord *y);
void (*max_get) (Evas_Object *obj, Evas_Coord *x, Evas_Coord *y);
void (*child_size_get) (Evas_Object *obj, Evas_Coord *x, Evas_Coord *y);
} pan_func;
struct
{
Evas_Bool forced : 1;
} thumbscroll;
unsigned char hbar_visible : 1;
unsigned char vbar_visible : 1;
@ -105,14 +109,14 @@ e_scrollframe_add(Evas *evas)
EAPI void
e_scrollframe_child_set(Evas_Object *obj, Evas_Object *child)
{
Evas_Coord w, h;
Evas_Object *o;
API_ENTRY return;
if (sd->child_obj)
{
e_pan_child_set(sd->pan_obj, NULL);
evas_object_event_callback_del(sd->child_obj, EVAS_CALLBACK_FREE, _e_smart_child_del_hook);
evas_object_event_callback_del(sd->child_obj, EVAS_CALLBACK_FREE,
_e_smart_child_del_hook);
}
sd->child_obj = child;
@ -122,8 +126,10 @@ e_scrollframe_child_set(Evas_Object *obj, Evas_Object *child)
{
o = e_pan_add(evas_object_evas_get(obj));
sd->pan_obj = o;
evas_object_smart_callback_add(o, "changed", _e_smart_pan_changed_hook, sd);
evas_object_smart_callback_add(o, "pan_changed", _e_smart_pan_pan_changed_hook, sd);
evas_object_smart_callback_add(o, "changed",
_e_smart_pan_changed_hook, sd);
evas_object_smart_callback_add(o, "pan_changed",
_e_smart_pan_pan_changed_hook, sd);
evas_object_show(o);
edje_object_part_swallow(sd->edje_obj, "e.swallow.content", o);
}
@ -133,11 +139,10 @@ e_scrollframe_child_set(Evas_Object *obj, Evas_Object *child)
sd->pan_func.max_get = e_pan_max_get;
sd->pan_func.child_size_get = e_pan_child_size_get;
evas_object_event_callback_add(child, EVAS_CALLBACK_FREE, _e_smart_child_del_hook, sd);
evas_object_event_callback_add(child, EVAS_CALLBACK_FREE,
_e_smart_child_del_hook, sd);
e_pan_child_set(sd->pan_obj, sd->child_obj);
sd->pan_func.child_size_get(sd->pan_obj, &w, &h);
sd->child.w = w;
sd->child.h = h;
sd->pan_func.child_size_get(sd->pan_obj, &sd->child.w, &sd->child.h);
_e_smart_scrollbar_size_adjust(sd);
_e_smart_scrollbar_reset(sd);
}
@ -180,8 +185,10 @@ e_scrollframe_extern_pan_set(Evas_Object *obj, Evas_Object *pan,
sd->pan_func.max_get = pan_max_get;
sd->pan_func.child_size_get = pan_child_size_get;
sd->extern_pan = 1;
evas_object_smart_callback_add(sd->pan_obj, "changed", _e_smart_pan_changed_hook, sd);
evas_object_smart_callback_add(sd->pan_obj, "pan_changed", _e_smart_pan_pan_changed_hook, sd);
evas_object_smart_callback_add(sd->pan_obj, "changed",
_e_smart_pan_changed_hook, sd);
evas_object_smart_callback_add(sd->pan_obj, "pan_changed",
_e_smart_pan_pan_changed_hook, sd);
edje_object_part_swallow(sd->edje_obj, "e.swallow.content", sd->pan_obj);
evas_object_show(sd->pan_obj);
}
@ -206,8 +213,7 @@ e_scrollframe_custom_edje_file_set(Evas_Object *obj, char *file, char *group)
{
API_ENTRY return 0;
if (!edje_object_file_set(sd->edje_obj, file, group))
return 0;
if (!edje_object_file_set(sd->edje_obj, file, group)) return 0;
if (sd->pan_obj)
edje_object_part_swallow(sd->edje_obj, "e.swallow.content", sd->pan_obj);
sd->vbar_visible = !sd->vbar_visible;
@ -277,7 +283,8 @@ e_scrollframe_child_viewport_size_get(Evas_Object *obj, Evas_Coord *w, Evas_Coor
{
API_ENTRY return;
edje_object_calc_force(sd->edje_obj);
edje_object_part_geometry_get(sd->edje_obj, "e.swallow.content", NULL, NULL, w, h);
edje_object_part_geometry_get(sd->edje_obj,
"e.swallow.content", NULL, NULL, w, h);
}
EAPI void
@ -432,7 +439,8 @@ _e_smart_event_wheel(void *data, Evas *e __UNUSED__, Evas_Object *obj __UNUSED__
if ((sd->vbar_visible) && ((ev->direction % 2 == 0) || (!sd->hbar_visible)))
y += ev->z * sd->step.y;
else if ((sd->hbar_visible) && ((ev->direction % 2 == 1) || (!sd->vbar_visible)))
else if ((sd->hbar_visible) &&
((ev->direction % 2 == 1) || (!sd->vbar_visible)))
x += ev->z * sd->step.x;
e_scrollframe_child_pos_set(sd->smart_obj, x, y);
@ -443,7 +451,6 @@ _e_smart_event_mouse_down(void *data, Evas *e __UNUSED__, Evas_Object *obj __UNU
{
Evas_Event_Mouse_Down *ev;
E_Smart_Data *sd;
Evas_Coord x = 0, y = 0;
sd = data;
ev = event_info;
@ -462,9 +469,8 @@ _e_smart_event_mouse_down(void *data, Evas *e __UNUSED__, Evas_Object *obj __UNU
sd->down.dir_y = 0;
sd->down.x = ev->canvas.x;
sd->down.y = ev->canvas.y;
e_scrollframe_child_pos_get(sd->smart_obj, &x, &y);
sd->down.sx = x;
sd->down.sy = y;
e_scrollframe_child_pos_get(sd->smart_obj,
&sd->down.sx, &sd->down.sy);
sd->down.locked = 0;
memset(&(sd->down.history[0]), 0, sizeof(sd->down.history[0]) * 20);
sd->down.history[0].timestamp = ecore_loop_time_get();
@ -550,7 +556,8 @@ _e_smart_event_mouse_up(void *data, Evas *e, Evas_Object *obj __UNUSED__, void *
(vel > e_config->thumbscroll_momentum_threshhold))
{
if (!sd->down.momentum_animator)
sd->down.momentum_animator = ecore_animator_add(_e_smart_momentum_animator, sd);
sd->down.momentum_animator =
ecore_animator_add(_e_smart_momentum_animator, sd);
sd->down.dx = ((double)dx / at);
sd->down.dy = ((double)dy / at);
sd->down.anim_start = t;
@ -865,16 +872,19 @@ _e_smart_scrollbar_size_adjust(E_Smart_Data *sd)
double vx, vy, size;
edje_object_calc_force(sd->edje_obj);
edje_object_part_geometry_get(sd->edje_obj, "e.swallow.content", NULL, NULL, &vw, &vh);
edje_object_part_geometry_get(sd->edje_obj, "e.swallow.content",
NULL, NULL, &vw, &vh);
w = sd->child.w;
if (w < 1) w = 1;
size = (double)vw / (double)w;
if (size > 1.0)
{
size = 1.0;
edje_object_part_drag_value_set(sd->edje_obj, "e.dragable.hbar", 0.0, 0.0);
edje_object_part_drag_value_set(sd->edje_obj, "e.dragable.hbar",
0.0, 0.0);
}
edje_object_part_drag_size_set(sd->edje_obj, "e.dragable.hbar", size, 1.0);
edje_object_part_drag_size_set(sd->edje_obj, "e.dragable.hbar",
size, 1.0);
h = sd->child.h;
if (h < 1) h = 1;
@ -882,33 +892,45 @@ _e_smart_scrollbar_size_adjust(E_Smart_Data *sd)
if (size > 1.0)
{
size = 1.0;
edje_object_part_drag_value_set(sd->edje_obj, "e.dragable.vbar", 0.0, 0.0);
edje_object_part_drag_value_set(sd->edje_obj, "e.dragable.vbar",
0.0, 0.0);
}
edje_object_part_drag_size_set(sd->edje_obj, "e.dragable.vbar", 1.0, size);
edje_object_part_drag_size_set(sd->edje_obj, "e.dragable.vbar",
1.0, size);
edje_object_part_drag_value_get(sd->edje_obj, "e.dragable.hbar", &vx, NULL);
edje_object_part_drag_value_get(sd->edje_obj, "e.dragable.vbar", NULL, &vy);
edje_object_part_drag_value_get(sd->edje_obj, "e.dragable.hbar",
&vx, NULL);
edje_object_part_drag_value_get(sd->edje_obj, "e.dragable.vbar",
NULL, &vy);
sd->pan_func.max_get(sd->pan_obj, &mx, &my);
x = vx * mx;
y = vy * my;
edje_object_part_drag_step_set(sd->edje_obj, "e.dragable.hbar", (double)sd->step.x / (double)w, 0.0);
edje_object_part_drag_step_set(sd->edje_obj, "e.dragable.vbar", 0.0, (double)sd->step.y / (double)h);
edje_object_part_drag_step_set(sd->edje_obj, "e.dragable.hbar",
(double)sd->step.x / (double)w, 0.0);
edje_object_part_drag_step_set(sd->edje_obj, "e.dragable.vbar",
0.0, (double)sd->step.y / (double)h);
if (sd->page.x > 0)
edje_object_part_drag_page_set(sd->edje_obj, "e.dragable.hbar", (double)sd->page.x / (double)w, 0.0);
edje_object_part_drag_page_set(sd->edje_obj, "e.dragable.hbar",
(double)sd->page.x / (double)w, 0.0);
else
edje_object_part_drag_page_set(sd->edje_obj, "e.dragable.hbar", -((double)sd->page.x * ((double)vw / (double)w)) / 100.0, 0.0);
edje_object_part_drag_page_set(sd->edje_obj, "e.dragable.hbar",
-((double)sd->page.x * ((double)vw / (double)w)) / 100.0, 0.0);
if (sd->page.y > 0)
edje_object_part_drag_page_set(sd->edje_obj, "e.dragable.vbar", 0.0, (double)sd->page.y / (double)h);
edje_object_part_drag_page_set(sd->edje_obj, "e.dragable.vbar",
0.0, (double)sd->page.y / (double)h);
else
edje_object_part_drag_page_set(sd->edje_obj, "e.dragable.vbar", 0.0, -((double)sd->page.y * ((double)vh / (double)h)) / 100.0);
edje_object_part_drag_page_set(sd->edje_obj, "e.dragable.vbar",
0.0, -((double)sd->page.y * ((double)vh / (double)h)) / 100.0);
sd->pan_func.set(sd->pan_obj, x, y);
}
else
{
edje_object_part_drag_size_set(sd->edje_obj, "e.dragable.vbar", 1.0, 1.0);
edje_object_part_drag_size_set(sd->edje_obj, "e.dragable.hbar", 1.0, 1.0);
edje_object_part_drag_size_set(sd->edje_obj, "e.dragable.vbar",
1.0, 1.0);
edje_object_part_drag_size_set(sd->edje_obj, "e.dragable.hbar",
1.0, 1.0);
sd->pan_func.set(sd->pan_obj, 0, 0);
}
_e_smart_scrollbar_bar_visibility_adjust(sd);
@ -930,7 +952,7 @@ _e_smart_add(Evas_Object *obj)
E_Smart_Data *sd;
Evas_Object *o;
sd = calloc(1, sizeof(E_Smart_Data));
sd = E_NEW(E_Smart_Data, 1);
if (!sd) return;
evas_object_smart_data_set(obj, sd);
@ -948,24 +970,31 @@ _e_smart_add(Evas_Object *obj)
sd->hbar_visible = 1;
sd->vbar_visible = 1;
evas_object_event_callback_add(obj, EVAS_CALLBACK_KEY_DOWN, _e_smart_event_key_down, sd);
evas_object_event_callback_add(obj, EVAS_CALLBACK_KEY_DOWN,
_e_smart_event_key_down, sd);
evas_object_propagate_events_set(obj, 0);
o = edje_object_add(evas_object_evas_get(obj));
sd->edje_obj = o;
e_theme_edje_object_set(o, "base/theme/widgets",
"e/widgets/scrollframe");
edje_object_signal_callback_add(o, "drag*", "e.dragable.vbar", _e_smart_edje_drag_v, sd);
edje_object_signal_callback_add(o, "drag*", "e.dragable.hbar", _e_smart_edje_drag_h, sd);
edje_object_signal_callback_add(o, "drag*", "e.dragable.vbar",
_e_smart_edje_drag_v, sd);
edje_object_signal_callback_add(o, "drag*", "e.dragable.hbar",
_e_smart_edje_drag_h, sd);
evas_object_smart_member_add(o, obj);
o = evas_object_rectangle_add(evas_object_evas_get(obj));
sd->event_obj = o;
evas_object_color_set(o, 0, 0, 0, 0);
evas_object_event_callback_add(o, EVAS_CALLBACK_MOUSE_WHEEL, _e_smart_event_wheel, sd);
evas_object_event_callback_add(o, EVAS_CALLBACK_MOUSE_DOWN, _e_smart_event_mouse_down, sd);
evas_object_event_callback_add(o, EVAS_CALLBACK_MOUSE_UP, _e_smart_event_mouse_up, sd);
evas_object_event_callback_add(o, EVAS_CALLBACK_MOUSE_MOVE, _e_smart_event_mouse_move, sd);
evas_object_event_callback_add(o, EVAS_CALLBACK_MOUSE_WHEEL,
_e_smart_event_wheel, sd);
evas_object_event_callback_add(o, EVAS_CALLBACK_MOUSE_DOWN,
_e_smart_event_mouse_down, sd);
evas_object_event_callback_add(o, EVAS_CALLBACK_MOUSE_UP,
_e_smart_event_mouse_up, sd);
evas_object_event_callback_add(o, EVAS_CALLBACK_MOUSE_MOVE,
_e_smart_event_mouse_move, sd);
evas_object_smart_member_add(o, obj);
evas_object_repeat_events_set(o, 1);
@ -985,8 +1014,9 @@ _e_smart_del(Evas_Object *obj)
if (!sd->extern_pan) evas_object_del(sd->pan_obj);
evas_object_del(sd->edje_obj);
evas_object_del(sd->event_obj);
if (sd->down.momentum_animator) ecore_animator_del(sd->down.momentum_animator);
free(sd);
if (sd->down.momentum_animator)
ecore_animator_del(sd->down.momentum_animator);
E_FREE(sd);
}
static void
@ -1066,12 +1096,8 @@ _e_smart_init(void)
_e_smart_color_set,
_e_smart_clip_set,
_e_smart_clip_unset,
NULL,
NULL,
NULL,
NULL
NULL, NULL, NULL, NULL
};
_e_smart = evas_smart_class_new(&sc);
}
}