#include <Elementary.h>
typedef struct _Example_Item
{
const char *path;
} Example_Item;
static const char *imgs[9] =
{
"panel_01.jpg",
"plant_01.jpg",
"rock_01.jpg",
"rock_02.jpg",
"sky_01.jpg",
"sky_02.jpg",
"sky_03.jpg",
"sky_04.jpg",
"wood_01.jpg",
};
static void
_horizontal_grid(void *data,
{
}
static void
_always_select_change(void *data,
{
if (always)
else
printf("\"Always select\" mode for gengrid items is now %s\n",
always ? "on" : "off");
}
static void
_bouncing_change(void *data,
{
printf("Bouncing effect for gengrid is now %s\n",
bounce ? "on" : "off");
}
static void
_multi_change(void *data,
{
elm_gengrid_multi_select_set(grid, multi);
printf("Multi-selection for gengrid is now %s\n",
multi ? "on" : "off");
if (!multi)
{
const Eina_List *selected = elm_gengrid_selected_items_get(grid), *l;
}
}
static void
_no_sel_change(void *data,
{
if (no_sel)
else
printf("Selection for gengrid items is now %s\n",
no_sel ? "disabled" : "enabled");
}
static void
_grid_sel(void *data,
void *event_info)
{
unsigned int x, y;
printf("Item [%p], with data [%p], path %s, at position (%u, %u),"
" has been selected\n", event_info, data, it->path, x, y);
}
static Example_Item *
_item_new(void)
{
Example_Item *it;
it = malloc(sizeof(*it));
sizeof(imgs[0]))]);
return it;
}
static void
_before_bt_clicked(void *data,
{
Example_Item *it;
sel = elm_gengrid_selected_item_get(grid);
if (!sel)
return;
it = _item_new();
elm_gengrid_item_insert_before(grid, gic, it, sel, _grid_sel, NULL);
}
static void
_after_bt_clicked(void *data,
{
Example_Item *it;
sel = elm_gengrid_selected_item_get(grid);
if (!sel)
return;
it = _item_new();
elm_gengrid_item_insert_after(grid, gic, it, sel, _grid_sel, NULL);
}
static void
_prepend_bt_clicked(void *data,
{
Example_Item *it;
it = _item_new();
elm_gengrid_item_prepend(grid, gic, it, _grid_sel, NULL);
}
static void
_append_bt_clicked(void *data,
{
Example_Item *it = _item_new();
elm_gengrid_item_append(grid, gic, it, _grid_sel, NULL);
}
static void
_clear_cb(void *data,
{
elm_gengrid_clear(data);
printf("Clearing the grid!\n");
}
static void
_bring_1st_clicked(void *data,
{
if (!gg_it) return;
}
static void
_show_last_clicked(void *data,
{
if (!gg_it) return;
}
static void
_toggle_disabled_cb(void *data,
{
if (!gg_it) return;
}
static void
_size_changed(void *data,
{
elm_gengrid_item_size_set(grid, size, size);
}
static void
void *event_info)
{
printf("Double click on item with handle %p\n", event_info);
}
static void
void *event_info)
{
printf("Long press on item with handle %p\n", event_info);
}
static char *
_grid_label_get(void *data,
{
const Example_Item *it = data;
char buf[256];
snprintf(buf, sizeof(buf), "Photo %s", it->path);
return strdup(buf);
}
_grid_content_get(void *data,
const char *part)
{
const Example_Item *it = data;
if (!strcmp(part, "elm.swallow.icon"))
{
char buf[PATH_MAX];
it->path);
1);
return icon;
}
else if (!strcmp(part, "elm.swallow.end"))
{
return ck;
}
return NULL;
}
{
}
static void
_grid_del(void *data,
{
Example_Item *it = data;
free(it);
}
static void
{
int h_pagenumber = 0, v_pagenumber = 0;
printf("Grid current horiz page is %d, vert page is %d\n",
h_pagenumber, v_pagenumber);
}
static void
_h_align_change_cb(void *data,
{
double v_align;
elm_gengrid_align_get(data, NULL, &v_align);
printf("Setting horizontal alignment to %f\n", val);
elm_gengrid_align_set(data, val, v_align);
}
static void
_v_align_change_cb(void *data,
{
double h_align;
elm_gengrid_align_get(data, &h_align, NULL);
printf("Setting vertical alignment to %f\n", val);
elm_gengrid_align_set(data, h_align, val);
}
static void
_page_change_cb(void *data,
{
printf("Setting grid page's relative size to %f\n", val);
}
EAPI_MAIN int
{
Evas_Object *win, *grid, *bx, *hbx_1, *hbx_2, *hbx_3, *bt, *ck, *sl, *sp;
double h, v;
srand(time(NULL));
elm_gengrid_item_size_set(grid, 150, 150);
elm_box_pack_end(bx, grid);
elm_box_pack_end(bx, hbx_1);
elm_object_text_set(bt, "Append");
elm_box_pack_end(hbx_1, bt);
elm_object_text_set(bt, "Prepend");
elm_box_pack_end(hbx_1, bt);
elm_object_text_set(before_bt, "Insert before");
grid);
elm_box_pack_end(hbx_1, before_bt);
elm_object_text_set(after_bt, "Insert after");
elm_box_pack_end(hbx_1, after_bt);
elm_object_text_set(bt, "Clear");
elm_box_pack_end(hbx_1, bt);
elm_object_text_set(bt, "Bring in 1st");
elm_box_pack_end(hbx_1, bt);
elm_object_text_set(bt, "Show last");
elm_box_pack_end(hbx_1, bt);
elm_spinner_label_format_set(sp, "Item size: %.0f");
elm_box_pack_end(hbx_1, sp);
elm_box_pack_end(bx, hbx_2);
elm_object_text_set(bt, "Disable item");
elm_box_pack_end(hbx_2, bt);
elm_object_text_set(ck, "Horizontal mode");
elm_box_pack_end(hbx_2, ck);
elm_object_text_set(ck, "Always select");
elm_box_pack_end(hbx_2, ck);
elm_object_text_set(ck, "Bouncing");
elm_box_pack_end(hbx_2, ck);
elm_object_text_set(ck, "Multi-selection");
elm_box_pack_end(hbx_2, ck);
elm_object_text_set(ck, "No selection");
elm_box_pack_end(hbx_2, ck);
elm_box_pack_end(bx, hbx_3);
elm_gengrid_align_get(grid, &h, &v);
elm_object_text_set(sl, "Horiz. alignment");
elm_box_pack_end(hbx_3, sl);
elm_object_text_set(sl, "Vert. alignment");
elm_box_pack_end(hbx_3, sl);
elm_gengrid_align_get(grid, &h, &v);
elm_object_text_set(sl, "Page rel. size");
elm_box_pack_end(hbx_3, sl);
_page_change_cb(grid, sl, NULL);
if (!gic)
{
}
_append_bt_clicked(grid, NULL, NULL);
_append_bt_clicked(grid, NULL, NULL);
_append_bt_clicked(grid, NULL, NULL);
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:292
@ EVAS_ASPECT_CONTROL_VERTICAL
Use all vertical container space to place an object, using the given aspect.
Definition: Evas_Common.h:372
#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:293
#define EINA_LIST_FOREACH(list, l, _data)
Definition for the macro to iterate over a list.
Definition: eina_list.h:1415
void eina_stringshare_del(Eina_Stringshare *str)
Notes that the given string has lost an instance.
Definition: eina_stringshare.c:533
Eina_Stringshare * eina_stringshare_add(const char *str)
Retrieves an instance of a string for use in a program.
Definition: eina_stringshare.c:606
#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
unsigned char Eina_Bool
Type to mimic a boolean.
Definition: eina_types.h:527
#define EINA_UNUSED
Used to indicate that a function parameter is purposely unused.
Definition: eina_types.h:339
void elm_app_info_set(void *mainfunc, const char *dom, const char *checkfile)
Re-locate the application somewhere else after compilation, if the developer wishes for easier distri...
Definition: elm_main.c:496
const char * elm_app_data_dir_get(void)
Get the application's run time data prefix directory, as set by elm_app_info_set() and the way (envir...
Definition: elm_main.c:586
Eina_Bool elm_bg_file_set(Eo *obj, const char *file, const char *group)
Sets the file (image or edje collection) to give life for the background.
Definition: efl_ui_bg.c:188
Evas_Object * elm_bg_add(Evas_Object *parent)
Adds a new background to the parent.
Definition: efl_ui_bg.c:300
Evas_Object * elm_box_add(Evas_Object *parent)
Add a new box to the parent.
Definition: elm_box.c:363
Eina_Bool elm_check_state_get(const Evas_Object *obj)
Get the state of the check object.
Definition: efl_ui_check.c:381
Evas_Object * elm_check_add(Evas_Object *parent)
Add a new Check object.
Definition: efl_ui_check.c:536
void elm_check_state_set(Evas_Object *obj, Eina_Bool state)
Set the on/off state of the check object.
Definition: efl_ui_check.c:372
Eo Elm_Object_Item
An Elementary Object item handle.
Definition: elm_object_item.h:6
void elm_object_item_disabled_set(Elm_Widget_Item *obj, Eina_Bool disable)
Control the disabled state of a widget item.
Definition: elm_widget_item_eo.legacy.c:111
void * elm_object_item_data_get(const Elm_Object_Item *it)
Get the data associated with an object item.
Definition: efl_ui_widget.c:3803
#define ELM_MAIN()
macro to be used after the elm_main() function
Definition: elm_general.h:528
void elm_object_disabled_set(Evas_Object *obj, Eina_Bool disabled)
Set the disabled state of an Elementary object.
Definition: elm_main.c:1618
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_run(void)
Run Elementary's main loop.
Definition: elm_main.c:1362
@ ELM_GENGRID_ITEM_SCROLLTO_IN
To the nearest viewport.
Definition: elm_general.h:397
@ ELM_POLICY_QUIT_LAST_WINDOW_CLOSED
quit when the application's last window is closed
Definition: elm_general.h:248
@ ELM_OBJECT_SELECT_MODE_NONE
no select mode.
Definition: elm_general.h:43
@ ELM_OBJECT_SELECT_MODE_DEFAULT
default select mode.
Definition: elm_general.h:34
@ ELM_OBJECT_SELECT_MODE_ALWAYS
always select mode.
Definition: elm_general.h:39
@ ELM_POLICY_QUIT
under which circumstances the application should quit automatically.
Definition: elm_general.h:227
Evas_Object * elm_gengrid_add(Evas_Object *parent)
Add a new gengrid widget to the given parent Elementary (container) object.
Definition: elm_gengrid.c:4238
Elm_Gengrid_Item_Class * elm_gengrid_item_class_new(void)
Add a new gengrid item class in a given gengrid widget.
Definition: elm_gengrid.c:5393
void elm_gengrid_item_pos_get(const Elm_Object_Item *it, unsigned int *x, unsigned int *y)
Get a given gengrid item's position, relative to the whole gengrid's grid area.
Definition: elm_gengrid_item_eo.legacy.c:39
Evas_Object * elm_slider_add(Evas_Object *parent)
Add a new slider widget to the given parent Elementary (container) object.
Definition: elm_slider.c:1437
double elm_slider_value_get(const Evas_Object *obj)
Get the value displayed by the slider.
Definition: elm_slider.c:1531
void elm_slider_value_set(Evas_Object *obj, double val)
Set the value the slider displays.
Definition: elm_slider.c:1517
void elm_slider_indicator_format_set(Evas_Object *obj, const char *indicator)
Set the format string for the indicator label.
Definition: elm_slider.c:1692
void elm_slider_span_size_set(Evas_Object *obj, Evas_Coord size)
Set the (exact) length of the bar region of a given slider widget.
Definition: elm_slider.c:1444
double elm_spinner_value_get(const Evas_Object *obj)
Control the value the spinner displays.
Definition: elm_spinner.c:1390
Evas_Object * elm_spinner_add(Evas_Object *parent)
Add a new spinner widget to the given parent Elementary (container) object.
Definition: elm_spinner.c:1353
void elm_spinner_min_max_set(Evas_Object *obj, double min, double max)
Control the minimum and maximum values for the spinner.
Definition: elm_spinner.c:1360
void elm_spinner_value_set(Evas_Object *obj, double val)
Control the value the spinner displays.
Definition: elm_spinner.c:1384
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:8992
void elm_win_autodel_set(Eo *obj, Eina_Bool autodel)
Set the window's autodel state.
Definition: efl_ui_win.c:6188
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:9576
void evas_object_show(Evas_Object *eo_obj)
Makes the given Evas object visible.
Definition: evas_object_main.c:1814
void evas_object_resize(Evas_Object *obj, Evas_Coord w, Evas_Coord h)
Changes the size of the given Evas object.
Definition: evas_object_main.c:1236
void evas_object_propagate_events_set(Efl_Canvas_Object *obj, Eina_Bool propagate)
Set whether events on a smart object's member should be propagated up to its parent.
Definition: efl_canvas_object_eo.legacy.c:63
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
void evas_object_size_hint_aspect_set(Evas_Object *obj, Evas_Aspect_Control aspect, Evas_Coord w, Evas_Coord h)
Sets the hints for an object's aspect ratio.
Definition: evas_object_main.c:2581
Efl_Canvas_Object Evas_Object
An Evas Object handle.
Definition: Evas_Common.h:180
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
Elm_Gen_Item_State_Get_Cb state_get
State fetching class function for genlist/gengrid item classes.
Definition: elm_gen.h:101
Elm_Gen_Item_Del_Cb del
Deletion class function for genlist/gengrid item classes.
Definition: elm_gen.h:102
Elm_Gen_Item_Content_Get_Cb content_get
Content fetching class function for genlist/gengrid item classes.
Definition: elm_gen.h:100
Elm_Gen_Item_Text_Get_Cb text_get
Text fetching class function for genlist/gengrid item classes.
Definition: elm_gen.h:99
Gengrid or Genlist item class definition.
Definition: elm_gen.h:109
Elm_Gen_Item_Class_Functions func
Set of callbacks.
Definition: elm_gen.h:126
const char * item_style
Name of the visual style to use for this item.
Definition: elm_gen.h:118