From 4aa37445c52fc460ea9baddc543fe0202ae74d93 Mon Sep 17 00:00:00 2001 From: Yakov Goldberg Date: Tue, 9 Jun 2015 13:28:44 +0300 Subject: [PATCH] vector: add a basic test (no change, just moving). --- data/Makefile.am | 3 +- data/vector.png | Bin 0 -> 1625 bytes src/bin/Makefile.am | 3 +- src/bin/tests.h | 1 + src/bin/vg_basic.c | 130 ++++++++++++++++++++++++++++++++++++++++++++ 5 files changed, 135 insertions(+), 2 deletions(-) create mode 100644 data/vector.png create mode 100644 src/bin/vg_basic.c diff --git a/data/Makefile.am b/data/Makefile.am index 939fc95..3a7182f 100644 --- a/data/Makefile.am +++ b/data/Makefile.am @@ -55,6 +55,7 @@ data.png \ widgets.png \ e-logo-2.png \ e-logo-mask.png \ -texture.png +texture.png \ +vector.png EXTRA_DIST = $(files_DATA) diff --git a/data/vector.png b/data/vector.png new file mode 100644 index 0000000000000000000000000000000000000000..a7208887774b32f7136befcaee8e3e6727fbde09 GIT binary patch literal 1625 zcmV-f2B!ImP)e zSad^gZEa<4bO1wgWnpw>WFU8GbZ8()Nlj2!fese{00qHGL_t(o!?jmyP*qhF{`TRe zB=3j{8)S+!9S8@GNJHizL)pV0MiV|_#KtDe#+=cnnx;R@q-5yiWKVU*u^LkG!6ZHq zDf5l=kO{mQlBQfjxN^An#^u~|_SX;KK9n1vvS!ZA*?XAYZGyLL+0?KS6@FF%zH*!bj=C~a-U+YJpE zk>uy+<8*pD0ANdAUd+h_3(9qig(N9SN+}0_`t@vYr&dz3y?N87vA7*Mx?sT;-DcC} zP{0Amn40ExtzNwi035St4yqTssGSC1-jNg9y!x<5gL=yIpkpBl?o1Xqq z$L`&I;l5pPF9|8HTyYum=O+c+a{x#J;yWrT?i}!qkJG6eue}y`6M?GKQ~*Hp*IzgL ze)*k)>@O(TLc{P|XsJ3Em;?j7-vHiFQO91p%Rf`9t4sa&Jufe& z_u4hx*Wvy(6?`Fc&Y%QH($Uu4pO%sit47_~dou~cw^_o3{{x_SKZGhu~4VtABpDbOAuFIW%dLabb zEmoZF{1w~I?!^9&b_1ec866Gr^Uvjqt^?UXY|oi9o;){u+$?@<9y8TUs;bJFnKSsy zw zVPfI{IMCj1D0WRdh5lU#yEhzD?@#rBZ+d?t_SRKlRqpE$QUH<|C&CeI26>!%Ln#m; z?t(A@Nr`74%*Dauhq146A07z34+Ib{#^COxguXfe09UUbP>km08sEg3yRZNNP?Y^5 zCeO_PK@_fCjI6|TESvE%4%Qw*#TVZpQFuccqzi0V_8|@)t;WXXWti}90^a+)1Pm7l zpAd;x3tmRA=|avu85k4k?b1Yfc^UG6SiQd9Q;Ho{jWg47*z|+{NqF(ddC!<6n`;`W zPRXFEs;vF$fS<0Vrpa%u^RF)EBxkX$?vl5)b2>E-liJ0Lw-2;mB>8>GcD7%%{_nX? zk|l-j^66>$)P0ZJ!E8-(?ohIHrdTP^%X$ z!k&o}lZ=)Y{f>9Un&u)9JLHuN01jtl#C7f3)p1Ae1|+4$Vr5}r3;?jGX!zx{wXCdE zKY#w#+H;c9;h;QmVvPwXy@A3WNaoC%1ps&ph}Jf5KHzR`?UpVV1KtyT=dWMaWPN>= z>`ygjXW#ni_35NZp7+L-l*jGs)>RrcHE!u}NNJjsrb+2`OL_LJZtmDoX{zcIBk}(q XUxWJvB%k*j00000NkvXXu0mjfojC+b literal 0 HcmV?d00001 diff --git a/src/bin/Makefile.am b/src/bin/Makefile.am index 1cc92a1..253400d 100644 --- a/src/bin/Makefile.am +++ b/src/bin/Makefile.am @@ -124,7 +124,8 @@ image_mask_9.c \ image_mask_10.c \ image_mask_11.c \ image_mask_12.c \ -image_mask_13.c +image_mask_13.c \ +vg_basic.c # \ # image_mask_14.c \ # image_mask_15.c diff --git a/src/bin/tests.h b/src/bin/tests.h index 2189ee4..97b95c9 100644 --- a/src/bin/tests.h +++ b/src/bin/tests.h @@ -106,6 +106,7 @@ #include "image_mask_11.c" #include "image_mask_12.c" #include "image_mask_13.c" +#include "vg_basic.c" #if 0 // test disabled - evas having code disabled #include "image_mask_14.c" #include "image_mask_15.c" diff --git a/src/bin/vg_basic.c b/src/bin/vg_basic.c new file mode 100644 index 0000000..45ea034 --- /dev/null +++ b/src/bin/vg_basic.c @@ -0,0 +1,130 @@ +#undef FNAME +#undef NAME +#undef ICON + +/* metadata */ +#define FNAME vg_basic_start +#define NAME "VG Basic" +#define ICON "vector.png" + +#ifndef PROTO +# ifndef UI +# include "main.h" + +/* standard var */ +static int done = 0; + +/* private data */ +static Eo *o_shapes[OBNUM]; + +static const Efl_Gfx_Gradient_Stop stops[3] = { + { 0, 255, 0, 0, 255 }, + { 0.5, 0, 255, 0, 255 }, + { 1, 0, 0, 255, 255 } +}; + +/* setup + * Creating Evas Objects, each holds a vector shape. + * Then start moving these Evas Objects. */ +static void _setup(void) +{ + unsigned int i; + + for (i = 0; i < OBNUM; i++) + { + Efl_VG *root, *gradient, *rect; + Eo *vector; + double w = 70, h = 70, stroke_w = 3; + + vector = eo_add(EVAS_VG_CLASS, evas); + o_shapes[i] = vector; + eo_do(vector, + efl_gfx_size_set(w + stroke_w * 2, h + stroke_w * 2), + efl_gfx_position_set(0, 0), + efl_gfx_visible_set(EINA_TRUE)); + + eo_do(vector, root = evas_obj_vg_root_node_get()); + + gradient = eo_add(EFL_VG_GRADIENT_LINEAR_CLASS, root); + eo_do(gradient, + efl_gfx_gradient_stop_set(stops, 3), + efl_gfx_gradient_spread_set(EFL_GFX_GRADIENT_SPREAD_REFLECT), + efl_gfx_gradient_linear_start_set(10, 10), + efl_gfx_gradient_linear_end_set(50, 50)); + + rect = eo_add(EFL_VG_SHAPE_CLASS, root); + eo_do(rect, + efl_gfx_shape_append_rect(0 + stroke_w, 0 + stroke_w, w, h, 10, 10), + efl_vg_shape_fill_set(gradient), + efl_gfx_shape_stroke_width_set(stroke_w), + efl_gfx_shape_stroke_color_set(255, 0, 255, 128), + efl_gfx_shape_stroke_join_set(EFL_GFX_JOIN_ROUND)); + } + done = 0; +} + +/* cleanup */ +static void _cleanup(void) +{ + unsigned int i; + + for (i = 0; i < OBNUM; i++) eo_del(o_shapes[i]); +} + +/* loop - do things */ +static void _loop(double t, int f) +{ + int i; + Evas_Coord x, y, w = 200, h = 200; + for (i = 0; i < OBNUM; i++) + { + 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)) * (w / 2); + eo_do(o_shapes[i], efl_gfx_position_set(x, y)); + } + FPS_STD(NAME); +} + +/* prepend special key handlers if interactive (before STD) */ +static void _key(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