slight change in drag events vs scrolling on_hold to fix small "distance

race" issue.



SVN revision: 46505
This commit is contained in:
Carsten Haitzler 2010-02-26 06:30:17 +00:00
parent de624fa62f
commit 6a7271084d
3 changed files with 20 additions and 12 deletions

View File

@ -872,6 +872,12 @@ item_drag_stop(void *data, Evas_Object *obj, void *event_info)
printf("drag stop\n");
}
static void
item_longpress(void *data, Evas_Object *obj, void *event_info)
{
printf("longpress\n");
}
void
test_genlist5(void *data, Evas_Object *obj, void *event_info)
{
@ -926,6 +932,7 @@ test_genlist5(void *data, Evas_Object *obj, void *event_info)
evas_object_smart_callback_add(gl, "drag,start,right", item_drag_right, NULL);
evas_object_smart_callback_add(gl, "drag", item_drag, NULL);
evas_object_smart_callback_add(gl, "drag,stop", item_drag_stop, NULL);
evas_object_smart_callback_add(gl, "longpressed", item_longpress, NULL);
bx2 = elm_box_add(win);
elm_box_horizontal_set(bx2, 1);

View File

@ -477,16 +477,7 @@ _mouse_move(void *data, Evas *evas, Evas_Object *obj, void *event_info)
_item_unselect(it);
}
}
if ((!it->down) || (it->wd->on_hold) || (it->wd->longpressed))
{
if (it->long_timer)
{
ecore_timer_del(it->long_timer);
it->long_timer = NULL;
}
return;
}
if (it->dragging)
if ((it->dragging) && (it->down))
{
if (it->long_timer)
{
@ -496,6 +487,15 @@ _mouse_move(void *data, Evas *evas, Evas_Object *obj, void *event_info)
evas_object_smart_callback_call(it->wd->obj, "drag", it);
return;
}
if ((!it->down)/* || (it->wd->on_hold)*/ || (it->wd->longpressed))
{
if (it->long_timer)
{
ecore_timer_del(it->long_timer);
it->long_timer = NULL;
}
return;
}
if (!it->display_only)
elm_coords_finger_size_adjust(1, &minw, 1, &minh);
evas_object_geometry_get(obj, &x, &y, NULL, NULL);
@ -577,6 +577,7 @@ _mouse_down(void *data, Evas *evas, Evas_Object *obj, void *event_info)
evas_object_geometry_get(obj, &x, &y, NULL, NULL);
it->dx = ev->canvas.x - x;
it->dy = ev->canvas.y - y;
it->wd->longpressed = EINA_FALSE;
if (ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD) it->wd->on_hold = EINA_TRUE;
else it->wd->on_hold = EINA_FALSE;
it->wd->wasselected = it->selected;
@ -599,6 +600,7 @@ _mouse_up(void *data, Evas *evas, Evas_Object *obj, void *event_info)
it->down = 0;
if (ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD) it->wd->on_hold = EINA_TRUE;
else it->wd->on_hold = EINA_FALSE;
it->wd->longpressed = EINA_FALSE;
if (it->long_timer)
{
ecore_timer_del(it->long_timer);
@ -612,7 +614,6 @@ _mouse_up(void *data, Evas *evas, Evas_Object *obj, void *event_info)
}
if (it->wd->on_hold)
{
it->wd->longpressed = EINA_FALSE;
it->wd->on_hold = EINA_FALSE;
return;
}

View File

@ -398,6 +398,7 @@ _mouse_up(void *data, Evas *evas, Evas_Object *obj, void *event_info)
if (ev->button != 1) return;
if (ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD) wd->on_hold = EINA_TRUE;
else wd->on_hold = EINA_FALSE;
wd->longpressed = EINA_FALSE;
if (it->long_timer)
{
ecore_timer_del(it->long_timer);
@ -410,7 +411,6 @@ _mouse_up(void *data, Evas *evas, Evas_Object *obj, void *event_info)
}
if (wd->longpressed)
{
wd->longpressed = EINA_FALSE;
if (!wd->wasselected) _item_unselect(it);
wd->wasselected = 0;
return;