efl/legacy/elementary/src/lib/elm_widget_segment_control.h

79 lines
2.5 KiB
C

#ifndef ELM_WIDGET_SEGMENT_CONTROL_H
#define ELM_WIDGET_SEGMENT_CONTROL_H
#include "Elementary.h"
/**
* @addtogroup Widget
* @{
*
* @section elm-segment-control-class The Elementary Segment control Class
*
* Elementary, besides having the @ref SegmentControl widget, exposes
* its foundation -- the Elementary Segment control Class -- in order
* to create other widgets which are a segment control with some more
* logic on top.
*/
/**
* Base layout smart data extended with segment control instance data.
*/
typedef struct _Elm_Segment_Control_Smart_Data Elm_Segment_Control_Smart_Data;
typedef struct _Elm_Segment_Item Elm_Segment_Item;
struct _Elm_Segment_Control_Smart_Data
{
Evas_Object *obj;
Eina_List *items;
Elm_Segment_Item *selected_item;
int item_width;
};
struct _Elm_Segment_Item
{
ELM_WIDGET_ITEM;
Evas_Object *icon;
const char *label;
int seg_index;
};
/**
* @}
*/
#define ELM_SEGMENT_CONTROL_DATA_GET(o, sd) \
Elm_Segment_Control_Smart_Data * sd = eo_data_scope_get(o, ELM_OBJ_SEGMENT_CONTROL_CLASS)
#define ELM_SEGMENT_CONTROL_DATA_GET_OR_RETURN(o, ptr) \
ELM_SEGMENT_CONTROL_DATA_GET(o, ptr); \
if (!ptr) \
{ \
CRITICAL("No widget data for object %p (%s)", \
o, evas_object_type_get(o)); \
return; \
}
#define ELM_SEGMENT_CONTROL_DATA_GET_OR_RETURN_VAL(o, ptr, val) \
ELM_SEGMENT_CONTROL_DATA_GET(o, ptr); \
if (!ptr) \
{ \
CRITICAL("No widget data for object %p (%s)", \
o, evas_object_type_get(o)); \
return val; \
}
#define ELM_SEGMENT_CONTROL_CHECK(obj) \
if (!eo_isa((obj), ELM_OBJ_SEGMENT_CONTROL_CLASS)) \
return
#define ELM_SEGMENT_CONTROL_ITEM_CHECK(it) \
ELM_WIDGET_ITEM_CHECK_OR_RETURN((Elm_Widget_Item *)it, ); \
ELM_SEGMENT_CONTROL_CHECK(it->base.widget);
#define ELM_SEGMENT_CONTROL_ITEM_CHECK_OR_RETURN(it, ...) \
ELM_WIDGET_ITEM_CHECK_OR_RETURN((Elm_Widget_Item *)it, __VA_ARGS__); \
ELM_SEGMENT_CONTROL_CHECK(it->base.widget) __VA_ARGS__;
#endif