1 #include <Elementary.h>
5 * @defgroup SegmentControl SegmentControl
8 * SegmentControl object is a horizontal control made of multiple segments,
9 * each segment item functioning as a discrete button. A segmented control affords a compact means to group together a number of controls.
10 * A segmented control can display a title or an image. The UISegmentedControl object automatically resizes segment items to fit proportionally
11 * within their superview unless they have a specific width set. When you add and remove segments,
12 * you can request that the action be animated with sliding and fading effects.
14 typedef struct _Widget_Data Widget_Data;
20 Elm_Segment_Item *ani_it;
26 int max_height, w_pad, h_pad;
32 unsigned int def_color[4];
33 unsigned int press_color[4];
34 unsigned int sel_color[4];
37 struct _Elm_Segment_Item
42 Evas_Object *label_wd;
45 Eina_Bool delete_me : 1;
51 char **_split(const char *string, char *delim);
52 static void _mouse_down(void *data, Evas *evas, Evas_Object *obj, void *event_info);
53 static void _mouse_up(void *data, Evas *e, Evas_Object *obj, void *event_info);
54 static void _signal_segment_selected(void *data);
55 static void _signal_segment_on(void *data);
56 static void _signal_segment_off(void *data);
57 static void _theme_hook(Evas_Object *obj);
58 static void _item_free(Evas_Object *obj, Elm_Segment_Item *it);
59 static void _del_hook(Evas_Object *obj);
60 static void _layout(Evas_Object *o, Evas_Object_Box_Data *priv, void *data);
61 static void _segment_resizing(void *data, Evas *e, Evas_Object *obj, void *event_info);
62 static void _segment_item_resizing(void *data, Evas *e, Evas_Object *obj, void *event_info);
64 static void _object_resize(void *data, Evas *e, Evas_Object *obj, void *event_info);
66 static void _update_list(Evas_Object *obj);
67 static void _refresh_segment_ids(Evas_Object *obj);
68 static void _state_value_set(Evas_Object *obj);
69 static void _color_value_get(Evas_Object *obj);
71 static Elm_Segment_Item* _item_new(Evas_Object *obj, const char *label, Evas_Object *icon);
72 static Elm_Segment_Item *_item_find(Evas_Object *obj, unsigned int index);
74 static Eina_Bool _animator_animate_add_cb(void *data);
75 static Eina_Bool _animator_animate_del_cb(void *data);
78 _signal_segment_off(void *data)
80 Elm_Segment_Item *item = (Elm_Segment_Item *) data;
81 Widget_Data *wd = elm_widget_data_get(item->obj);
84 // item->sel = EINA_FALSE;
85 edje_object_signal_emit(item->base, "elm,action,unfocus", "elm");
86 edje_object_signal_emit(item->base, "elm,state,segment,release", "elm");
87 if(!item->label_wd && item->label)
88 edje_object_signal_emit(item->base, "elm,state,text,visible", "elm");
90 elm_label_text_color_set(item->label_wd, wd->def_color[0], wd->def_color[1], wd->def_color[2], wd->def_color[3]);
97 _signal_segment_on(void *data)
99 Elm_Segment_Item *item = (Elm_Segment_Item *) data;
100 Elm_Segment_Item *it;
103 Widget_Data *wd = elm_widget_data_get(item->obj);
106 // item->sel = EINA_TRUE;
107 if (item->segment_id == wd->cur_seg_id) return;
109 EINA_LIST_FOREACH(wd->seg_ctrl, l, it)
111 if (it->segment_id == wd->cur_seg_id)
113 _signal_segment_off (it);
116 edje_object_signal_emit(item->base, "elm,action,focus", "elm");
118 edje_object_signal_emit(item->base, "elm,state,text,change", "elm");
120 elm_label_text_color_set(item->label_wd, wd->sel_color[0],wd->sel_color[1], wd->sel_color[1], wd->sel_color[3]);
122 wd->cur_seg_id = item->segment_id;
123 evas_object_smart_callback_call(item->obj, "changed", (void*)wd->cur_seg_id);
129 _mouse_up(void *data, Evas *e, Evas_Object *obj, void *event_info)
131 Elm_Segment_Item *item = (Elm_Segment_Item *) data;
132 Widget_Data *wd = elm_widget_data_get(item->obj);
134 if (item->segment_id == wd->cur_seg_id)
137 edje_object_signal_emit(item->base, "elm,state,text,change", "elm");
138 // item->sel = EINA_TRUE;
141 _signal_segment_on((void*)item);
147 _mouse_down(void *data, Evas *evas, Evas_Object *obj, void *event_info)
149 Elm_Segment_Item *item = (Elm_Segment_Item *) data;
150 Widget_Data *wd = elm_widget_data_get(item->obj);
154 if(!item->label_wd && wd->cur_seg_id != item->segment_id)
156 edje_object_signal_emit(item->base, "elm,state,text,pressed", "elm");
158 if(item->label_wd && wd->cur_seg_id != item->segment_id)
159 elm_label_text_color_set(item->label_wd, wd->press_color[0], wd->press_color[1], wd->press_color[2], wd->press_color[3]);
161 edje_object_signal_emit(item->base, "elm,state,segment,press", "elm");
166 _theme_hook(Evas_Object *obj)
168 _elm_theme_object_set(obj, obj, "segmented-control", "base", elm_widget_style_get(obj));
174 _item_free(Evas_Object *obj, Elm_Segment_Item *it)
176 Widget_Data *wd = elm_widget_data_get(obj);
180 wd->seg_ctrl = eina_list_remove(wd->seg_ctrl, it);
182 if(it->icon) evas_object_del(it->icon);
185 evas_object_del(it->label_wd);
187 if (edje_object_part_swallow_get(it->base, "elm.swallow.label.content") == NULL)
189 edje_object_part_unswallow(it->base, it->label_wd);
192 if(it->base) evas_object_del(it->base);
193 if(it->label) eina_stringshare_del(it->label);
203 _del_hook(Evas_Object *obj)
205 Widget_Data *wd = elm_widget_data_get(obj);
206 Elm_Segment_Item *it;
207 Eina_List *l, *clear = NULL;
209 EINA_LIST_FOREACH(wd->seg_ctrl, l, it) clear = eina_list_append(clear, it);
210 EINA_LIST_FREE(clear, it) _item_free(obj, it);
220 _layout(Evas_Object *o, Evas_Object_Box_Data *priv, void *data)
222 Widget_Data *wd = data;
224 _els_box_layout(o, priv, 1, 0); /* making box layout non homogenous */
230 _segment_resizing(void *data, Evas *e, Evas_Object *obj, void *event_info)
232 Widget_Data *wd = elm_widget_data_get((Evas_Object *)data);
234 Evas_Coord w = 0, h = 0;
236 evas_object_geometry_get(wd->base, NULL, NULL, &w, &h);
237 wd->item_width = wd->width = w;
240 _state_value_set((Evas_Object *)data);
244 _object_resize(void *data, Evas *e, Evas_Object *obj, void *event_info)
248 wd = elm_widget_data_get((Evas_Object *)data);
251 ecore_job_add(_segment_resizing, (Evas_Object *)data);
256 _segment_item_resizing(void *data, Evas *e, Evas_Object *obj, void *event_info)
259 Elm_Segment_Item *it = (Elm_Segment_Item *)data;
260 wd = elm_widget_data_get(it->obj);
263 Evas_Coord w = 0, h = 0;
264 _update_list(it->obj);
266 evas_object_geometry_get(it->base, NULL, NULL, &w, &h);
268 if(wd->max_height == 1) wd->max_height = h;
272 elm_label_wrap_width_set(it->label_wd, w-wd->w_pad);
273 elm_label_wrap_height_set(it->label_wd, wd->max_height-wd->h_pad);
275 if (edje_object_part_swallow_get(it->base, "elm.swallow.label.content") == NULL)
277 edje_object_part_unswallow(it->base, it->label_wd);
279 edje_object_part_swallow(it->base, "elm.swallow.label.content", it->label_wd);
280 edje_object_signal_emit(it->base, "elm,state,label,visible", "elm");
281 if (it->segment_id == wd->cur_seg_id)
283 elm_label_text_color_set(it->label_wd, wd->sel_color[0], wd->sel_color[1], wd->sel_color[2], wd->sel_color[3]);
286 elm_label_text_color_set(it->label_wd, wd->def_color[0], wd->def_color[1], wd->def_color[2], wd->def_color[3]);
291 _object_item_resize(void *data, Evas *e, Evas_Object *obj, void *event_info)
293 ecore_job_add(_segment_item_resizing, (Evas_Object *)data);
297 static Elm_Segment_Item*
298 _item_new(Evas_Object *obj, const char *label, Evas_Object *icon)
300 Elm_Segment_Item *it;
302 Widget_Data *wd = elm_widget_data_get(obj);
303 if (!wd) return NULL;
305 it = calloc(1, sizeof( Elm_Segment_Item));
306 if (!it) return NULL;
308 if(obj) it->obj = obj;
309 it->delete_me = EINA_FALSE;
310 it->segment_id = wd->id;
312 // it->sel = EINA_FALSE;
314 it->base = edje_object_add(evas_object_evas_get(obj));
315 _elm_theme_object_set(obj, it->obj, "segment", "base/default", elm_object_style_get(it->obj));
317 if (it->label) eina_stringshare_del(it->label);
320 it->label = eina_stringshare_add(label);
323 if ((it->icon != icon) && (it->icon))
324 elm_widget_sub_object_del(obj, it->icon);
328 elm_widget_sub_object_add(obj, icon);
329 Evas_Coord minw = -1, minh = -1, maxw = -1, maxh = -1;
330 elm_coords_finger_size_adjust(1, &minw, 1, &minh);
331 elm_coords_finger_size_adjust(1, &minw, 1, &minh);
333 evas_object_size_hint_weight_set(it->base, 1.0, -1.0);
334 evas_object_size_hint_align_set(it->base, 1.0, -1.0);
335 evas_object_size_hint_min_set(it->base, -1, -1);
336 evas_object_size_hint_max_set(it->base, maxw, maxh);
339 edje_object_size_min_restricted_calc(obj, &mw, &mh, 0, 0);
340 evas_object_size_hint_weight_set(obj, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
341 evas_object_size_hint_align_set(obj, EVAS_HINT_FILL, EVAS_HINT_FILL);
348 _update_list(Evas_Object *obj)
350 Elm_Segment_Item *it = NULL;
351 Elm_Segment_Item *del_it = NULL;
352 Elm_Segment_Item *next_sel_it = NULL;
353 Elm_Segment_Item *seg_it;
357 Widget_Data *wd = elm_widget_data_get(obj);
360 wd->count = eina_list_count(wd->seg_ctrl);
363 it = _item_find(obj, 0);
364 _elm_theme_object_set(obj, it->base, "segment", "base/single", elm_object_style_get(it->obj));
\r
365 edje_object_signal_emit(it->base, "elm,state,segment,on", "elm");
366 if(it->label && !it->label_wd)
368 edje_object_signal_emit(it->base, "elm,state,text,change", "elm");
369 edje_object_part_text_set(it->base, "elm.text", it->label);
372 edje_object_signal_emit(it->base, "elm,state,text,hidden", "elm");
374 if (it->icon && edje_object_part_swallow_get(it->base, "elm.swallow.content") == NULL)
378 edje_object_part_swallow(it->base, "elm.swallow.content", it->icon);
379 edje_object_signal_emit(it->base, "elm,state,icon,visible", "elm");
382 edje_object_signal_emit(it->base, "elm,state,icon,hidden", "elm");
386 edje_object_signal_emit(it->base, "elm,state,label,visible", "elm");
387 elm_label_text_color_set(it->label_wd, wd->sel_color[0], wd->sel_color[1], wd->sel_color[2], wd->sel_color[3]);
393 EINA_LIST_FOREACH(wd->seg_ctrl, l, it)
397 _elm_theme_object_set(obj, it->base, "segment", "base/first", elm_object_style_get(it->obj));
399 else if(i==wd->count-1)
401 _elm_theme_object_set(obj, it->base, "segment", "base/last", elm_object_style_get(it->obj));
405 _elm_theme_object_set(obj, it->base, "segment", "base/default", elm_object_style_get(it->obj));
409 if(it->label && !it->label_wd)
411 edje_object_signal_emit(it->base, "elm,state,text,visible", "elm");
412 edje_object_part_text_set(it->base, "elm.text", it->label);
415 edje_object_signal_emit(it->base, "elm,state,text,hidden", "elm");
417 if (it->icon && edje_object_part_swallow_get(it->base, "elm.swallow.content") == NULL)
421 edje_object_part_swallow(it->base, "elm.swallow.content", it->icon);
422 edje_object_signal_emit(it->base, "elm,state,icon,visible", "elm");
425 edje_object_signal_emit(it->base, "elm,state,icon,hidden", "elm");
429 edje_object_signal_emit(it->base, "elm,state,label,visible", "elm");
436 EINA_LIST_FOREACH(wd->seg_ctrl, l, seg_it)
438 if(wd->del_index == 0)
442 next_sel_it = seg_it;
443 _signal_segment_on((void*)next_sel_it);
449 if (i == wd->del_index-1)
450 next_sel_it = seg_it;
451 if (i == wd->del_index)
459 if(next_sel_it && del_it && del_it->sel)
460 _signal_segment_on((void*)next_sel_it);
465 _refresh_segment_ids(Evas_Object *obj)
467 Elm_Segment_Item *it;
470 Widget_Data *wd = elm_widget_data_get(obj);
473 if ((wd->insert_index > 0) && wd->cur_seg_id >= wd->insert_index)
476 wd->insert_index = 0;
478 if (wd->del_index > 0)
480 if (wd->cur_seg_id >= wd->del_index)
485 EINA_LIST_FOREACH(wd->seg_ctrl, l, it)
493 _state_value_set(Evas_Object *obj)
495 Elm_Segment_Item *it;
497 Evas_Coord mw, mh, x, y;
501 Widget_Data *wd = elm_widget_data_get(obj);
504 count = eina_list_count(wd->seg_ctrl);
506 wd->item_width = wd->width/count;
509 evas_object_geometry_get(wd->ani_it->base, &x, &y, &w1, NULL);
510 if (wd->ani_it->delete_me)
512 w1-=(wd->item_width/5);
517 w1+=(wd->item_width/5);
518 if( w1 > wd->item_width )
521 w2 = (wd->width-w1)/(count -1);
526 EINA_LIST_FOREACH(wd->seg_ctrl, l, it)
528 edje_object_size_min_restricted_calc(it->base, &mw, &mh, 0, 0);
529 evas_object_size_hint_weight_set(it->base, 1.0, 1.0);
530 evas_object_size_hint_align_set(it->base, -1.0, -1.0);
533 if(wd->ani_it && it == wd->ani_it)
535 evas_object_resize(it->base, w1, wd->height);
536 evas_object_size_hint_min_set(it->base, w1, wd->height);
537 evas_object_size_hint_max_set(it->base, w1, wd->height);
541 evas_object_resize(it->base, w2, wd->height);
542 evas_object_size_hint_min_set(it->base, w2, wd->height);
543 evas_object_size_hint_max_set(it->base, w2, wd->height);
551 /* split string into tokens, return token array */
553 _split(const char *string, char *delim)
555 char **tokens = NULL;
556 char *working = NULL;
560 tokens = malloc(sizeof(char *) * MAXTOKENS);
563 working = malloc(sizeof(char) * strlen(string) + 1);
567 /* to make sure, copy string to a safe place */
568 strcpy(working, string);
569 for(idx = 0; idx < MAXTOKENS; idx++)
572 token = strtok(working, delim);
575 /* always keep the last entry NULL terminated */
576 while((idx < (MAXTOKENS - 1)) && (token != NULL)) {
577 tokens[idx] = malloc(sizeof(char) * strlen(token) + 1);
578 if(tokens[idx] != NULL) {
579 strcpy(tokens[idx], token);
581 token = strtok(NULL, delim);
589 static void _color_value_get(Evas_Object *obj)
591 Widget_Data *wd = (Widget_Data *)obj;
594 const char *def_color;
595 const char *press_color;
596 const char *sel_color;
599 char **tokens = NULL;
602 def_color = edje_object_data_get(wd->base, "def_rgb");
605 tokens = _split(def_color, delim);
606 for(i = 0; tokens[i] != NULL; i++)
608 if (tokens[i]) wd->def_color[i] = atoi(tokens[i]);
609 else wd->def_color[i] = 0xFF;
611 for(i = 0; tokens[i] != NULL; i++)
618 for(i = 0; i<(MAXTOKENS - 1); i++)
619 wd->def_color[i] = 0xFF;
621 press_color = edje_object_data_get(wd->base, "press_rgb");
624 tokens = _split(press_color, delim);
625 for(i = 0; tokens[i] != NULL; i++)
627 if (tokens[i]) wd->press_color[i] = atoi(tokens[i]);
628 else wd->press_color[i] = 0xFF;
630 for(i = 0; tokens[i] != NULL; i++)
637 for(i = 0; i<(MAXTOKENS - 1); i++)
638 wd->press_color[i] = 0xFF;
641 sel_color = edje_object_data_get(wd->base, "sel_rgb");
644 tokens = _split(sel_color, delim);
645 for(i = 0; tokens[i] != NULL; i++)
647 if (tokens[i]) wd->sel_color[i] = atoi(tokens[i]);
648 else wd->sel_color[i] = 0xFF;
650 for(i = 0; tokens[i] != NULL; i++)
658 for(i = 0; i<(MAXTOKENS - 1); i++)
659 wd->sel_color[i] = 0xFF;
664 _animator_animate_add_cb(void *data)
667 Evas_Object *obj = (Evas_Object *)data;
668 Widget_Data *wd = elm_widget_data_get(obj);
671 evas_object_geometry_get(wd->ani_it->base, NULL, NULL, &w, NULL);
672 if( w < wd->item_width )
674 _state_value_set(obj);
675 evas_object_geometry_get(wd->ani_it->base, NULL, NULL, &w, NULL);
676 return ECORE_CALLBACK_RENEW;
680 ecore_animator_del(wd->ani);
683 return ECORE_CALLBACK_CANCEL;
689 _animator_animate_del_cb(void *data)
692 Evas_Object *obj = (Evas_Object *)data;
693 Widget_Data *wd = elm_widget_data_get(obj);
696 evas_object_geometry_get(wd->ani_it->base, NULL, NULL, &w, NULL);
699 _state_value_set(obj);
700 evas_object_geometry_get(wd->ani_it->base, NULL, NULL, &w, NULL);
701 return ECORE_CALLBACK_RENEW;
705 _item_free(obj, wd->ani_it );
706 _refresh_segment_ids(obj);
707 ecore_animator_del(wd->ani);
711 wd->id = eina_list_count(wd->seg_ctrl);
712 return ECORE_CALLBACK_CANCEL;
716 static Elm_Segment_Item *
717 _item_find(Evas_Object *obj, unsigned int index)
719 Elm_Segment_Item *it;
722 Widget_Data *wd = elm_widget_data_get(obj);
723 if (!wd) return NULL;
725 EINA_LIST_FOREACH(wd->seg_ctrl, l, it)
727 if (i == index) return it;
734 * Add a new segmentcontrol to the parent
735 * @param parent The parent object
736 * @return The new object or NULL if it cannot be created
738 * @ingroup SegmentControl SegmentControl
741 elm_segment_control_add(Evas_Object *parent)
747 const char *deffont, *maxheight, *wpad, *hpad;
749 wd = ELM_NEW(Widget_Data);
750 e = evas_object_evas_get(parent);
752 obj = elm_widget_add(e);
753 elm_widget_type_set(obj, "segmented-control");
754 elm_widget_sub_object_add(parent, obj);
755 elm_widget_data_set(obj, wd);
756 elm_widget_del_hook_set(obj, _del_hook);
757 elm_widget_theme_hook_set(obj, _theme_hook);
759 wd->base = edje_object_add(e);
760 _elm_theme_object_set(obj, wd->base, "segmented-control", "base", "default");
761 elm_widget_resize_object_set(obj, wd->base);
762 wd->box = evas_object_box_add(e);
763 evas_object_box_layout_set(wd->box, _layout, wd, NULL);
764 elm_widget_sub_object_add(obj, wd->box);
765 edje_object_part_swallow(wd->base, "elm.swallow.content", wd->box);
766 evas_object_show(wd->box);
768 evas_object_event_callback_add(obj, EVAS_CALLBACK_RESIZE, _segment_resizing, obj);
771 wd->insert_index = -1;
774 deffont = edje_object_data_get(wd->base, "default_font_size");
775 if (deffont) wd->cur_fontsize = atoi(deffont);
776 else wd->cur_fontsize = 1;
778 maxheight = edje_object_data_get(wd->base, "max_height");
779 if (maxheight) wd->max_height = atoi(maxheight);
780 else wd->max_height = 1;
782 wpad = edje_object_data_get(wd->base, "w_pad");
783 if (wpad) wd->w_pad = atoi(wpad);
786 hpad = edje_object_data_get(wd->base, "h_pad");
787 if (hpad) wd->h_pad = atoi(hpad);
790 _color_value_get((Evas_Object *)wd);
795 EAPI Elm_Segment_Item *
796 elm_segment_control_item_add(Evas_Object *obj, Evas_Object *icon, const char *label, Eina_Bool animate)
798 Elm_Segment_Item *it;
799 Widget_Data *wd = elm_widget_data_get(obj);
802 it = _item_new(obj, label, icon);
805 wd->seg_ctrl = eina_list_append(wd->seg_ctrl, it);
806 wd->id = eina_list_count(wd->seg_ctrl);
808 evas_object_event_callback_add(it->base, EVAS_CALLBACK_MOUSE_DOWN, _mouse_down, it);
809 evas_object_event_callback_add(it->base, EVAS_CALLBACK_MOUSE_UP, _mouse_up, it);
810 evas_object_event_callback_add(it->base, EVAS_CALLBACK_RESIZE, _segment_item_resizing, it);
811 wd->insert_index = -1;
813 _refresh_segment_ids(obj);
815 if(animate && it->segment_id && wd->ani_it == NULL)
817 evas_object_resize(it->base, 1, wd->height);
819 wd->ani = ecore_animator_add( _animator_animate_add_cb, obj );
823 _state_value_set(obj);
826 evas_object_show( it->base);
828 evas_object_box_append(wd->box, it->base);
829 evas_object_smart_calculate(wd->box);
835 * Add a new segment item to segmentcontrol
836 * @param obj The SegmentControl object
837 * @param icon The icon object for added segment item
838 * @param label The label for added segment item
839 * @param animate If EINA_TRUE the action be animated with sliding effects default EINA_FALSE.
840 * @return The new segment item or NULL if it cannot be created
842 * @ingroup SegmentControl SegmentControl
844 EAPI Elm_Segment_Item *
845 elm_segment_control_add_segment(Evas_Object *obj, Evas_Object *icon, const char *label, Eina_Bool animate)
847 Elm_Segment_Item * it;
848 it = elm_segment_control_item_add(obj, icon, label, animate);
853 EAPI Elm_Segment_Item *
854 elm_segment_control_item_insert_at(Evas_Object *obj, Evas_Object *icon, const char *label, unsigned int index, Eina_Bool animate)
856 Elm_Segment_Item *it, *it_rel;
857 Widget_Data *wd = elm_widget_data_get(obj);
860 it = _item_new(obj, label, icon);
861 it_rel = _item_find(obj, index);
864 wd->seg_ctrl = eina_list_append(wd->seg_ctrl, it);
868 if (!it) return NULL;
869 wd->seg_ctrl = eina_list_prepend_relative(wd->seg_ctrl, it, it_rel);
871 evas_object_event_callback_add(it->base, EVAS_CALLBACK_MOUSE_DOWN, _mouse_down, it);
872 evas_object_event_callback_add(it->base, EVAS_CALLBACK_MOUSE_UP, _mouse_up, it);
873 evas_object_event_callback_add(it->base, EVAS_CALLBACK_RESIZE, _segment_item_resizing, it);
874 wd->insert_index = index;
875 wd->id = eina_list_count(wd->seg_ctrl);
876 _refresh_segment_ids(obj);
878 if(animate && it->segment_id && wd->ani_it == NULL)
881 evas_object_resize(it->base, 1, wd->height);
882 wd->ani = ecore_animator_add( _animator_animate_add_cb, obj );
886 _state_value_set(obj);
890 evas_object_show( it->base);
892 if(index >= wd->id-1)
894 evas_object_box_append(wd->box, it->base);
898 evas_object_box_insert_at(wd->box, it->base, index);
901 evas_object_smart_calculate(wd->box);
906 * Insert a new segment item to segmentcontrol
907 * @param obj The SegmentControl object
908 * @param icon The icon object for added segment item
909 * @param label The label for added segment item
910 * @param index The position at which segment item to be inserted
911 * @param animate If 1EINA_TRUE the action be animated with sliding effects default EINA_FALSE.
912 * @return The new segment item or NULL if it cannot be created
914 * @ingroup SegmentControl SegmentControl
917 elm_segment_control_insert_segment_at(Evas_Object *obj, Evas_Object *icon, const char *label, unsigned int index, Eina_Bool animate)
919 Elm_Segment_Item *it;
920 it = elm_segment_control_item_insert_at(obj, icon, label, index, animate);
926 elm_segment_control_item_del(Evas_Object *obj, Elm_Segment_Item *item, Eina_Bool animate)
928 Elm_Segment_Item *it;
929 Widget_Data *wd = elm_widget_data_get(obj);
936 wd->del_index = it->segment_id;
937 if(animate && it->segment_id && wd->ani_it == NULL)
939 it->delete_me = EINA_TRUE;
941 wd->ani = ecore_animator_add( _animator_animate_del_cb, obj );
945 evas_object_box_remove(wd->box, it->base);
946 evas_object_smart_calculate(wd->box);
949 _refresh_segment_ids(obj);
950 _state_value_set(obj);
952 wd->id = eina_list_count(wd->seg_ctrl);
957 * Delete a segment item to segmentcontrol
958 * @param obj The SegmentControl object
959 * @param item The segment item to be deleted
960 * @param animate If EINA_TRUE the action be animated with sliding effects default EINA_FALSE.
962 * @ingroup SegmentControl SegmentControl
965 elm_segment_control_delete_segment(Evas_Object *obj, Elm_Segment_Item *item, Eina_Bool animate)
967 elm_segment_control_item_del(obj, item, animate);
973 elm_segment_control_item_del_at(Evas_Object *obj, unsigned int index, Eina_Bool animate)
975 Elm_Segment_Item *it;
976 Widget_Data *wd = elm_widget_data_get(obj);
979 it = _item_find(obj, index);
983 wd->del_index = index;
984 if(animate && it->segment_id)
986 if(wd->ani_it == NULL)
989 it->delete_me = EINA_TRUE;
990 wd->ani = ecore_animator_add( _animator_animate_del_cb, obj );
995 evas_object_box_remove(wd->box, it->base);
996 evas_object_smart_calculate(wd->box);
998 _refresh_segment_ids(obj);
999 _state_value_set(obj);
1001 wd->id = eina_list_count(wd->seg_ctrl);
1006 * Delete a segment item of given index to segmentcontrol
1007 * @param obj The SegmentControl object
1008 * @param index The position at which segment item to be deleted
1009 * @param animate If EINA_TRUE the action be animated with sliding effects default EINA_FALSE.
1011 * @ingroup SegmentControl SegmentControl
1014 elm_segment_control_delete_segment_at(Evas_Object *obj, unsigned int index, Eina_Bool animate)
1016 elm_segment_control_item_del_at( obj, index, animate);
1023 elm_segment_control_item_label_get(Evas_Object *obj, unsigned int index)
1025 Elm_Segment_Item *it_rel;
1026 Widget_Data *wd = elm_widget_data_get(obj);
1027 if(!wd) return NULL;
1029 it_rel = _item_find(obj, index);
1031 if(it_rel) return it_rel->label;
1037 * Get the label of a segment item of segmentcontrol
1038 * @param obj The SegmentControl object
1039 * @param index The index of the segment item
1040 * @return The label of the segment item
1042 * @ingroup SegmentControl SegmentControl
1045 elm_segment_control_get_segment_label_at(Evas_Object *obj, unsigned int index)
1048 label = elm_segment_control_item_label_get( obj, index);
1054 elm_segment_control_item_icon_get(Evas_Object *obj, unsigned int index)
1056 Elm_Segment_Item *seg_rel;
1057 Widget_Data *wd = elm_widget_data_get(obj);
1058 if(!wd) return NULL;
1060 seg_rel = _item_find(obj, index);
1062 if(seg_rel) return seg_rel->icon;
1068 * Get the icon of a segment item of segmentcontrol
1069 * @param obj The SegmentControl object
1070 * @param index The index of the segment item
1071 * @return The icon object or NULL if it is not found.
1073 * @ingroup SegmentControl SegmentControl
1076 elm_segment_control_get_segment_icon_at(Evas_Object *obj, unsigned int index)
1079 icon = elm_segment_control_item_icon_get( obj, index);
1084 EAPI Elm_Segment_Item *
1085 elm_segment_control_item_selected_get(const Evas_Object *obj)
1087 Elm_Segment_Item *it;
1089 Widget_Data *wd = elm_widget_data_get(obj);
1090 if(!wd || !wd->seg_ctrl) return NULL;
1092 EINA_LIST_FOREACH(wd->seg_ctrl, l, it)
1094 if(it->segment_id == wd->cur_seg_id)
1101 * Get the currently selected segment item of segmentcontrol
1102 * @param obj The SegmentControl object
1103 * @param value The Selected Segment id.
1104 * @return The selected Segment item
1106 * @ingroup SegmentControl SegmentControl
1108 EAPI Elm_Segment_Item *
1109 elm_segment_control_selected_segment_get(const Evas_Object *obj, int *value)
1111 Elm_Segment_Item *it;
1112 it = elm_segment_control_item_selected_get(obj);
1113 if(!it) return NULL;
1114 *value = it->segment_id;
1120 elm_segment_control_item_count_get(Evas_Object *obj)
1122 Widget_Data *wd = elm_widget_data_get(obj);
1129 * Get the count of segments of segmentcontrol
1130 * @param obj The SegmentControl object
1131 * @return The count of Segment items
1133 * @ingroup SegmentControl SegmentControl
1136 elm_segment_control_get_segment_count(Evas_Object *obj)
1139 id = elm_segment_control_item_count_get( obj);
1145 * Get the base object of segment item in segmentcontrol
1146 * @param it The Segment item
1147 * @return obj The base object of the segment item.
1149 * @ingroup SegmentControl SegmentControl
1152 elm_segment_control_item_object_get(Elm_Segment_Item *it)
1154 if (!it) return NULL;
1160 * Select/unselect a particular segment item of segmentcontrol
1161 * @param item The Segment item that is to be selected or unselected.
1162 * @param select If 1 the segment item is selected and if 0 it will be unselected.
1164 * @ingroup SegmentControl SegmentControl
1167 elm_segment_control_item_selected_set( Elm_Segment_Item *item, Eina_Bool select)
1170 Widget_Data *wd = elm_widget_data_get(item->obj);
1175 if(item->segment_id == wd->cur_seg_id && wd->cur_seg_id) return;
1176 // item->sel = EINA_TRUE;
1177 _signal_segment_on(item);
1179 else if(item->segment_id == wd->cur_seg_id)
1181 // item->sel = EINA_FALSE;
1182 wd->cur_seg_id = -1;
1183 _signal_segment_off(item);
1190 * Get a particular indexed segment item of segmentcontrol
1191 * @param obj The Segment control object.
1192 * @param index The index of the segment item.
1193 * @return The corresponding Segment item.
1195 * @ingroup SegmentControl SegmentControl
1197 EAPI Elm_Segment_Item *
1198 elm_segment_control_item_get_at(Evas_Object *obj, unsigned int index)
1200 Elm_Segment_Item *it;
1201 it = _item_find(obj, index);
1207 * Get the index of a Segment item of Segmentcontrol
1208 * @param item The Segment item.
1209 * @return The corresponding index of the Segment item.
1211 * @ingroup SegmentControl SegmentControl
1214 elm_segment_control_item_index_get(Elm_Segment_Item *item)
1216 if(!item) return -1;
1217 Widget_Data *wd = elm_widget_data_get(item->obj);
1220 return item->segment_id;
1224 * Set The Label widget to a Segment item of Segmentcontrol
1225 * @param item The Segment item.
1226 * @param label The Label.
1227 * @return Evas_Object The Label widget.
1229 * @ingroup SegmentControl SegmentControl
1232 elm_segment_control_item_label_object_set(Elm_Segment_Item *item, char *label)
1234 if(!item) return NULL;
1235 Widget_Data *wd = elm_widget_data_get(item->obj);
1236 if(!wd) return NULL;
1237 if(!label) return NULL;
1239 item->label_wd = elm_label_add(item->obj);
1240 elm_object_style_set(item->label_wd, "segment");
1241 elm_label_label_set(item->label_wd, label);
1242 elm_label_text_align_set(item->label_wd, "middle");
1243 elm_label_ellipsis_set(item->label_wd, 1);
1244 eina_stringshare_replace(&item->label, label);
1246 return item->label_wd;