Table example

In this example, we illustrate how to organize your objects on a table, using the edje_object_part_table functions.

To be easier to understand the objects in this example will be four simple rects, when the user click over one item with the left button its is removed from the table, if any other button was used all items are removed. For each action is printed a message with the current number of rows and columns.

We started creating an EDC file with one part of the type TABLE called "table_part", that is the part which we will refer to access the table:

collections {
group {
name: "example_table";
min: 50 50;
parts {
part {
name: "table_part";
type: TABLE;
description {
min: 50 50;
state: "default" 0.0;
rel1.relative: 0.0 0.0;
rel2.relative: 1.0 1.0;
}
}
}
}
}

On the other hand, in the C file we first create the rectangles and added a callback for mouse down, as you can see bellow:

_rects_create(Evas *evas, Evas_Object **rects, Evas_Object *edje_obj)
{
int i;
for (i = 0; i < 4; i++)
{
rects[i] = evas_object_rectangle_add(evas);
evas_object_size_hint_min_set(rects[i], 200, 200);
evas_object_size_hint_weight_set(rects[i], 1.0, 1.0);
evas_object_show(rects[i]);
_on_mouse_down, edje_obj);
}
}

With the objects created we have to pack them into the table, to do this, we just have to use the function edje_object_part_table_pack().

if (!edje_object_part_table_pack(edje_obj, "table_part", rects[0],
0, 0, 1, 2))
fprintf(stderr, "Cannot add the rectangle 1 to table\n");
if (!edje_object_part_table_pack(edje_obj, "table_part", rects[1],
0, 1, 1, 1))
fprintf(stderr, "Cannot add the rectangle 2 to table\n");
if (!edje_object_part_table_pack(edje_obj, "table_part", rects[2],
1, 0, 1, 1))
fprintf(stderr, "Cannot add the rectangle 3 to table\n");
if (!edje_object_part_table_pack(edje_obj, "table_part", rects[3],
1, 1, 1, 1))
fprintf(stderr, "Cannot add the rectangle 4 to table\n");

The other bit of code that is relevant to us now is our event handler for when the user click over the rectangle. Here we use the function edje_object_part_table_unpack() to remove the item from the table or edje_object_part_table_clear() to remove all items, it depends on which mouse button the user uses.

_on_mouse_down(void *data, Evas *evas EINA_UNUSED, Evas_Object *obj, void *event_info)
{
Evas_Object *edje_obj;
ev = (Evas_Event_Mouse_Down *)event_info;
edje_obj = (Evas_Object *)data;
if (ev->button != 1)
edje_object_part_table_clear(edje_obj, "table_part", EINA_TRUE);
else if (!edje_object_part_table_unpack(edje_obj, "table_part", obj))
fprintf(stderr, "Cannot remove the selected rectangle\n");
_columns_rows_print(edje_obj);
}

Finally, the last important thing in this example is about how to know how many columns and rows are there in the table, It should be noted that this function don't tell you how many items are there in the table, just the number of the columns and rows of the table.

}

The example's window should look like this picture:

edje-table-example.png

The full source code follows:

#ifdef HAVE_CONFIG_H
# include "config.h"
#else
# define EINA_UNUSED
#endif
#ifndef PACKAGE_DATA_DIR
#define PACKAGE_DATA_DIR "."
#endif
#include <Ecore.h>
#include <Ecore_Evas.h>
#include <Edje.h>
#define WIDTH (400)
#define HEIGHT (400)
static void
_on_delete(Ecore_Evas *ee EINA_UNUSED)
{
}
/* Try to get the number of columns and rows of the table
* and print them. */
static void
_columns_rows_print(Evas_Object *edje_obj)
{
int cols, rows;
if (edje_object_part_table_col_row_size_get(edje_obj, "table_part", &cols,
&rows))
printf("Number of columns: %d\nNumber of rows: %d\n", cols, rows);
else
fprintf(stderr, "Cannot get the number of columns and rows\n");
}
/* here just to keep our example's window size and table items
* size in synchrony. */
static void
_on_canvas_resize(Ecore_Evas *ee)
{
Evas_Object *edje_obj;
Evas_Object **rects;
int i;
int w;
int h;
bg = ecore_evas_data_get(ee, "background");
edje_obj = ecore_evas_data_get(ee, "edje_obj");
rects = ecore_evas_data_get(ee, "rects");
ecore_evas_geometry_get(ee, NULL, NULL, &w, &h);
evas_object_resize(bg, w, h);
evas_object_resize(edje_obj, w, h);
for (i = 0; i < 4; i++)
evas_object_size_hint_min_set(rects[i], w/2, h/2);
}
/* Mouse button 1 = remove the clicked item
* any other button = remove all items. */
static void
_on_mouse_down(void *data, Evas *evas EINA_UNUSED, Evas_Object *obj, void *event_info)
{
Evas_Object *edje_obj;
ev = (Evas_Event_Mouse_Down *)event_info;
edje_obj = (Evas_Object *)data;
if (ev->button != 1)
edje_object_part_table_clear(edje_obj, "table_part", EINA_TRUE);
else if (!edje_object_part_table_unpack(edje_obj, "table_part", obj))
fprintf(stderr, "Cannot remove the selected rectangle\n");
_columns_rows_print(edje_obj);
}
static void
_rects_create(Evas *evas, Evas_Object **rects, Evas_Object *edje_obj)
{
int i;
for (i = 0; i < 4; i++)
{
rects[i] = evas_object_rectangle_add(evas);
evas_object_size_hint_min_set(rects[i], 200, 200);
evas_object_size_hint_weight_set(rects[i], 1.0, 1.0);
evas_object_show(rects[i]);
_on_mouse_down, edje_obj);
}
}
int
main(int argc EINA_UNUSED, char *argv[] EINA_UNUSED)
{
const char *edje_file = PACKAGE_DATA_DIR"/table.edj";
Ecore_Evas *ee;
Evas *evas;
Evas_Object *edje_obj;
Evas_Object *rects[4];
return EXIT_FAILURE;
if (!edje_init())
goto shutdown_ecore_evas;
/* this will give you a window with an Evas canvas under the first
* engine available */
ee = ecore_evas_new(NULL, 0, 0, WIDTH, HEIGHT, NULL);
if (!ee) goto shutdown_edje;
ecore_evas_callback_resize_set(ee, _on_canvas_resize);
ecore_evas_title_set(ee, "Edje Table Example");
evas = ecore_evas_get(ee);
evas_object_color_set(bg, 255, 255, 255, 255); /* white bg */
evas_object_move(bg, 0, 0); /* at canvas' origin */
evas_object_resize(bg, WIDTH, HEIGHT); /* covers full canvas */
ecore_evas_data_set(ee, "background", bg);
edje_obj = edje_object_add(evas);
edje_object_file_set(edje_obj, edje_file, "example_table");
evas_object_move(edje_obj, 0, 0); /* at canvas' origin */
evas_object_resize(edje_obj, WIDTH, HEIGHT);
evas_object_show(edje_obj);
ecore_evas_data_set(ee, "edje_obj", edje_obj);
_rects_create(evas, rects, edje_obj);
ecore_evas_data_set(ee, "rects", rects);
/* Colouring the rectangles */
evas_object_color_set(rects[0], 255, 0, 0, 255);
evas_object_color_set(rects[1], 0, 255, 0, 255);
evas_object_color_set(rects[2], 0, 0, 255, 255);
evas_object_color_set(rects[3], 128, 128, 128, 255);
/* Packing the rectangles into the table */
if (!edje_object_part_table_pack(edje_obj, "table_part", rects[0],
0, 0, 1, 2))
fprintf(stderr, "Cannot add the rectangle 1 to table\n");
if (!edje_object_part_table_pack(edje_obj, "table_part", rects[1],
0, 1, 1, 1))
fprintf(stderr, "Cannot add the rectangle 2 to table\n");
if (!edje_object_part_table_pack(edje_obj, "table_part", rects[2],
1, 0, 1, 1))
fprintf(stderr, "Cannot add the rectangle 3 to table\n");
if (!edje_object_part_table_pack(edje_obj, "table_part", rects[3],
1, 1, 1, 1))
fprintf(stderr, "Cannot add the rectangle 4 to table\n");
_columns_rows_print(edje_obj);
return EXIT_SUCCESS;
shutdown_edje:
shutdown_ecore_evas:
return EXIT_FAILURE;
}

To compile use this command:

* gcc -o edje-table edje-table.c -DPACKAGE_BIN_DIR=\"/Where/enlightenment/is/installed/bin\" -DPACKAGE_LIB_DIR=\"/Where/enlightenment/is/installed/lib\"
* -DPACKAGE_DATA_DIR=\"/Where/enlightenment/is/installed/share\"
* `pkg-config --cflags --libs evas ecore ecore-evas edje`
*
* edje_cc table.edc
*