#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 "image_blend_smooth_solid_same_scaled_capi.h" /* standard var */ static int done = 0; /* private data */ static efl::eina::list images; /* setup */ static void _setup(void) { evas::canvas canvas(::eo_ref(G_evas)); for (int i = 0; i < OBNUM; i++) { evas::image o(efl::eo::parent = canvas); images.push_back(o); eo_do(o._eo_ptr(), efl_file_set(build_path("image.png"), NULL)); // XXX o.smooth_scale_set(1); o.visibility_set(true); } done = 0; } /* cleanup */ static void _cleanup() { for (evas::image& i : images) i.parent_set(efl::eo::base(nullptr)); images.clear(); } /* loop - do things */ static void _loop(double t, int f) { int i = 0; for (evas::image& img : images) { Evas_Coord w0 = 80; Evas_Coord h0 = 80; Evas_Coord w = 40 + ((i % 3) * (w0 / 2)); Evas_Coord h = 40 + ((i % 3) * (h0 / 2)); Evas_Coord x = (win_w / 2) - (w / 2); x += sin((double)(f + (i * 13)) / (36.7 * SLOW)) * (w0 / 2); Evas_Coord y = (win_h / 2) - (h / 2); y += cos((double)(f + (i * 28)) / (43.8 * SLOW)) * (h0 / 2); img.evas::object::position_set(x, y); img.evas::object::size_set(w, h); img.fill_set(0, 0, w, h); ++i; } FPS_STD(NAME); } /* prepend special key handlers if interactive (before STD) */ static void _key(char *key) { KEY_STD; } extern "C" void FNAME(void) { ui_func_set(_key, _loop); _setup(); }