Browse Source

expedite: test and benchmark lines.

SVN revision: 84039
devs/cedric/efl-1.11
Cedric BAIL 9 years ago
parent
commit
244a1da63c
  1. 4
      ChangeLog
  2. 1
      NEWS
  3. 19
      src/bin/Makefile.am
  4. 143
      src/bin/line_blend.c
  5. 1
      src/bin/tests.h
  6. 1
      src/bin/ui.c

4
ChangeLog

@ -33,3 +33,7 @@
2013-01-23 Yakov Goldberg
* Porting to Eo
2013-02-18 Cedric Bail
* Test and benchmark lines.

1
NEWS

@ -6,6 +6,7 @@ Changes since Expedite 1.7.0:
Additions:
* Support for Wayland engines
* Test and benchmark lines
Removals:

19
src/bin/Makefile.am

@ -112,7 +112,24 @@ image_blend_occlude3_very_many.c \
poly_blend.c \
proxy_image.c \
proxy_text_fixed.c \
proxy_text_random.c
proxy_text_random.c \
line_blend.c
# \
# image_mask.c \
# image_mask_2.c \
# image_mask_3.c \
# image_mask_4.c \
# image_mask_5.c \
# image_mask_6.c \
# image_mask_7.c \
# image_mask_8.c \
# image_mask_9.c \
# image_mask_10.c \
# image_mask_11.c \
# image_mask_12.c \
# image_mask_13.c \
# image_mask_14.c \
# image_mask_15.c
expedite_CFLAGS = @WIN32_CFLAGS@ @WAYLAND_CLIENT_CFLAGS@ @WAYLAND_EGL_CFLAGS@
expedite_CXXFLAGS = @EXPEDITE_CXXFLAGS@

143
src/bin/line_blend.c

@ -0,0 +1,143 @@
#undef FNAME
#undef NAME
#undef ICON
/* metadata */
#define FNAME line_blend_start
#define NAME "Line Blend"
#define ICON "rect.png"
#ifndef PROTO
# ifndef UI
# include "main.h"
/* standard var */
static int done = 0;
/* private data */
static Evas_Object *o_images[OBNUM];
/* setup */
static void _setup(void)
{
int i;
Evas_Object *o;
srnd();
for (i = 0; i < OBNUM; i++)
{
int r, g, b, a;
o = eo_add(EVAS_OBJ_LINE_CLASS, evas);
o_images[i] = o;
a = (rnd()&0xff) / 2;
r = ((rnd()&0xff) * a) / 255;
g = ((rnd()&0xff) * a) / 255;
b = ((rnd()&0xff) * a) / 255;
eo_do(o,
evas_obj_color_set(r, g, b, a),
evas_obj_line_xy_set(((win_w / 2) * (rnd()&0xff)) / 255,
((win_h / 2) * (rnd()&0xff)) / 255,
((win_w / 2) * (rnd()&0xff)) / 255 + (win_w / 2),
((win_h / 2) * (rnd()&0xff)) / 255 + (win_h / 2)),
evas_obj_visibility_set(EINA_TRUE));
}
done = 0;
}
/* cleanup */
static void _cleanup(void)
{
int i;
for (i = 0; i < OBNUM; i++) eo_del(o_images[i]);
}
#define PI (double) 3.141592654
static void
_rotate_point(Evas_Coord *ox, Evas_Coord *oy, int r)
{
double d;
double x, y;
double angle;
x = *ox - (win_w / 2);
y = *oy - (win_h / 2);
d = sqrt(x * x + y * y);
angle = atan((double) y / (double) x);
if (x < 0) angle -= PI;
switch (r & 0x3)
{
case 0: angle += 1 * PI / 180; break;
case 1: angle += -1 * PI / 180; break;
case 2: angle += 7 * PI / 180; break;
case 3: angle += -1 * PI / 180; break;
}
*ox = d * cos(angle) + (win_w / 2);
*oy = d * sin(angle) + (win_h / 2);
}
/* loop - do things */
static void _loop(double t, int f)
{
int i;
Evas_Coord ox1, oy1, ox2, oy2;
Evas_Object *o;
for (i = 0; i < OBNUM; i++)
{
o = o_images[i];
eo_do(o, evas_obj_line_xy_get(&ox1, &oy1, &ox2, &oy2));
_rotate_point(&ox1, &oy1, i);
_rotate_point(&ox2, &oy2, i);
eo_do(o, evas_obj_line_xy_set(ox1, oy1, ox2, oy2));
}
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

1
src/bin/tests.h

@ -89,6 +89,7 @@
#include "proxy_image.c"
#include "proxy_text_fixed.c"
#include "proxy_text_random.c"
#include "line_blend.c"
#if 0 // test disabled - evas having code disabled
#include "image_mask.c"
#include "image_mask_2.c"

1
src/bin/ui.c

@ -202,6 +202,7 @@ static double weights[] =
0.0,
0.0,
0.0,
0.0,
0.0
};

Loading…
Cancel
Save