fix clicked when on hold set.
authorraster <raster@7cbeb6ba-43b4-40fd-8cce-4c39aea84d33>
Sun, 21 Nov 2010 06:28:13 +0000 (06:28 +0000)
committerraster <raster@7cbeb6ba-43b4-40fd-8cce-4c39aea84d33>
Sun, 21 Nov 2010 06:28:13 +0000 (06:28 +0000)
git-svn-id: http://svn.enlightenment.org/svn/e/trunk/edje@54757 7cbeb6ba-43b4-40fd-8cce-4c39aea84d33

src/lib/edje_callbacks.c

index 4966688..04d70cc 100644 (file)
@@ -194,7 +194,8 @@ _edje_mouse_down_signal_cb(void *data, Evas *e, Evas_Object *obj, void *event_in
    if (rp->clicked_button == 0)
      {
        rp->clicked_button = ev->button;
-       rp->still_in = 1;
+        if (!(ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD))
+         rp->still_in = 1;
      }
 //   _edje_recalc_do(ed);
    _edje_thaw(ed);
@@ -293,21 +294,30 @@ _edje_mouse_move_signal_cb(void *data, Evas *e, Evas_Object *obj, void *event_in
 
    if (rp->still_in)
      {
-       Evas_Coord x, y, w, h;
 
-       evas_object_geometry_get(obj, &x, &y, &w, &h);
-       if ((ev->cur.canvas.x < x) || (ev->cur.canvas.y < y) ||
-           (ev->cur.canvas.x >= (x + w)) || (ev->cur.canvas.y >= (y + h)))
-         rp->still_in = 0;
+        if (ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD)
+          rp->still_in = 0;
+        else
+          {
+            Evas_Coord x, y, w, h;
+            
+            evas_object_geometry_get(obj, &x, &y, &w, &h);
+            if ((ev->cur.canvas.x < x) || (ev->cur.canvas.y < y) ||
+                (ev->cur.canvas.x >= (x + w)) || (ev->cur.canvas.y >= (y + h)))
+              rp->still_in = 0;
+          }
      }
    else
      {
-       Evas_Coord x, y, w, h;
-
-       evas_object_geometry_get(obj, &x, &y, &w, &h);
-       if ((ev->cur.canvas.x >= x) && (ev->cur.canvas.y >= y) &&
-           (ev->cur.canvas.x < (x + w)) && (ev->cur.canvas.y < (y + h)))
-         rp->still_in = 1;
+        if (!(ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD))
+          {
+            Evas_Coord x, y, w, h;
+
+            evas_object_geometry_get(obj, &x, &y, &w, &h);
+            if ((ev->cur.canvas.x >= x) && (ev->cur.canvas.y >= y) &&
+                (ev->cur.canvas.x < (x + w)) && (ev->cur.canvas.y < (y + h)))
+              rp->still_in = 1;
+          }
      }
    _edje_freeze(ed);
    if (rp->drag)