ryuan pushed a commit to branch master.
commit b25834147b46260666688ea402a1f087c31cbf22
Author: Ryuan Choi <[email protected]>
Date: Tue Jun 11 11:13:24 2013 +0900
colorselector: Do not send "changed" signal twice when pressed color bar
Regardless of color selector mode, mouse down captured color.
This patch moves callbacks related to picker mode to _start_grab_pick_cb.
---
ChangeLog | 4 ++++
NEWS | 1 +
src/lib/elm_colorselector.c | 19 ++++++++++---------
3 files changed, 15 insertions(+), 9 deletions(-)
diff --git a/ChangeLog b/ChangeLog
index 7b00fce..6c86cab 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1410,3 +1410,7 @@
scroller, slider, slideshow, spinner, toolbar, win, calendar, check,
clock, colorselector, datetime, diskselector, flipselector, gengrid,
ctxpopup, fileselector_button, naviframe, player, popup, bubble,
button.
+
+2013-06-05 Ryuan Choi (ryuan)
+
+ * Fix colorselector send "changed" signal twice when pressed color bar.
diff --git a/NEWS b/NEWS
index 7b1fcb2..8927b10 100644
--- a/NEWS
+++ b/NEWS
@@ -242,6 +242,7 @@ Fixes:
* Fix navifame to recover the focus for the prev page when top item is
deleted.
* Up/down step of hour decimal of elm_clock is changed to 12 not to touch
hour unit at editing mode.
* Remove the keyboard area in the conformant if the keyboard state is off.
+ * Fix colorselector send "changed" signal twice when pressed color bar.
Removals:
diff --git a/src/lib/elm_colorselector.c b/src/lib/elm_colorselector.c
index 4be452f..e363a7c 100644
--- a/src/lib/elm_colorselector.c
+++ b/src/lib/elm_colorselector.c
@@ -476,6 +476,8 @@ _entry_changed_cb(void *data,
#ifdef HAVE_ELEMENTARY_X
static Eina_Bool _mouse_grab_pixels(void *data, int type __UNUSED__, void
*event __UNUSED__);
+static Eina_Bool _key_up_cb(void *data, int type __UNUSED__, void *event
__UNUSED__);
+static Eina_Bool _mouse_up_cb(void *data, int type __UNUSED__, void *event
__UNUSED__);
static Ecore_X_Window
_x11_elm_widget_xwin_get(const Evas_Object *obj)
@@ -507,8 +509,9 @@ _start_grab_pick_cb(void *data, Evas_Object *obj, void
*event_info __UNUSED__)
elm_object_disabled_set(obj, EINA_TRUE);
- ecore_event_handler_del(sd->grab.mouse_motion);
sd->grab.mouse_motion = ecore_event_handler_add(ECORE_EVENT_MOUSE_MOVE,
_mouse_grab_pixels, o);
+ sd->grab.key_up = ecore_event_handler_add(ECORE_EVENT_KEY_UP, _key_up_cb,
o);
+ sd->grab.mouse_up = ecore_event_handler_add(ECORE_EVENT_MOUSE_BUTTON_UP,
_mouse_up_cb, o);
ecore_x_keyboard_grab(sd->grab.xroot);
ecore_x_pointer_grab(sd->grab.xroot);
@@ -525,8 +528,9 @@ _key_up_cb(void *data, int type __UNUSED__, void *event
__UNUSED__)
elm_object_disabled_set(sd->button, EINA_FALSE);
ecore_x_keyboard_ungrab();
ecore_x_pointer_ungrab();
- ecore_event_handler_del(sd->grab.mouse_motion);
- sd->grab.mouse_motion = ecore_event_handler_add(ECORE_X_RAW_MOTION,
_mouse_grab_pixels, o);
+ ELM_SAFE_FREE(sd->grab.mouse_motion, ecore_event_handler_del);
+ ELM_SAFE_FREE(sd->grab.key_up, ecore_event_handler_del);
+ ELM_SAFE_FREE(sd->grab.mouse_up, ecore_event_handler_del);
return EINA_TRUE;
}
@@ -544,8 +548,9 @@ _mouse_up_cb(void *data, int type __UNUSED__, void *event
__UNUSED__)
elm_object_disabled_set(sd->button, EINA_FALSE);
ecore_x_keyboard_ungrab();
ecore_x_pointer_ungrab();
- ecore_event_handler_del(sd->grab.mouse_motion);
- sd->grab.mouse_motion = ecore_event_handler_add(ECORE_X_RAW_MOTION,
_mouse_grab_pixels, o);
+ ELM_SAFE_FREE(sd->grab.mouse_motion, ecore_event_handler_del);
+ ELM_SAFE_FREE(sd->grab.key_up, ecore_event_handler_del);
+ ELM_SAFE_FREE(sd->grab.mouse_up, ecore_event_handler_del);
pixels = evas_object_image_data_get(sd->picker_display, EINA_FALSE);
r = (pixels[17 * 9 + 9] >> 16) & 0xFF;
@@ -655,10 +660,6 @@ _color_picker_add(Evas_Object *obj,
Elm_Colorselector_Smart_Data *sd)
{
sd->grab.xroot = ecore_x_window_root_get(xwin);
ecore_x_input_raw_select(sd->grab.xroot);
-
- sd->grab.mouse_motion = ecore_event_handler_add(ECORE_X_RAW_MOTION,
_mouse_grab_pixels, obj);
- sd->grab.key_up = ecore_event_handler_add(ECORE_EVENT_KEY_UP,
_key_up_cb, obj);
- sd->grab.mouse_up =
ecore_event_handler_add(ECORE_EVENT_MOUSE_BUTTON_UP, _mouse_up_cb, obj);
}
#endif
--
------------------------------------------------------------------------------
This SF.net email is sponsored by Windows:
Build for Windows Store.
http://p.sf.net/sfu/windows-dev2dev