diff options
author | Thiep Ha <thiepha@gmail.com> | 2014-03-06 19:33:05 +0900 |
---|---|---|
committer | Carsten Haitzler (Rasterman) <raster@rasterman.com> | 2014-03-06 20:14:11 +0900 |
commit | f7a1955ebbc4223cdcd77d5c76fc9ca1c9f625c6 (patch) | |
tree | 2bec48178da2a12f2bd36963b91a7973afdae2ed | |
parent | 0cd2ab1b52568aaead84042e69fe7cf9dd4e8399 (diff) | |
download | elementary-f7a1955ebbc4223cdcd77d5c76fc9ca1c9f625c6.tar.gz |
Fix bug of moving cursor handler
Summary:
In elm entry, cursor handlers are placed and moved incorrectly if we do selection from bottom to top.
Ex: In elementary_test -> Entry -> Right click -> choose Select -> do selection from bottom to top (or press Shift + <- keys to do selection).
Look at selection handlers: they are incorrectly placed.
Try to move selection handlers: They suddenly move to near each other.
Minor: Remove unused variable.
@fix
Reviewers: seoz
Differential Revision: https://phab.enlightenment.org/D583
-rw-r--r-- | src/lib/elm_entry.c | 111 | ||||
-rw-r--r-- | src/lib/elm_widget_entry.h | 2 |
2 files changed, 70 insertions, 43 deletions
diff --git a/src/lib/elm_entry.c b/src/lib/elm_entry.c index 5217940de..ab4de25bf 100644 --- a/src/lib/elm_entry.c +++ b/src/lib/elm_entry.c @@ -393,10 +393,10 @@ _update_selection_handler(Evas_Object *obj) { ELM_ENTRY_DATA_GET(obj, sd); - Evas_Coord sx, sy, sw, sh; + Evas_Coord sx, sy, sh; Evas_Coord ent_x, ent_y; - Evas_Coord ex, ey, ew, eh; - int start_pos, end_pos; + Evas_Coord ex, ey, eh; + int start_pos, end_pos, last_pos; if (!sd->sel_handler_disabled) { @@ -406,31 +406,39 @@ _update_selection_handler(Evas_Object *obj) (sd->entry_edje, "elm.text", EDJE_CURSOR_SELECTION_END); evas_object_geometry_get(sd->entry_edje, &ent_x, &ent_y, NULL, NULL); + last_pos = edje_object_part_text_cursor_pos_get(sd->entry_edje, "elm.text", + EDJE_CURSOR_MAIN); edje_object_part_text_cursor_pos_set(sd->entry_edje, "elm.text", EDJE_CURSOR_MAIN, start_pos); edje_object_part_text_cursor_geometry_get(sd->entry_edje, "elm.text", - &sx, &sy, &sw, &sh); + &sx, &sy, NULL, &sh); edje_object_part_text_cursor_pos_set(sd->entry_edje, "elm.text", EDJE_CURSOR_MAIN, end_pos); edje_object_part_text_cursor_geometry_get(sd->entry_edje, "elm.text", - &ex, &ey, &ew, &eh); - if (sd->start_handler_down) - edje_object_part_text_cursor_pos_set(sd->entry_edje, "elm.text", - EDJE_CURSOR_MAIN, start_pos); + &ex, &ey, NULL, &eh); + edje_object_part_text_cursor_pos_set(sd->entry_edje, "elm.text", + EDJE_CURSOR_MAIN, last_pos); if (!sd->start_handler_shown) { edje_object_signal_emit(sd->start_handler, "elm,handler,show", "elm"); sd->start_handler_shown = EINA_TRUE; } - evas_object_move(sd->start_handler, ent_x + sx, ent_y + sy + sh); + if (start_pos < end_pos) + evas_object_move(sd->start_handler, ent_x + sx, ent_y + sy + sh); + else + evas_object_move(sd->start_handler, ent_x + ex, ent_y + ey + eh); + if (!sd->end_handler_shown) { edje_object_signal_emit(sd->end_handler, "elm,handler,show", "elm"); sd->end_handler_shown = EINA_TRUE; } - evas_object_move(sd->end_handler, ent_x + ex, ent_y + ey + eh); + if (start_pos < end_pos) + evas_object_move(sd->end_handler, ent_x + ex, ent_y + ey + eh); + else + evas_object_move(sd->end_handler, ent_x + sx, ent_y + sy + sh); } else { @@ -3025,7 +3033,6 @@ _resize_cb(void *data, _elm_entry_resize_internal(data); } -Evas_Coord ox, oy; static void _start_handler_mouse_down_cb(void *data, Evas *e EINA_UNUSED, @@ -3037,21 +3044,33 @@ _start_handler_mouse_down_cb(void *data, Evas_Event_Mouse_Down *ev = event_info; Evas_Coord ex, ey; Evas_Coord cx, cy, cw, ch; - int pos, main_pos; + int start_pos, end_pos, main_pos, pos; sd->start_handler_down = EINA_TRUE; - pos = edje_object_part_text_cursor_pos_get(sd->entry_edje, "elm.text", + start_pos = edje_object_part_text_cursor_pos_get(sd->entry_edje, "elm.text", EDJE_CURSOR_SELECTION_BEGIN); + end_pos = edje_object_part_text_cursor_pos_get(sd->entry_edje, "elm.text", + EDJE_CURSOR_SELECTION_END); main_pos = edje_object_part_text_cursor_pos_get(sd->entry_edje, "elm.text", EDJE_CURSOR_MAIN); + if (start_pos <= end_pos) + { + pos = start_pos; + sd->sel_handler_cursor = EDJE_CURSOR_SELECTION_BEGIN; + } + else + { + pos = end_pos; + sd->sel_handler_cursor = EDJE_CURSOR_SELECTION_END; + } if (pos != main_pos) edje_object_part_text_cursor_pos_set(sd->entry_edje, "elm.text", EDJE_CURSOR_MAIN, pos); edje_object_part_text_cursor_geometry_get(sd->entry_edje, "elm.text", &cx, &cy, &cw, &ch); evas_object_geometry_get(sd->entry_edje, &ex, &ey, NULL, NULL); - ox = ev->canvas.x - (ex + cx + (cw / 2)); - oy = ev->canvas.y - (ey + cy + (ch / 2)); + sd->ox = ev->canvas.x - (ex + cx + (cw / 2)); + sd->oy = ev->canvas.y - (ey + cy + (ch / 2)); if (_elm_config->magnifier_enable) { @@ -3088,22 +3107,19 @@ _start_handler_mouse_move_cb(void *data, Evas_Event_Mouse_Move *ev = event_info; Evas_Coord ex, ey; Evas_Coord cx, cy, ch; - int spos, epos; + int pos; evas_object_geometry_get(sd->entry_edje, &ex, &ey, NULL, NULL); - cx = ev->cur.canvas.x - ox - ex; - cy = ev->cur.canvas.y - oy - ey; + cx = ev->cur.canvas.x - sd->ox - ex; + cy = ev->cur.canvas.y - sd->oy - ey; if (cx <= 0) cx = 1; + edje_object_part_text_cursor_coord_set(sd->entry_edje, "elm.text", - EDJE_CURSOR_SELECTION_BEGIN, cx, cy); - spos = edje_object_part_text_cursor_pos_get(sd->entry_edje, "elm.text", - EDJE_CURSOR_SELECTION_BEGIN); - epos = edje_object_part_text_cursor_pos_get(sd->entry_edje, "elm.text", - EDJE_CURSOR_SELECTION_END); - if (spos >= epos) - edje_object_part_text_cursor_pos_set(sd->entry_edje, "elm.text", - EDJE_CURSOR_SELECTION_BEGIN, - epos - 1); + sd->sel_handler_cursor, cx, cy); + pos = edje_object_part_text_cursor_pos_get(sd->entry_edje, "elm.text", + sd->sel_handler_cursor); + edje_object_part_text_cursor_pos_set(sd->entry_edje, "elm.text", + EDJE_CURSOR_MAIN, pos); edje_object_part_text_cursor_geometry_get(sd->entry_edje, "elm.text", &cx, &cy, NULL, &ch); @@ -3122,11 +3138,23 @@ _end_handler_mouse_down_cb(void *data, Evas_Event_Mouse_Down *ev = event_info; Evas_Coord ex, ey; Evas_Coord cx, cy, cw, ch; - int pos, main_pos; + int pos, start_pos, end_pos, main_pos; sd->end_handler_down = EINA_TRUE; - pos = edje_object_part_text_cursor_pos_get(sd->entry_edje, "elm.text", + start_pos = edje_object_part_text_cursor_pos_get(sd->entry_edje, "elm.text", + EDJE_CURSOR_SELECTION_BEGIN); + end_pos = edje_object_part_text_cursor_pos_get(sd->entry_edje, "elm.text", EDJE_CURSOR_SELECTION_END); + if (start_pos < end_pos) + { + pos = end_pos; + sd->sel_handler_cursor = EDJE_CURSOR_SELECTION_END; + } + else + { + pos = start_pos; + sd->sel_handler_cursor = EDJE_CURSOR_SELECTION_BEGIN; + } main_pos = edje_object_part_text_cursor_pos_get(sd->entry_edje, "elm.text", EDJE_CURSOR_MAIN); if (pos != main_pos) @@ -3136,8 +3164,8 @@ _end_handler_mouse_down_cb(void *data, edje_object_part_text_cursor_geometry_get(sd->entry_edje, "elm.text", &cx, &cy, &cw, &ch); evas_object_geometry_get(sd->entry_edje, &ex, &ey, NULL, NULL); - ox = ev->canvas.x - (ex + cx + (cw / 2)); - oy = ev->canvas.y - (ey + cy + (ch / 2)); + sd->ox = ev->canvas.x - (ex + cx + (cw / 2)); + sd->oy = ev->canvas.y - (ey + cy + (ch / 2)); if (_elm_config->magnifier_enable) { @@ -3174,22 +3202,19 @@ _end_handler_mouse_move_cb(void *data, Evas_Event_Mouse_Move *ev = event_info; Evas_Coord ex, ey; Evas_Coord cx, cy, ch; - int spos, epos; + int pos; evas_object_geometry_get(sd->entry_edje, &ex, &ey, NULL, NULL); - cx = ev->cur.canvas.x - ox - ex; - cy = ev->cur.canvas.y - oy - ey; + cx = ev->cur.canvas.x - sd->ox - ex; + cy = ev->cur.canvas.y - sd->oy - ey; if (cx <= 0) cx = 1; - edje_object_part_text_cursor_coord_set(sd->entry_edje, "elm.text", - EDJE_CURSOR_SELECTION_END, cx, cy); - spos = edje_object_part_text_cursor_pos_get(sd->entry_edje, "elm.text", - EDJE_CURSOR_SELECTION_BEGIN); - epos = edje_object_part_text_cursor_pos_get(sd->entry_edje, "elm.text", - EDJE_CURSOR_SELECTION_END); - if (epos <= spos) - edje_object_part_text_cursor_pos_set(sd->entry_edje, "elm.text", - EDJE_CURSOR_SELECTION_END, spos + 1); + edje_object_part_text_cursor_coord_set(sd->entry_edje, "elm.text", + sd->sel_handler_cursor, cx, cy); + pos = edje_object_part_text_cursor_pos_get(sd->entry_edje, "elm.text", + sd->sel_handler_cursor); + edje_object_part_text_cursor_pos_set(sd->entry_edje, "elm.text", + EDJE_CURSOR_MAIN, pos); edje_object_part_text_cursor_geometry_get(sd->entry_edje, "elm.text", &cx, &cy, NULL, &ch); diff --git a/src/lib/elm_widget_entry.h b/src/lib/elm_widget_entry.h index dabfde30e..f6feadb0f 100644 --- a/src/lib/elm_widget_entry.h +++ b/src/lib/elm_widget_entry.h @@ -48,6 +48,7 @@ struct _Elm_Entry_Smart_Data Elm_Text_Format format; Evas_Coord last_w, ent_mw, ent_mh; Evas_Coord downx, downy; + Evas_Coord ox, oy; Eina_List *items; /** context menu item list */ Eina_List *item_providers; Eina_List *markup_filters; @@ -60,6 +61,7 @@ struct _Elm_Entry_Smart_Data Elm_Autocapital_Type autocapital_type; Elm_Input_Panel_Lang input_panel_lang; Elm_Input_Panel_Return_Key_Type input_panel_return_key_type; + Edje_Cursor sel_handler_cursor; void *input_panel_imdata; int input_panel_imdata_len; int input_panel_layout_variation; |