#ifdef HAVE_CONFIG_H # include #endif #include "Eo.h" #include "Evas.h" #include "Eo.hh" #include "Eina.hh" #include "Evas.hh" #include "main.h" #define EXPEDITE_CXX_TEST_IMPL #include /* standard var */ static int done = 0; /* private data */ static efl::eina::list images; /* setup */ static void _setup(void) { int i; Evas_Object *o; for (i = 0; i < (OBNUM / 2); i++) { o = eo_add(EVAS_IMAGE_CLASS, G_evas); images[i] = o; eo_do(o, efl_file_set(build_path("logo.png"), NULL), evas_obj_image_fill_set(0, 0, 120, 160), evas_obj_size_set(120, 160), evas_obj_visibility_set(EINA_TRUE)); } done = 0; } /* cleanup */ static void _cleanup(void) { int i; for (i = 0; i < (OBNUM / 2); i++) eo_del(images[i]); } /* loop - do things */ static void _loop(double t, int f) { int i; static Evas_Map *m = NULL; Evas_Coord x, y, w, h; if (!m) m = evas_map_new(4); for (i = 0; i < (OBNUM / 2); i++) { w = 120; h = 160; x = (win_w / 2) - (w / 2); x += sin((double)(f + (i * 13)) / (36.7 * SLOW)) * (w / 2); y = (win_h / 2) - (h / 2); y += cos((double)(f + (i * 28)) / (43.8 * SLOW)) * (h / 2); evas_map_util_points_populate_from_geometry(m, x, y, w, h, 0); evas_map_util_rotate(m, f, x + (w / 2), y + (h / 2)); eo_do(images[i], evas_obj_map_enable_set(1), evas_obj_map_set(m)); } FPS_STD(NAME); } /* prepend special key handlers if interactive (before STD) */ static void _key(char *key) { KEY_STD; } extern "C" void FNAME(void) { _setup(); ui_func_set(_key, _loop); }