evas: implement all Evas_VG_Shape property.

This commit is contained in:
Cedric BAIL 2015-04-03 16:14:51 +02:00
parent b50931a5ca
commit 3447936adb
1 changed files with 112 additions and 50 deletions

View File

@ -10,6 +10,26 @@ struct _Evas_VG_Shape_Data
{
Evas_VG_Path_Command *op;
double *points;
Evas_VG_Node *fill;
struct {
Evas_VG_Dash *dash;
Evas_VG_Node *fill;
Evas_VG_Node *marker;
double scale;
double width;
double centered; // from 0 to 1
int r, g, b, a;
unsigned int dash_count;
Evas_VG_Cap cap;
Evas_VG_Join join;
} stroke;
unsigned int op_count;
unsigned int pts_counts;
};
@ -37,146 +57,188 @@ void
_evas_vg_shape_eo_base_constructor(Eo *obj, Evas_VG_Shape_Data *pd EINA_UNUSED)
{
eo_do_super(obj, MY_CLASS, eo_constructor());
pd->stroke.cap = EVAS_VG_CAP_BUTT;
pd->stroke.join = EVAS_VG_JOIN_MITER;
pd->stroke.scale = 1;
pd->stroke.a = 1;
pd->stroke.centered = 0.5;
}
void
_evas_vg_shape_eo_base_destructor(Eo *obj, Evas_VG_Shape_Data *pd)
_evas_vg_shape_eo_base_destructor(Eo *obj, Evas_VG_Shape_Data *pd EINA_UNUSED)
{
(void) obj; (void) pd;
eo_do_super(obj, MY_CLASS, eo_destructor());
}
void
_evas_vg_shape_fill_set(Eo *obj, Evas_VG_Shape_Data *pd, Evas_VG_Node *f)
_evas_vg_shape_fill_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
Evas_VG_Node *f)
{
(void) obj; (void) pd; (void) f;
Evas_VG_Node *tmp = pd->fill;
pd->fill = eo_ref(f);
eo_unref(tmp);
}
Evas_VG_Node *
_evas_vg_shape_fill_get(Eo *obj, Evas_VG_Shape_Data *pd)
_evas_vg_shape_fill_get(Eo *obj EINA_UNUSED, Evas_VG_Shape_Data *pd)
{
(void) obj; (void) pd;
return NULL;
return pd->fill;
}
void
_evas_vg_shape_stroke_scale_set(Eo *obj, Evas_VG_Shape_Data *pd, double s)
_evas_vg_shape_stroke_scale_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
double s)
{
(void) obj; (void) pd; (void) s;
pd->stroke.scale = s;
}
double
_evas_vg_shape_stroke_scale_get(Eo *obj, Evas_VG_Shape_Data *pd)
_evas_vg_shape_stroke_scale_get(Eo *obj EINA_UNUSED, Evas_VG_Shape_Data *pd)
{
(void) obj; (void) pd;
return 0.0;
return pd->stroke.scale;
}
void
_evas_vg_shape_stroke_color_set(Eo *obj, Evas_VG_Shape_Data *pd,
_evas_vg_shape_stroke_color_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
int r, int g, int b, int a)
{
(void) obj; (void) pd; (void) r; (void) g; (void) b; (void) a;
pd->stroke.r = r;
pd->stroke.g = g;
pd->stroke.b = b;
pd->stroke.a = a;
}
void
_evas_vg_shape_stroke_color_get(Eo *obj, Evas_VG_Shape_Data *pd,
_evas_vg_shape_stroke_color_get(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
int *r, int *g, int *b, int *a)
{
(void) obj; (void) pd; (void) r; (void) g; (void) b; (void) a;
if (r) *r = pd->stroke.r;
if (g) *g = pd->stroke.g;
if (b) *b = pd->stroke.b;
if (a) *a = pd->stroke.a;
}
void
_evas_vg_shape_stroke_fill_set(Eo *obj, Evas_VG_Shape_Data *pd, Evas_VG_Node *f)
_evas_vg_shape_stroke_fill_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
Evas_VG_Node *f)
{
(void) obj; (void) pd; (void) f;
Evas_VG_Node *tmp = pd->fill;
pd->stroke.fill = eo_ref(f);
eo_unref(tmp);
}
Evas_VG_Node *
_evas_vg_shape_stroke_fill_get(Eo *obj, Evas_VG_Shape_Data *pd)
_evas_vg_shape_stroke_fill_get(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd)
{
(void) obj; (void) pd;
return NULL;
return pd->stroke.fill;
}
void
_evas_vg_shape_stroke_width_set(Eo *obj, Evas_VG_Shape_Data *pd, double w)
_evas_vg_shape_stroke_width_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
double w)
{
(void) obj; (void) pd; (void) w;
pd->stroke.width = w;
}
double
_evas_vg_shape_stroke_width_get(Eo *obj, Evas_VG_Shape_Data *pd)
_evas_vg_shape_stroke_width_get(Eo *obj EINA_UNUSED, Evas_VG_Shape_Data *pd)
{
(void) obj; (void) pd;
return 0.0;
return pd->stroke.width;
}
void
_evas_vg_shape_stroke_location_set(Eo *obj, Evas_VG_Shape_Data *pd,
_evas_vg_shape_stroke_location_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
double centered)
{
(void) obj; (void) pd; (void) centered;
pd->stroke.centered = centered;
}
double
_evas_vg_shape_stroke_location_get(Eo *obj, Evas_VG_Shape_Data *pd)
_evas_vg_shape_stroke_location_get(Eo *obj EINA_UNUSED, Evas_VG_Shape_Data *pd)
{
(void) obj; (void) pd;
return 0.0;
return pd->stroke.centered;
}
void
_evas_vg_shape_stroke_dash_set(Eo *obj, Evas_VG_Shape_Data *pd,
_evas_vg_shape_stroke_dash_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
const Evas_VG_Dash *dash, unsigned int length)
{
(void) obj; (void) pd; (void) dash; (void) length;
free(pd->stroke.dash);
pd->stroke.dash = NULL;
pd->stroke.dash_count = 0;
pd->stroke.dash = malloc(sizeof (Evas_VG_Dash) * length);
if (!pd->stroke.dash) return ;
memcpy(pd->stroke.dash, dash, sizeof (Evas_VG_Dash) * length);
pd->stroke.dash_count = length;
}
void
_evas_vg_shape_stroke_dash_get(Eo *obj, Evas_VG_Shape_Data *pd,
_evas_vg_shape_stroke_dash_get(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
const Evas_VG_Dash **dash, unsigned int *length)
{
(void) obj; (void) pd; (void) dash; (void) length;
if (dash) *dash = pd->stroke.dash;
if (length) *length = pd->stroke.dash_count;
}
void
_evas_vg_shape_stroke_marker_set(Eo *obj, Evas_VG_Shape_Data *pd,
_evas_vg_shape_stroke_marker_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
Evas_VG_Shape *m)
{
(void) obj; (void) pd; (void) m;
Evas_VG_Node *tmp = pd->stroke.marker;
pd->stroke.marker = eo_ref(m);
eo_unref(tmp);
}
Evas_VG_Shape *
_evas_vg_shape_stroke_marker_get(Eo *obj, Evas_VG_Shape_Data *pd)
_evas_vg_shape_stroke_marker_get(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd)
{
(void) obj; (void) pd;
return NULL;
return pd->stroke.marker;
}
void
_evas_vg_shape_stroke_cap_set(Eo *obj, Evas_VG_Shape_Data *pd, Evas_VG_Cap c)
_evas_vg_shape_stroke_cap_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
Evas_VG_Cap c)
{
(void) obj; (void) pd; (void) c;
pd->stroke.cap = c;
}
Evas_VG_Cap
_evas_vg_shape_stroke_cap_get(Eo *obj, Evas_VG_Shape_Data *pd)
_evas_vg_shape_stroke_cap_get(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd)
{
(void) obj; (void) pd;
return EVAS_VG_CAP_LAST;
return pd->stroke.cap;
}
void
_evas_vg_shape_stroke_join_set(Eo *obj, Evas_VG_Shape_Data *pd, Evas_VG_Join j)
_evas_vg_shape_stroke_join_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
Evas_VG_Join j)
{
(void) obj; (void) pd; (void) j;
pd->stroke.join = j;
}
Evas_VG_Join
_evas_vg_shape_stroke_join_get(Eo *obj, Evas_VG_Shape_Data *pd)
_evas_vg_shape_stroke_join_get(Eo *obj EINA_UNUSED, Evas_VG_Shape_Data *pd)
{
(void) obj; (void) pd;
return EVAS_VG_JOIN_LAST;
return pd->stroke.join;
}
#include "evas_vg_shape.eo.c"