#include <Elementary.h>
 
static int counter = 3;
 
static void
                void *event_info)
{
   printf("Selected Item %s\n", elm_object_item_text_get(it));
}
 
static void
{
   char label[32];
 
   snprintf(label, sizeof(label), "Item %i", counter++);
   ds_it = elm_diskselector_item_append(ds, label, NULL, NULL, NULL);
   if (!ds_it) printf("Error adding item\n");
}
 
static void
{
   char label[32];
 
   snprintf(label, sizeof(label), "Item %i", counter++);
 
   ds_it = elm_diskselector_item_append(ds, label, ic, NULL, NULL);
   if (!ds_it) printf("Error adding item with icon\n");
}
 
static void
{
   printf("Selected label: %s\n", elm_object_item_text_get(ds_it));
}
 
static void
{
   char label[32];
 
   snprintf(label, sizeof(label), "Item %i", counter++);
   ds_it = elm_diskselector_item_append(ds, label, NULL, _sel_cb, NULL);
   if (!ds_it) printf("Error adding item\n");
}
 
static void
{
   char *content = data;
   printf("Selected label: %s with data: %s\n",
          elm_object_item_text_get(ds_it), content);
}
 
static void
{
   free(data);
}
 
static void
{
   char label[32];
   char *content = malloc(sizeof(char) * 32);
 
   snprintf(content, 32, "Item content %i", counter);
   snprintf(label, sizeof(label), "Item %i", counter++);
   ds_it = elm_diskselector_item_append(ds, label, NULL, _sel_data_cb, content);
   if (!ds_it)
     {
        printf("Error adding item\n");
        return;
     }
}
 
static void
{
 
   selected_ds_it = elm_diskselector_selected_item_get(ds);
}
 
static void
{
 
   selected_ds_it = elm_diskselector_selected_item_get(ds);
   elm_diskselector_item_selected_set(selected_ds_it, 
EINA_FALSE);
}
 
static void
{
 
   items = elm_diskselector_items_get(ds);
     printf("%s\n", elm_object_item_text_get(ds_it));
}
 
static void
{
   elm_diskselector_clear(ds);
}
 
static void
{
 
   first_ds_it = elm_diskselector_first_item_get(ds);
   if (first_ds_it)
     elm_diskselector_item_selected_set(first_ds_it, 
EINA_TRUE);
}
 
static void
{
 
   last_ds_it = elm_diskselector_last_item_get(ds);
   if (last_ds_it)
     elm_diskselector_item_selected_set(last_ds_it, 
EINA_TRUE);
}
 
static void
{
 
   selected_ds_it = elm_diskselector_selected_item_get(ds);
   if (!selected_ds_it) return;
 
   next_ds_it = elm_diskselector_item_next_get(selected_ds_it);
   if (next_ds_it)
     elm_diskselector_item_selected_set(next_ds_it, 
EINA_TRUE);
}
 
static void
{
 
   selected_ds_it = elm_diskselector_selected_item_get(ds);
   if (!selected_ds_it) return;
 
   prev_ds_it = elm_diskselector_item_prev_get(selected_ds_it);
   if (prev_ds_it)
     elm_diskselector_item_selected_set(prev_ds_it, 
EINA_TRUE);
}
 
EAPI_MAIN int
{
 
 
 
 
 
   elm_diskselector_item_append(ds, "Item 0", NULL, NULL, NULL);
   elm_diskselector_item_append(ds, "Item 1", NULL, NULL, NULL);
   elm_diskselector_item_append(ds, "Item 2", NULL, NULL, NULL);
 
 
   elm_object_text_set(bt, "Append item");
 
   elm_object_text_set(bt, "Append with icon");
 
   elm_object_text_set(bt, "Append with selected function");
 
   elm_object_text_set(bt, "Append with data");
 
 
   elm_object_text_set(bt, "Delete item");
 
   elm_object_text_set(bt, "Unselect item");
 
   elm_object_text_set(bt, "Print items");
 
   elm_object_text_set(bt, "Clear");
 
 
   elm_object_text_set(bt, "Select first item");
 
   elm_object_text_set(bt, "Select last item");
 
   elm_object_text_set(bt, "Select next item");
 
   elm_object_text_set(bt, "Select previous item");
 
 
 
   return 0;
}
#define EVAS_HINT_EXPAND
Use with evas_object_size_hint_weight_set(), evas_object_size_hint_weight_get(), evas_object_size_hin...
Definition: Evas_Common.h:297
#define EVAS_HINT_FILL
Use with evas_object_size_hint_align_set(), evas_object_size_hint_align_get(), evas_object_size_hint_...
Definition: Evas_Common.h:298
#define EINA_LIST_FOREACH(list, l, _data)
Definition for the macro to iterate over a list.
Definition: eina_list.h:1415
#define EINA_TRUE
boolean value TRUE (numerical value 1)
Definition: eina_types.h:539
#define EINA_FALSE
boolean value FALSE (numerical value 0)
Definition: eina_types.h:533
#define EINA_UNUSED
Used to indicate that a function parameter is purposely unused.
Definition: eina_types.h:339
Evas_Object * elm_box_add(Evas_Object *parent)
Add a new box to the parent.
Definition: elm_box.c:363
void elm_box_horizontal_set(Elm_Box *obj, Eina_Bool horizontal)
Set the horizontal orientation.
Definition: elm_box_eo.legacy.c:27
void elm_box_pack_end(Elm_Box *obj, Efl_Canvas_Object *subobj)
Add an object at the end of the pack list.
Definition: elm_box_eo.legacy.c:57
Evas_Object * elm_diskselector_add(Evas_Object *parent)
Add a new diskselector widget to the given parent Elementary (container) object.
Definition: elm_diskselector.c:1408
Eo Elm_Object_Item
An Elementary Object item handle.
Definition: elm_object_item.h:6
void elm_object_item_del_cb_set(Elm_Widget_Item *obj, Evas_Smart_Cb del_cb)
Set the function to be called when an item from the widget is freed.
Definition: elm_widget_item_eo.legacy.c:231
#define ELM_MAIN()
macro to be used after the elm_main() function
Definition: elm_general.h:528
Eina_Bool elm_policy_set(unsigned int policy, int value)
Set a new policy's value (for a given policy group/identifier).
Definition: elm_main.c:1385
void elm_object_item_del(Eo *obj)
Delete the given item.
Definition: elm_main.c:2022
void elm_run(void)
Run Elementary's main loop.
Definition: elm_main.c:1362
@ ELM_POLICY_QUIT_LAST_WINDOW_CLOSED
quit when the application's last window is closed
Definition: elm_general.h:248
@ ELM_POLICY_QUIT
under which circumstances the application should quit automatically.
Definition: elm_general.h:227
Evas_Object * elm_icon_add(Evas_Object *parent)
Add a new icon object to the parent.
Definition: elm_icon.c:613
Eina_Bool elm_icon_standard_set(Evas_Object *obj, const char *name)
Set the icon by icon standards names.
Definition: elm_icon.c:885
void elm_win_resize_object_add(Eo *obj, Evas_Object *subobj)
Add subobj as a resize object of window obj.
Definition: efl_ui_win.c:8995
void elm_win_autodel_set(Eo *obj, Eina_Bool autodel)
Set the window's autodel state.
Definition: efl_ui_win.c:6189
Evas_Object * elm_win_util_standard_add(const char *name, const char *title)
Adds a window object with standard setup.
Definition: efl_ui_win.c:9579
void evas_object_show(Evas_Object *eo_obj)
Makes the given Evas object visible.
Definition: evas_object_main.c:1814
void evas_object_size_hint_weight_set(Evas_Object *obj, double x, double y)
Sets the hints for an object's weight.
Definition: evas_object_main.c:2638
void evas_object_size_hint_align_set(Evas_Object *obj, double x, double y)
Sets the hints for an object's alignment.
Definition: evas_object_main.c:2650
Efl_Canvas_Object Evas_Object
An Evas Object handle.
Definition: Evas_Common.h:185
void evas_object_smart_callback_add(Evas_Object *eo_obj, const char *event, Evas_Smart_Cb func, const void *data)
Add (register) a callback function to the smart event specified by event on the smart object obj.
Definition: evas_object_smart.c:1040
Type for a generic double linked list.
Definition: eina_list.h:318