woohyun pushed a commit to branch master. http://git.enlightenment.org/core/elementary.git/commit/?id=a3a41cec1d8bc28b7aed10038fdad598e88a3a50
commit a3a41cec1d8bc28b7aed10038fdad598e88a3a50 Author: WooHyun Jung <wh0705.j...@samsung.com> Date: Fri Jul 4 11:16:59 2014 +0900 focus: when focus_highlight is enabled, it should be shown immediately. --- src/bin/test_focus.c | 21 ++++++++++++++++++++- src/lib/elm_win.c | 11 ++++++++++- 2 files changed, 30 insertions(+), 2 deletions(-) diff --git a/src/bin/test_focus.c b/src/bin/test_focus.c index b450229..d7cef02 100644 --- a/src/bin/test_focus.c +++ b/src/bin/test_focus.c @@ -60,6 +60,15 @@ _tb_sel(void *data EINA_UNUSED, Evas_Object *obj, void *event_info EINA_UNUSED) } static void +_focus_highlight_changed(void *data, Evas_Object *obj, void *event_info EINA_UNUSED) +{ + if (elm_check_state_get(obj)) + elm_win_focus_highlight_enabled_set(data, EINA_TRUE); + else + elm_win_focus_highlight_enabled_set(data, EINA_FALSE); +} + +static void _focus_anim_changed(void *data, Evas_Object *obj, void *event_info EINA_UNUSED) { if (elm_check_state_get(obj)) @@ -429,9 +438,19 @@ test_focus(void *data EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_inf { Evas_Object *ck; + + ck = elm_check_add(bx); + elm_object_text_set(ck, "Focus Highlight Enable"); + elm_check_state_set(ck, elm_win_focus_highlight_enabled_get(win)); + elm_box_pack_end(bx, ck); + my_show(ck); + evas_object_smart_callback_add(ck, "changed", + _focus_highlight_changed, + win); + ck = elm_check_add(bx); elm_object_text_set(ck, "Focus Highlight Animation Enable"); - elm_check_state_set(ck, elm_config_focus_highlight_animate_get()); + elm_check_state_set(ck, elm_win_focus_highlight_animate_get(win)); elm_box_pack_end(bx, ck); my_show(ck); evas_object_smart_callback_add(ck, "changed", diff --git a/src/lib/elm_win.c b/src/lib/elm_win.c index 11ca2d3..80e0ce1 100644 --- a/src/lib/elm_win.c +++ b/src/lib/elm_win.c @@ -2281,7 +2281,16 @@ _elm_win_focus_highlight_init(Elm_Win_Data *sd) EVAS_CALLBACK_CANVAS_OBJECT_FOCUS_OUT, _elm_win_object_focus_out, sd->obj); - sd->focus_highlight.cur.target = NULL; + sd->focus_highlight.cur.target = _elm_win_focus_target_get(evas_focus_get(sd->evas)); + if (sd->focus_highlight.cur.target) + { + if (elm_widget_highlight_in_theme_get(sd->focus_highlight.cur.target)) + sd->focus_highlight.cur.in_theme = EINA_TRUE; + else + _elm_win_focus_target_callbacks_add(sd); + } + + sd->focus_highlight.prev.target = NULL; sd->focus_highlight.fobj = edje_object_add(sd->evas); sd->focus_highlight.theme_changed = EINA_TRUE; --