cedric pushed a commit to branch master.

http://git.enlightenment.org/tools/expedite.git/commit/?id=6c2c96b622b3c7aa54d5f4de54dff057fe5f29e3

commit 6c2c96b622b3c7aa54d5f4de54dff057fe5f29e3
Author: Cedric BAIL <ced...@ddlm.me>
Date:   Wed May 8 17:53:54 2019 -0700

    add new test for stretchable zone support on image object.
---
 data/meson.build                    |   1 +
 data/stretch.png                    | Bin 0 -> 3972 bytes
 src/bin/image_blend_solid_stretch.c | 110 ++++++++++++++++++++++++++++++++++++
 src/bin/meson.build                 |   1 +
 src/bin/tests.h                     |   1 +
 5 files changed, 113 insertions(+)

diff --git a/data/meson.build b/data/meson.build
index 30925f9..c4daa22 100644
--- a/data/meson.build
+++ b/data/meson.build
@@ -17,6 +17,7 @@ files = [ 'Kochi.ttf',
        'image.png',
        'bar.png',
        'frame.png',
+       'stretch.png',
        'pan.png',
        'tp.png',
        'tp.yuv',
diff --git a/data/stretch.png b/data/stretch.png
new file mode 100644
index 0000000..7a420a1
Binary files /dev/null and b/data/stretch.png differ
diff --git a/src/bin/image_blend_solid_stretch.c 
b/src/bin/image_blend_solid_stretch.c
new file mode 100644
index 0000000..2d7c0d4
--- /dev/null
+++ b/src/bin/image_blend_solid_stretch.c
@@ -0,0 +1,110 @@
+#undef FNAME
+#undef NAME
+#undef ICON
+
+/* metadata */
+#define FNAME image_blend_solid_stretch_start
+#define NAME "Image Blend Solid Stretch"
+#define ICON "blend.png"
+
+#ifndef PROTO
+# ifndef UI
+#  include "main.h"
+
+/* standard var */
+static int done = 0;
+/* private data */
+static Evas_Object *o_images[OBNUM];
+
+// Each  offset is relative to the last block
+static const Efl_Gfx_Image_Stretch_Region hsz[] = { { 8, 8 }, { 16, 55 } };
+static const Efl_Gfx_Image_Stretch_Region vsz[] = { { 8, 8 }, { 16, 12 } };
+
+/* setup */
+static void _setup(void)
+{
+   int i;
+   Evas_Object *o;
+   for (i = 0; i < OBNUM; i++)
+     {
+        o = efl_add(EFL_CANVAS_IMAGE_CLASS, evas);
+        o_images[i] = o;
+        efl_file_simple_load(o, build_path("stretch.png"), NULL);
+        efl_gfx_image_stretch_region_set(o, EINA_C_ARRAY_ITERATOR_NEW(hsz),
+                                         EINA_C_ARRAY_ITERATOR_NEW(vsz));
+        efl_gfx_entity_visible_set(o, EINA_TRUE);
+     }
+   done = 0;
+}
+
+/* cleanup */
+static void _cleanup(void)
+{
+   int i;
+   for (i = 0; i < OBNUM; i++) efl_del(o_images[i]);
+}
+
+/* loop - do things */
+static void _loop(double t, int f)
+{
+   int i;
+   Evas_Coord x, y, w, h, w0, h0;
+   static int done = 0;
+   for (i = 0; i < OBNUM; i++)
+     {
+        w0 = 80;
+        h0 = 80;
+        w = 5 + ((1.0 + cos((double)(f + (i * 10)) / (7.4 * SLOW))) * w0 * 2);
+        h = 5 + ((1.0 + sin((double)(f + (i * 19)) / (12.6 * SLOW))) * w0 * 2);
+        x = (win_w / 2) - (w / 2);
+        x += sin((double)(f + (i * 13)) / (36.7 * SLOW)) * (w0 / 2);
+        y = (win_h / 2) - (h / 2);
+        y += cos((double)(f + (i * 28)) / (43.8 * SLOW)) * (h0 / 2);
+        efl_gfx_entity_position_set(o_images[i], EINA_POSITION2D(x, y));
+        efl_gfx_entity_size_set(o_images[i], EINA_SIZE2D(w, h));
+        efl_gfx_fill_set(o_images[i], EINA_RECT(0, 0, w, h));
+     }
+   FPS_STD(NAME);
+}
+
+/* prepend special key handlers if interactive (before STD) */
+static void _key(const char *key)
+{
+   KEY_STD;
+}
+
+
+
+
+
+
+
+
+
+
+
+
+/* template stuff - ignore */
+# endif
+#endif
+
+#ifdef UI
+_ui_menu_item_add(ICON, NAME, FNAME);
+#endif
+
+#ifdef PROTO
+void FNAME(void);
+#endif
+
+#ifndef PROTO
+# ifndef UI
+void FNAME(void)
+{
+   ui_func_set(_key, _loop);
+   _setup();
+}
+# endif
+#endif
+#undef FNAME
+#undef NAME
+#undef ICON
diff --git a/src/bin/meson.build b/src/bin/meson.build
index 73a4724..658e558 100644
--- a/src/bin/meson.build
+++ b/src/bin/meson.build
@@ -38,6 +38,7 @@ expedite_sources = [ 'main.c',
        'image_blend_border.c',
        'image_blend_solid_middle_border.c',
        'image_blend_solid_border.c',
+       'image_blend_solid_stretch.c',
        'image_blend_border_recolor.c',
        'image_map_rotate.c',
        'image_map_solid_rotate.c',
diff --git a/src/bin/tests.h b/src/bin/tests.h
index 18833de..655ac84 100644
--- a/src/bin/tests.h
+++ b/src/bin/tests.h
@@ -31,6 +31,7 @@
 #include "image_blend_border.c"
 #include "image_blend_solid_middle_border.c"
 #include "image_blend_solid_border.c"
+#include "image_blend_solid_stretch.c"
 #include "image_blend_border_recolor.c"
 #include "image_map_rotate.c"
 #include "image_map_solid_rotate.c"

-- 


Reply via email to