1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
|
#ifndef ELM_WIDGET_DISKSELECTOR_H
#define ELM_WIDGET_DISKSELECTOR_H
#include "Elementary.h"
/* DO NOT USE THIS HEADER UNLESS YOU ARE PREPARED FOR BREAKING OF YOUR
* CODE. THIS IS ELEMENTARY'S INTERNAL WIDGET API (for now) AND IS NOT
* FINAL. CALL elm_widget_api_check(ELM_INTERNAL_API_VERSION) TO CHECK
* IT AT RUNTIME.
*/
/**
* @addtogroup Widget
* @{
*
* @section elm-diskselector-class The Elementary Diskselector Class
*
* Elementary, besides having the @ref Diskselector widget, exposes its
* foundation -- the Elementary Diskselector Class -- in order to create other
* widgets which are a diskselector with some more logic on top.
*/
/**
* Base widget smart data extended with diskselector instance data.
*/
typedef struct _Elm_Diskselector_Data Elm_Diskselector_Data;
typedef struct _Elm_Diskselector_Item_Data Elm_Diskselector_Item_Data;
struct _Elm_Diskselector_Data
{
Evas_Object *hit_rect;
Evas_Object *main_box;
Elm_Diskselector_Item_Data *selected_item;
Elm_Diskselector_Item_Data *first;
Elm_Diskselector_Item_Data *second;
Elm_Diskselector_Item_Data *s_last;
Elm_Diskselector_Item_Data *last;
Eina_List *items;
Eina_List *r_items;
Eina_List *over_items;
Eina_List *under_items;
Eina_List *left_blanks;
Eina_List *right_blanks;
Ecore_Idle_Enterer *scroller_move_idle_enterer; // idle enterer for scroller move
Ecore_Idle_Enterer *string_check_idle_enterer; // idle enterer for string check
int item_count, len_threshold, len_side,
display_item_num;
Evas_Coord minw, minh;
Eina_Bool init : 1;
Eina_Bool round : 1;
Eina_Bool display_item_num_by_api : 1;
Eina_Bool left_boundary_reached:1;
Eina_Bool right_boundary_reached:1;
};
struct _Elm_Diskselector_Item_Data
{
Elm_Widget_Item_Data *base;
Eina_List *node;
Evas_Object *icon;
const char *label;
Evas_Smart_Cb func;
};
/**
* @}
*/
#define ELM_DISKSELECTOR_DATA_GET(o, sd) \
Elm_Diskselector_Data * sd = efl_data_scope_get(o, ELM_DISKSELECTOR_CLASS)
#define ELM_DISKSELECTOR_DATA_GET_OR_RETURN(o, ptr) \
ELM_DISKSELECTOR_DATA_GET(o, ptr); \
if (EINA_UNLIKELY(!ptr)) \
{ \
ERR("No widget data for object %p (%s)", \
o, evas_object_type_get(o)); \
return; \
}
#define ELM_DISKSELECTOR_DATA_GET_OR_RETURN_VAL(o, ptr, val) \
ELM_DISKSELECTOR_DATA_GET(o, ptr); \
if (EINA_UNLIKELY(!ptr)) \
{ \
ERR("No widget data for object %p (%s)", \
o, evas_object_type_get(o)); \
return val; \
}
#define ELM_DISKSELECTOR_CHECK(obj) \
if (EINA_UNLIKELY(!efl_isa((obj), ELM_DISKSELECTOR_CLASS))) \
return
#define ELM_DISKSELECTOR_ITEM_CHECK(it) \
ELM_WIDGET_ITEM_CHECK_OR_RETURN(it->base, ); \
ELM_DISKSELECTOR_CHECK(it->base->widget);
#define ELM_DISKSELECTOR_ITEM_CHECK_OR_RETURN(it, ...) \
ELM_WIDGET_ITEM_CHECK_OR_RETURN(it->base, __VA_ARGS__); \
ELM_DISKSELECTOR_CHECK(it->base->widget) __VA_ARGS__;
#define ELM_DISKSELECTOR_ITEM_CHECK_OR_GOTO(it, label) \
ELM_WIDGET_ITEM_CHECK_OR_GOTO(it->base, label); \
if (!it->base->widget || !efl_isa((it->base->widget), ELM_DISKSELECTOR_CLASS)) \
goto label;
#define ELM_DISKSELECTOR_ITEM_DATA_GET(o, sd) \
Elm_Diskselector_Item_Data* sd = efl_data_scope_get(o, ELM_DISKSELECTOR_ITEM_CLASS)
#endif
|