elementary/naviframe : Fixed a bug that naviframe's focus_next didn't work after changing evenry item to elm_layout.
This commit is contained in:
parent
a35926215d
commit
cfe2ab206e
|
@ -1136,3 +1136,7 @@
|
|||
2013-03-08 ChunEon Park (Hermet)
|
||||
|
||||
* Remove the back button callback if the button is unset on the naviframe.
|
||||
|
||||
2013-03-11 WooHyun Jung
|
||||
|
||||
* Fixed a bug that naviframe's focus_next didn't work after changing evenry item to elm_layout.
|
||||
|
|
|
@ -179,6 +179,7 @@ Fixes:
|
|||
* After elm_win is created, if there is no manual focus setting, only elm_win should get focus when focus state is changed.
|
||||
* Fix the toolbar cannot be unselected when it's mode is ELM_OBJECT_SELECT_MODE_ALWAYS.
|
||||
* Remove the back button callback if the back button is unset on the naviframe.
|
||||
* Fixed a bug that naviframe's focus_next didn't work after changing evenry item to elm_layout.
|
||||
|
||||
Removals:
|
||||
|
||||
|
|
|
@ -456,9 +456,8 @@ _item_del_pre_hook(Elm_Object_Item *it)
|
|||
|
||||
if (nit->content && !sd->on_deletion)
|
||||
{
|
||||
nit->content_unfocusable =
|
||||
elm_widget_tree_unfocusable_get(nit->content);
|
||||
elm_widget_tree_unfocusable_set(nit->content, EINA_TRUE);
|
||||
nit->unfocusable = elm_widget_tree_unfocusable_get(VIEW(nit));
|
||||
elm_widget_tree_unfocusable_set(VIEW(nit), EINA_TRUE);
|
||||
}
|
||||
|
||||
if (sd->stack->last->prev)
|
||||
|
@ -1014,7 +1013,7 @@ _on_item_push_finished(void *data,
|
|||
evas_object_hide(VIEW(it));
|
||||
|
||||
if (it->content)
|
||||
elm_widget_tree_unfocusable_set(it->content, it->content_unfocusable);
|
||||
elm_widget_tree_unfocusable_set(VIEW(it), it->unfocusable);
|
||||
|
||||
if (sd->freeze_events)
|
||||
evas_object_freeze_events_set(VIEW(it), EINA_FALSE);
|
||||
|
@ -1033,7 +1032,7 @@ _on_item_pop_finished(void *data,
|
|||
ELM_NAVIFRAME_DATA_GET(WIDGET(it), sd);
|
||||
|
||||
if (sd->preserve && it->content)
|
||||
elm_widget_tree_unfocusable_set(it->content, it->content_unfocusable);
|
||||
elm_widget_tree_unfocusable_set(VIEW(it), it->unfocusable);
|
||||
sd->popping = eina_list_remove(sd->popping, it);
|
||||
|
||||
elm_widget_item_del(data);
|
||||
|
@ -1049,12 +1048,20 @@ _on_item_show_finished(void *data,
|
|||
const char *source __UNUSED__)
|
||||
{
|
||||
Elm_Naviframe_Item *it = data;
|
||||
unsigned int order = 0;
|
||||
Evas_Object *newest;
|
||||
|
||||
ELM_NAVIFRAME_DATA_GET(WIDGET(it), sd);
|
||||
|
||||
elm_object_signal_emit(VIEW(it), "elm,state,visible", "elm");
|
||||
|
||||
elm_widget_tree_unfocusable_set(it->content, it->content_unfocusable);
|
||||
elm_widget_tree_unfocusable_set(VIEW(it), it->unfocusable);
|
||||
|
||||
newest = elm_widget_newest_focus_order_get(VIEW(it), &order, EINA_TRUE);
|
||||
if (newest)
|
||||
elm_object_focus_set(newest, EINA_TRUE);
|
||||
else
|
||||
elm_object_focus_set(VIEW(it), EINA_TRUE);
|
||||
|
||||
if (sd->freeze_events)
|
||||
evas_object_freeze_events_set(VIEW(it), EINA_FALSE);
|
||||
|
@ -1196,7 +1203,6 @@ _elm_naviframe_smart_focus_next(Eo *obj, void *_pd EINA_UNUSED, va_list *list)
|
|||
|
||||
Eina_List *l = NULL;
|
||||
Elm_Naviframe_Item *top_it;
|
||||
Elm_Naviframe_Content_Item_Pair *content_pair = NULL;
|
||||
void *(*list_data_get)(const Eina_List *list);
|
||||
|
||||
Elm_Focus_Direction dir = va_arg(*list, Elm_Focus_Direction);
|
||||
|
@ -1208,16 +1214,10 @@ _elm_naviframe_smart_focus_next(Eo *obj, void *_pd EINA_UNUSED, va_list *list)
|
|||
top_it = (Elm_Naviframe_Item *)elm_naviframe_top_item_get(obj);
|
||||
if (!top_it) return;
|
||||
|
||||
//In case of the title area is invisible.
|
||||
if (!top_it->title_visible)
|
||||
{
|
||||
int_ret = elm_widget_focus_next_get(top_it->content, dir, next);
|
||||
if (ret) *ret = int_ret;
|
||||
return;
|
||||
}
|
||||
|
||||
list_data_get = eina_list_data_get;
|
||||
|
||||
l = eina_list_append(l, VIEW(top_it));
|
||||
|
||||
/* access */
|
||||
if (_elm_config->access_mode)
|
||||
{
|
||||
|
@ -1225,24 +1225,6 @@ _elm_naviframe_smart_focus_next(Eo *obj, void *_pd EINA_UNUSED, va_list *list)
|
|||
if (ao) l = eina_list_append(l, ao);
|
||||
}
|
||||
|
||||
/* icon would be able to have an widget. ex: segment control */
|
||||
if ((top_it->title_icon) &&
|
||||
(elm_widget_can_focus_get(top_it->title_icon) ||
|
||||
elm_widget_child_can_focus_get(top_it->title_icon)))
|
||||
l = eina_list_append(l, top_it->title_icon);
|
||||
|
||||
if (top_it->title_prev_btn)
|
||||
l = eina_list_append(l, top_it->title_prev_btn);
|
||||
if (top_it->title_next_btn)
|
||||
l = eina_list_append(l, top_it->title_next_btn);
|
||||
if (top_it->content)
|
||||
l = eina_list_append(l, top_it->content);
|
||||
EINA_INLIST_FOREACH(top_it->content_list, content_pair)
|
||||
{
|
||||
if (content_pair->content)
|
||||
l = eina_list_append(l, content_pair->content);
|
||||
}
|
||||
|
||||
int_ret = elm_widget_focus_list_next_get(obj, l, list_data_get, dir, next);
|
||||
if (ret) *ret = int_ret;
|
||||
eina_list_free(l);
|
||||
|
@ -1431,6 +1413,8 @@ _item_push(Eo *obj, void *_pd, va_list *list)
|
|||
|
||||
evas_object_show(VIEW(it));
|
||||
elm_widget_resize_object_set(obj, VIEW(it));
|
||||
if (prev_it)
|
||||
elm_widget_sub_object_add(obj, VIEW(prev_it));
|
||||
|
||||
if (prev_it)
|
||||
{
|
||||
|
@ -1445,15 +1429,13 @@ _item_push(Eo *obj, void *_pd, va_list *list)
|
|||
edje_object_message_signal_process(elm_layout_edje_get(VIEW(prev_it)));
|
||||
edje_object_message_signal_process(elm_layout_edje_get(VIEW(it)));
|
||||
|
||||
if (prev_it->content)
|
||||
{
|
||||
prev_it->content_unfocusable =
|
||||
elm_widget_tree_unfocusable_get(prev_it->content);
|
||||
elm_widget_tree_unfocusable_set(prev_it->content, EINA_TRUE);
|
||||
}
|
||||
prev_it->unfocusable = elm_widget_tree_unfocusable_get(VIEW(prev_it));
|
||||
elm_widget_tree_unfocusable_set(VIEW(prev_it), EINA_TRUE);
|
||||
|
||||
it->animator = ecore_animator_add(_push_transition_cb, it);
|
||||
}
|
||||
else
|
||||
elm_object_focus_set(VIEW(it), EINA_TRUE);
|
||||
|
||||
sd->stack = eina_inlist_append(sd->stack, EINA_INLIST_GET(it));
|
||||
evas_object_raise(VIEW(it));
|
||||
|
@ -1561,8 +1543,10 @@ _item_insert_after(Eo *obj, void *_pd, va_list *list)
|
|||
if (top_inserted)
|
||||
{
|
||||
elm_widget_resize_object_set(obj, VIEW(it));
|
||||
elm_widget_sub_object_add(obj, VIEW(after));
|
||||
evas_object_show(VIEW(it));
|
||||
evas_object_hide(VIEW(after));
|
||||
elm_object_focus_set(VIEW(it), EINA_TRUE);
|
||||
}
|
||||
|
||||
/* access */
|
||||
|
@ -1603,11 +1587,8 @@ _item_pop(Eo *obj, void *_pd, va_list *list)
|
|||
|
||||
evas_object_data_set(VIEW(it), "out_of_list", (void *)1);
|
||||
|
||||
if (it->content)
|
||||
{
|
||||
it->content_unfocusable = elm_widget_tree_unfocusable_get(it->content);
|
||||
elm_widget_tree_unfocusable_set(it->content, EINA_TRUE);
|
||||
}
|
||||
it->unfocusable = elm_widget_tree_unfocusable_get(VIEW(it));
|
||||
elm_widget_tree_unfocusable_set(VIEW(it), EINA_TRUE);
|
||||
|
||||
if (sd->stack->last->prev)
|
||||
prev_it = EINA_INLIST_CONTAINER_GET
|
||||
|
@ -1688,6 +1669,7 @@ elm_naviframe_item_pop_to(Elm_Object_Item *it)
|
|||
EAPI void
|
||||
elm_naviframe_item_promote(Elm_Object_Item *it)
|
||||
{
|
||||
Elm_Object_Item * prev_top;
|
||||
Elm_Naviframe_Item *nit;
|
||||
Elm_Naviframe_Item *prev_it;
|
||||
|
||||
|
@ -1696,23 +1678,21 @@ elm_naviframe_item_promote(Elm_Object_Item *it)
|
|||
nit = (Elm_Naviframe_Item *)it;
|
||||
ELM_NAVIFRAME_DATA_GET(WIDGET(nit), sd);
|
||||
|
||||
if (it == elm_naviframe_top_item_get(nit->base.widget)) return;
|
||||
prev_top = elm_naviframe_top_item_get(nit->base.widget);
|
||||
if (it == prev_top) return;
|
||||
|
||||
/* remember, last is 1st on the naviframe, push it to last pos. */
|
||||
sd->stack = eina_inlist_demote(sd->stack, EINA_INLIST_GET(nit));
|
||||
|
||||
elm_widget_resize_object_set(WIDGET(it), VIEW(nit));
|
||||
elm_widget_sub_object_add(WIDGET(it), VIEW(prev_top));
|
||||
|
||||
/* this was the previous top one */
|
||||
prev_it = EINA_INLIST_CONTAINER_GET
|
||||
(sd->stack->last->prev, Elm_Naviframe_Item);
|
||||
|
||||
if (prev_it->content)
|
||||
{
|
||||
prev_it->content_unfocusable =
|
||||
elm_widget_tree_unfocusable_get(prev_it->content);
|
||||
elm_widget_tree_unfocusable_set(prev_it->content, EINA_TRUE);
|
||||
}
|
||||
prev_it->unfocusable = elm_widget_tree_unfocusable_get(VIEW(prev_it));
|
||||
elm_widget_tree_unfocusable_set(VIEW(prev_it), EINA_TRUE);
|
||||
|
||||
if (sd->freeze_events)
|
||||
{
|
||||
|
|
|
@ -55,7 +55,7 @@ struct _Elm_Naviframe_Item
|
|||
Evas_Coord minh;
|
||||
|
||||
Eina_Bool title_visible : 1;
|
||||
Eina_Bool content_unfocusable : 1;
|
||||
Eina_Bool unfocusable : 1;
|
||||
};
|
||||
|
||||
typedef struct _Elm_Naviframe_Content_Item_Pair Elm_Naviframe_Content_Item_Pair;
|
||||
|
|
Loading…
Reference in New Issue