+/*
+ * vim:ts=8:sw=3:sts=8:noexpandtab:cino=>5n-3f0^-2{2
+ */
#include <Elementary.h>
#include "elm_priv.h"
struct _Widget_Data
{
- Evas_Object *base;
- Evas_Object *hbox;
- int page_count;
- Eina_List *page_list;
- unsigned int cur_page_id;
- Evas_Object *parent;
- int padding;
+ Evas_Object *base;
+ Evas_Object *hbox;
+ int page_count;
+ Eina_List *page_list;
+ unsigned int cur_page_id;
+ Evas_Object *parent;
+ int padding;
double scale_factor;
};
+
struct _Page_Item
{
- Evas_Object *obj;
- Evas_Object *base;
- const void *data;
- int page_id;
- Eina_Bool selected :1;
+ Evas_Object *obj;
+ Evas_Object *base;
+ const void *data;
+ int page_id;
+ Eina_Bool selected :1;
};
static void _theme_hook(Evas_Object *obj)
{
- Widget_Data *wd = elm_widget_data_get(obj);
- _elm_theme_object_set(obj, wd->base, "page_control", "base", elm_widget_style_get(obj));
+ Widget_Data *wd = elm_widget_data_get(obj);
+ _elm_theme_object_set(obj, wd->base, "page_control", "base", elm_widget_style_get(obj));
}
static void _sizing_eval(Evas_Object *obj)
{
- Widget_Data *wd = elm_widget_data_get(obj);
+ Widget_Data *wd = elm_widget_data_get(obj);
Evas_Coord minw = -1, minh = -1, maxw = -1, maxh = -1;
- if (!wd)
- return;
+ if (!wd)
+ return;
elm_coords_finger_size_adjust(1, &minw, 1, &minh);
edje_object_size_min_restricted_calc(wd->base, &minw, &minh, minw, minh);
elm_coords_finger_size_adjust(1, &minw, 1, &minh);
- evas_object_size_hint_min_set(obj, -1, -1);
- evas_object_size_hint_max_set(obj, -1, -1);
+ evas_object_size_hint_min_set(obj, -1, -1);
+ evas_object_size_hint_max_set(obj, -1, -1);
}
static void _item_free(Evas_Object *obj, Page_Item *it)
{
- Widget_Data *wd = elm_widget_data_get(obj);
- if (!wd)
- return;
+ Widget_Data *wd = elm_widget_data_get(obj);
+ if (!wd)
+ return;
- if (wd->page_list)
- wd->page_list = eina_list_remove(wd->page_list, it);
+ if (wd->page_list)
+ wd->page_list = eina_list_remove(wd->page_list, it);
- if (it->base)
- evas_object_del(it->base);
+ if (it->base)
+ evas_object_del(it->base);
- if (it)
- free(it);
- it = NULL;
- return;
+ if (it)
+ free(it);
+ it = NULL;
+ return;
}
+
static void _del_hook(Evas_Object *obj)
{
- Widget_Data *wd = elm_widget_data_get(obj);
- Page_Item *it;
- Eina_List *l, *clear = NULL;
+ Widget_Data *wd = elm_widget_data_get(obj);
+ Page_Item *it;
+ Eina_List *l, *clear = NULL;
- EINA_LIST_FOREACH(wd->page_list, l, it) clear = eina_list_append(clear, it);
- EINA_LIST_FREE(clear, it) _item_free(obj, it);
+ EINA_LIST_FOREACH(wd->page_list, l, it) clear = eina_list_append(clear, it);
+ EINA_LIST_FREE(clear, it) _item_free(obj, it);
- if (wd)
- free(wd);
- wd = NULL;
+ if (wd)
+ free(wd);
+ wd = NULL;
- return;
+ return;
}
static Page_Item *
_page_find(Evas_Object *obj, unsigned int index)
{
- Widget_Data *wd = elm_widget_data_get(obj);
- if (!wd)
- return NULL;
-
- Page_Item *it;
- Eina_List *l;
-
- int i = 0;
- EINA_LIST_FOREACH(wd->page_list, l, it)
- {
- if (i == index) {
- return it;
- }
- i++;
+ Widget_Data *wd = elm_widget_data_get(obj);
+ if (!wd)
+ return NULL;
+
+ Page_Item *it;
+ Eina_List *l;
+
+ int i = 0;
+ EINA_LIST_FOREACH(wd->page_list, l, it)
+ {
+ if (i == index) {
+ return it;
}
- return NULL;
+ i++;
+ }
+ return NULL;
}
static void _indicator_click_left(void *data, Evas_Object *obj, const char *emission, const char *source)
{
- Widget_Data *wd = elm_widget_data_get((Evas_Object *)data);
- if (!wd)
- return;
+ Widget_Data *wd = elm_widget_data_get((Evas_Object *)data);
+ if (!wd)
+ return;
- Page_Item *it;
- Eina_List *l;
- double cur_position = 0.0;
+ Page_Item *it;
+ Eina_List *l;
+ double cur_position = 0.0;
- if(wd->cur_page_id <= 0) return;
- it=_page_find((Evas_Object *)data, wd->cur_page_id);
- if(!it) return;
+ if(wd->cur_page_id <= 0) return;
+ it=_page_find((Evas_Object *)data, wd->cur_page_id);
+ if(!it) return;
- edje_object_signal_emit(it->base, "elm,state,indicator,off", "elm");
+ edje_object_signal_emit(it->base, "elm,state,indicator,off", "elm");
- it=_page_find((Evas_Object *)data, it->page_id-1);
- if(!it) return;
+ it=_page_find((Evas_Object *)data, it->page_id-1);
+ if(!it) return;
- edje_object_signal_emit(it->base, "elm,state,indicator,on", "elm");
- wd->cur_page_id = it->page_id;
+ edje_object_signal_emit(it->base, "elm,state,indicator,on", "elm");
+ wd->cur_page_id = it->page_id;
evas_object_smart_callback_call(it->obj, "changed", (void*)wd->cur_page_id);
if(!wd->page_count)
- return;
+ return;
cur_position = ((double)wd->cur_page_id)/wd->page_count;
- edje_object_part_drag_value_set(wd->base, "elm.drag.part", cur_position, 0.5);
+ edje_object_part_drag_value_set(wd->base, "elm.drag.part", cur_position, 0.5);
}
static void _indicator_click_right(void *data, Evas_Object *obj, const char *emission, const char *source)
{
- Widget_Data *wd = elm_widget_data_get((Evas_Object *)data);
- if (!wd)
- return;
+ Widget_Data *wd = elm_widget_data_get((Evas_Object *)data);
+ if (!wd)
+ return;
- Page_Item *it;
- Eina_List *l;
- double cur_position = 0.0;
+ Page_Item *it;
+ Eina_List *l;
+ double cur_position = 0.0;
- if(wd->cur_page_id >= wd->page_count-1) return;
+ if(wd->cur_page_id >= wd->page_count-1) return;
- it=_page_find((Evas_Object *)data, wd->cur_page_id);
- if(!it) return;
+ it=_page_find((Evas_Object *)data, wd->cur_page_id);
+ if(!it) return;
- edje_object_signal_emit(it->base, "elm,state,indicator,off", "elm");
+ edje_object_signal_emit(it->base, "elm,state,indicator,off", "elm");
- it=_page_find((Evas_Object *)data, it->page_id+1);
- if(!it) return;
+ it=_page_find((Evas_Object *)data, it->page_id+1);
+ if(!it) return;
- edje_object_signal_emit(it->base, "elm,state,indicator,on", "elm");
- wd->cur_page_id = it->page_id;
+ edje_object_signal_emit(it->base, "elm,state,indicator,on", "elm");
+ wd->cur_page_id = it->page_id;
evas_object_smart_callback_call(it->obj, "changed", (void*)wd->cur_page_id);
if(!wd->page_count)
- return;
+ return;
cur_position = ((double)wd->cur_page_id)/wd->page_count;
- edje_object_part_drag_value_set(wd->base, "elm.drag.part", cur_position, 0);
-
+ edje_object_part_drag_value_set(wd->base, "elm.drag.part", cur_position, 0);
}
static void _indicator_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
{
- Widget_Data *wd = elm_widget_data_get((Evas_Object *)data);
- if (!wd)
- return;
-
- Page_Item *it;
- Eina_List *l;
-
- int i = 0;
- EINA_LIST_FOREACH(wd->page_list, l, it)
- {
- if (it->base == obj)
- {
- edje_object_signal_emit(it->base, "elm,state,indicator,on", "elm");
- wd->cur_page_id = it->page_id;
- evas_object_smart_callback_call(it->obj, "changed", (void*)wd->cur_page_id);
- }
- else
- edje_object_signal_emit(it->base, "elm,state,indicator,off", "elm");
- i++;
- }
+ Widget_Data *wd = elm_widget_data_get((Evas_Object *)data);
+ if (!wd)
+ return;
+
+ Page_Item *it;
+ Eina_List *l;
+
+ int i = 0;
+ EINA_LIST_FOREACH(wd->page_list, l, it)
+ {
+ if (it->base == obj)
+ {
+ edje_object_signal_emit(it->base, "elm,state,indicator,on", "elm");
+ wd->cur_page_id = it->page_id;
+ evas_object_smart_callback_call(it->obj, "changed", (void*)wd->cur_page_id);
+ }
+ else
+ edje_object_signal_emit(it->base, "elm,state,indicator,off", "elm");
+ i++;
+ }
} // Added by jh0506.yun for BEAT UX v3.0
static Page_Item*
_create_item(Evas_Object *obj, unsigned int page_id)
{
- Widget_Data *wd = elm_widget_data_get(obj);
- Page_Item *it;
- Evas_Coord mw, mh;
- it = calloc(1, sizeof(Page_Item));
- if (!it)
- return NULL;
-
- it->obj = obj;
- it->selected = EINA_FALSE;
- it->data = it;
- it->page_id = page_id;
-
- it->base = edje_object_add(evas_object_evas_get(obj));
-
- _elm_theme_object_set(obj, it->base, "page", "item", "default");
- edje_object_size_min_restricted_calc(it->base, &mw, &mh, 0, 0);
- evas_object_size_hint_weight_set(it->base, 1.0, 1.0);
- evas_object_size_hint_align_set(it->base, -1.0, -1.0);
-
- evas_object_resize(it->base, mw, mh);
- evas_object_size_hint_min_set(it->base, mw, mh);
- evas_object_size_hint_max_set(it->base, mw, mh);
-
- // Added by jh0506.yun for BEAT UX v3.0
- edje_object_signal_callback_add(it->base, "clicked", "indicator_clicked", _indicator_clicked_cb, obj);
-
- return it;
+ Widget_Data *wd = elm_widget_data_get(obj);
+ Page_Item *it;
+ Evas_Coord mw, mh;
+ it = calloc(1, sizeof(Page_Item));
+ if (!it)
+ return NULL;
+
+ it->obj = obj;
+ it->selected = EINA_FALSE;
+ it->data = it;
+ it->page_id = page_id;
+
+ it->base = edje_object_add(evas_object_evas_get(obj));
+
+ _elm_theme_object_set(obj, it->base, "page", "item", "default");
+ edje_object_size_min_restricted_calc(it->base, &mw, &mh, 0, 0);
+ evas_object_size_hint_weight_set(it->base, 1.0, 1.0);
+ evas_object_size_hint_align_set(it->base, -1.0, -1.0);
+
+ evas_object_resize(it->base, mw, mh);
+ evas_object_size_hint_min_set(it->base, mw, mh);
+ evas_object_size_hint_max_set(it->base, mw, mh);
+
+ // Added by jh0506.yun for BEAT UX v3.0
+ edje_object_signal_callback_add(it->base, "clicked", "indicator_clicked", _indicator_clicked_cb, obj);
+
+ return it;
}
static void _layout(Evas_Object *o, Evas_Object_Box_Data *priv, void *data)
{
- Widget_Data *wd = data;
+ Widget_Data *wd = data;
- if (!wd)
- return;
- _els_box_layout(o, priv, 1, 0); /* making box layout non homogenous */
- return;
+ if (!wd)
+ return;
+
+ _els_box_layout(o, priv, 1, 0); /* making box layout non homogenous */
+ return;
}
/**
*
* @ingroup PageControl
*/
-
EAPI Evas_Object *
elm_page_control_add(Evas_Object *parent)
{
- Evas_Object *obj;
- Evas *e;
- Widget_Data *wd;
- const char *padding;
-
- wd = ELM_NEW(Widget_Data);
- e = evas_object_evas_get(parent);
- obj = elm_widget_add(e);
- elm_widget_type_set(obj, "page_control");
- elm_widget_sub_object_add(parent, obj);
- elm_widget_data_set(obj, wd);
- elm_widget_del_hook_set(obj, _del_hook);
- elm_widget_theme_hook_set(obj, _theme_hook);
-
- wd->base = edje_object_add(e);
- _elm_theme_object_set(obj, wd->base, "page_control", "base", "default");
- elm_widget_resize_object_set(obj, wd->base);
-
- edje_object_signal_callback_add(wd->base, "elm,state,indicator,click,left", "elm", _indicator_click_left, obj);
- edje_object_signal_callback_add(wd->base, "elm,state,indicator,click,right", "elm", _indicator_click_right, obj);
-
- wd->scale_factor = elm_scale_get();
- if ( wd->scale_factor == 0.0 ) {
- wd->scale_factor = 1.0;
- }
- padding = edje_object_data_get(wd->base, "padding");
+ Evas_Object *obj;
+ Evas *e;
+ Widget_Data *wd;
+ const char *padding;
- if(padding)
- wd->padding = (int) (atoi(padding));
- else
- wd->padding == PADDING;
- wd->hbox = evas_object_box_add(e);
- evas_object_box_padding_set(wd->hbox, wd->padding, 0);
- evas_object_size_hint_weight_set(wd->hbox, 0, 0);
+ wd = ELM_NEW(Widget_Data);
+ e = evas_object_evas_get(parent);
+ obj = elm_widget_add(e);
+ elm_widget_type_set(obj, "page_control");
+ elm_widget_sub_object_add(parent, obj);
+ elm_widget_data_set(obj, wd);
+ elm_widget_del_hook_set(obj, _del_hook);
+ elm_widget_theme_hook_set(obj, _theme_hook);
+
+ wd->base = edje_object_add(e);
+ _elm_theme_object_set(obj, wd->base, "page_control", "base", "default");
+ elm_widget_resize_object_set(obj, wd->base);
+
+ edje_object_signal_callback_add(wd->base, "elm,state,indicator,click,left", "elm", _indicator_click_left, obj);
+ edje_object_signal_callback_add(wd->base, "elm,state,indicator,click,right", "elm", _indicator_click_right, obj);
- evas_object_box_layout_set(wd->hbox, _layout, wd, NULL);
- elm_widget_sub_object_add(obj, wd->hbox);
+ wd->scale_factor = elm_scale_get();
+ if ( wd->scale_factor == 0.0 )
+ {
+ wd->scale_factor = 1.0;
+ }
+ padding = edje_object_data_get(wd->base, "padding");
- edje_object_part_swallow(wd->base, "elm.swallow.page", wd->hbox);
+ if(padding)
+ wd->padding = (int) (atoi(padding));
+ else
+ wd->padding == PADDING;
- evas_object_show(wd->hbox);
+ wd->hbox = evas_object_box_add(e);
+ evas_object_box_padding_set(wd->hbox, wd->padding, 0);
+ evas_object_size_hint_weight_set(wd->hbox, 0, 0);
- wd->parent = parent;
+ evas_object_box_layout_set(wd->hbox, _layout, wd, NULL);
+ elm_widget_sub_object_add(obj, wd->hbox);
- wd->page_count = 0;
- wd->cur_page_id = 0;
+ edje_object_part_swallow(wd->base, "elm.swallow.page", wd->hbox);
- _sizing_eval(obj);
+ evas_object_show(wd->hbox);
- return obj;
+ wd->parent = parent;
+
+ wd->page_count = 0;
+ wd->cur_page_id = 0;
+
+ _sizing_eval(obj);
+
+ return obj;
}
/**
*/
EAPI void elm_page_control_page_count_set(Evas_Object *obj, unsigned int page_count)
{
- Widget_Data *wd = elm_widget_data_get(obj);
- if (!wd)
- return;
- if (!page_count)
- return;
-
- Evas_Object *controller;
- Page_Item *it;
- Evas_Coord mw, mh;
-
- int i = 0;
- for (i = 0; i < page_count; i++)
- {
- it = _create_item(obj, i);
- wd->page_list = eina_list_append(wd->page_list, it);
- if (i == 0)
- {
- edje_object_signal_emit(it->base, "elm,state,indicator,on", "elm");
- evas_object_geometry_get(it->base, NULL, NULL, &mw, &mh);
- }
-
- evas_object_show(it->base);
-
- evas_object_box_append(wd->hbox, it->base);
- evas_object_smart_calculate(wd->hbox);
-
- }
- int width = (mw+wd->padding)*page_count+mw;
- evas_object_resize(wd->hbox, width, mh);
- evas_object_size_hint_min_set(wd->hbox, width, mh);
- evas_object_size_hint_max_set(wd->hbox, width, mh);
+ Widget_Data *wd = elm_widget_data_get(obj);
+ if (!wd)
+ return;
+ if (!page_count)
+ return;
+
+ Evas_Object *controller;
+ Page_Item *it;
+ Evas_Coord mw, mh;
+
+ int i = 0;
+ for (i = 0; i < page_count; i++)
+ {
+ it = _create_item(obj, i);
+ wd->page_list = eina_list_append(wd->page_list, it);
+ if (i == 0)
+ {
+ edje_object_signal_emit(it->base, "elm,state,indicator,on", "elm");
+ evas_object_geometry_get(it->base, NULL, NULL, &mw, &mh);
+ }
+
+ evas_object_show(it->base);
+
+ evas_object_box_append(wd->hbox, it->base);
evas_object_smart_calculate(wd->hbox);
- wd->page_count = page_count;
+ }
+
+ int width = (mw+wd->padding)*page_count+mw;
+ evas_object_resize(wd->hbox, width, mh);
+ evas_object_size_hint_min_set(wd->hbox, width, mh);
+ evas_object_size_hint_max_set(wd->hbox, width, mh);
+ evas_object_smart_calculate(wd->hbox);
+ wd->page_count = page_count;
}
/**
EAPI
void elm_page_control_page_id_set(Evas_Object *obj, unsigned int page_id)
{
- Widget_Data *wd = elm_widget_data_get(obj);
- if (!wd) return;
+ Widget_Data *wd = elm_widget_data_get(obj);
+ if (!wd) return;
- if(page_id >= wd->page_count || page_id == wd->cur_page_id) return;
+ if(page_id >= wd->page_count || page_id == wd->cur_page_id) return;
- Page_Item *it;
- double cur_position = 0.0;
- it=_page_find(obj, wd->cur_page_id);
- if(!it) return;
+ Page_Item *it;
+ double cur_position = 0.0;
+ it=_page_find(obj, wd->cur_page_id);
+ if(!it) return;
- edje_object_signal_emit(it->base, "elm,state,indicator,off", "elm");
- it = _page_find(obj, page_id);
- if(!it) return;
+ edje_object_signal_emit(it->base, "elm,state,indicator,off", "elm");
+ it = _page_find(obj, page_id);
+ if(!it) return;
- edje_object_signal_emit(it->base, "elm,state,indicator,on", "elm");
- wd->cur_page_id=page_id;
+ edje_object_signal_emit(it->base, "elm,state,indicator,on", "elm");
+ wd->cur_page_id=page_id;
cur_position = ((double)wd->cur_page_id)/wd->page_count;
- edje_object_part_drag_value_set(wd->base, "elm.drag.part", cur_position,0);
+ edje_object_part_drag_value_set(wd->base, "elm.drag.part", cur_position,0);
}
/**
EAPI
unsigned int elm_page_control_page_id_get(Evas_Object *obj)
{
- Widget_Data *wd = elm_widget_data_get(obj);
- if (!wd) return;
+ Widget_Data *wd = elm_widget_data_get(obj);
+ if (!wd) return;
- return wd->cur_page_id;
+ return wd->cur_page_id;
}