efl/src/lib/evas/canvas/evas_vg_shape.c

253 lines
6.6 KiB
C
Raw Normal View History

#include "evas_common_private.h"
#include "evas_private.h"
2015-04-03 07:14:50 -07:00
#include "evas_vg_private.h"
#define MY_CLASS EVAS_VG_SHAPE_CLASS
typedef struct _Evas_VG_Shape_Data Evas_VG_Shape_Data;
struct _Evas_VG_Shape_Data
{
2015-04-03 07:14:55 -07:00
Efl_Geometry_Path_Command *op;
double *points;
Evas_VG_Node *fill;
struct {
2015-04-03 07:14:55 -07:00
Efl_Geometry_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;
2015-04-03 07:14:55 -07:00
Efl_Geometry_Cap cap;
Efl_Geometry_Join join;
} stroke;
unsigned int op_count;
unsigned int pts_counts;
};
Eina_Bool
2015-04-03 07:14:55 -07:00
_evas_vg_shape_efl_geometry_shape_path_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
const Efl_Geometry_Path_Command *op,
const double *points)
{
2015-04-03 07:13:13 -07:00
free(pd->points);
pd->points = NULL;
free(pd->op);
pd->op = NULL;
2015-04-03 07:14:55 -07:00
return efl_geometry_path_dup(&pd->op, &pd->points, op, points);
}
Eina_Bool
_evas_vg_shape_bounds_get(Eo *obj, Evas_VG_Shape_Data *pd, Eina_Rectangle *r)
{
2015-04-03 07:14:50 -07:00
(void) obj; (void) pd; (void) r;
return EINA_FALSE;
}
void
_evas_vg_shape_eo_base_constructor(Eo *obj, Evas_VG_Shape_Data *pd EINA_UNUSED)
{
eo_do_super(obj, MY_CLASS, eo_constructor());
2015-04-03 07:14:55 -07:00
pd->stroke.cap = EFL_GEOMETRY_CAP_BUTT;
pd->stroke.join = EFL_GEOMETRY_JOIN_MITER;
pd->stroke.scale = 1;
pd->stroke.a = 1;
pd->stroke.centered = 0.5;
2015-04-03 07:14:50 -07:00
}
void
_evas_vg_shape_eo_base_destructor(Eo *obj, Evas_VG_Shape_Data *pd EINA_UNUSED)
2015-04-03 07:14:50 -07:00
{
eo_do_super(obj, MY_CLASS, eo_destructor());
2015-04-03 07:14:50 -07:00
}
void
_evas_vg_shape_fill_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
Evas_VG_Node *f)
2015-04-03 07:14:50 -07:00
{
Evas_VG_Node *tmp = pd->fill;
pd->fill = eo_ref(f);
eo_unref(tmp);
2015-04-03 07:14:50 -07:00
}
Evas_VG_Node *
_evas_vg_shape_fill_get(Eo *obj EINA_UNUSED, Evas_VG_Shape_Data *pd)
2015-04-03 07:14:50 -07:00
{
return pd->fill;
2015-04-03 07:14:50 -07:00
}
void
2015-04-03 07:14:55 -07:00
_evas_vg_shape_efl_geometry_shape_stroke_scale_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
double s)
2015-04-03 07:14:50 -07:00
{
pd->stroke.scale = s;
2015-04-03 07:14:50 -07:00
}
double
2015-04-03 07:14:55 -07:00
_evas_vg_shape_efl_geometry_shape_stroke_scale_get(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd)
2015-04-03 07:14:50 -07:00
{
return pd->stroke.scale;
2015-04-03 07:14:50 -07:00
}
void
2015-04-03 07:14:55 -07:00
_evas_vg_shape_efl_geometry_shape_stroke_color_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
int r, int g, int b, int a)
2015-04-03 07:14:50 -07:00
{
pd->stroke.r = r;
pd->stroke.g = g;
pd->stroke.b = b;
pd->stroke.a = a;
2015-04-03 07:14:50 -07:00
}
void
2015-04-03 07:14:55 -07:00
_evas_vg_shape_efl_geometry_shape_stroke_color_get(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
int *r, int *g, int *b, int *a)
2015-04-03 07:14:50 -07:00
{
if (r) *r = pd->stroke.r;
if (g) *g = pd->stroke.g;
if (b) *b = pd->stroke.b;
if (a) *a = pd->stroke.a;
2015-04-03 07:14:50 -07:00
}
void
_evas_vg_shape_stroke_fill_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
Evas_VG_Node *f)
2015-04-03 07:14:50 -07:00
{
Evas_VG_Node *tmp = pd->fill;
pd->stroke.fill = eo_ref(f);
eo_unref(tmp);
2015-04-03 07:14:50 -07:00
}
Evas_VG_Node *
_evas_vg_shape_stroke_fill_get(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd)
2015-04-03 07:14:50 -07:00
{
return pd->stroke.fill;
}
void
2015-04-03 07:14:55 -07:00
_evas_vg_shape_efl_geometry_shape_stroke_width_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
double w)
{
pd->stroke.width = w;
2015-04-03 07:14:50 -07:00
}
double
2015-04-03 07:14:55 -07:00
_evas_vg_shape_efl_geometry_shape_stroke_width_get(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd)
2015-04-03 07:14:50 -07:00
{
return pd->stroke.width;
2015-04-03 07:14:50 -07:00
}
void
2015-04-03 07:14:55 -07:00
_evas_vg_shape_efl_geometry_shape_stroke_location_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
double centered)
2015-04-03 07:14:50 -07:00
{
pd->stroke.centered = centered;
2015-04-03 07:14:50 -07:00
}
double
2015-04-03 07:14:55 -07:00
_evas_vg_shape_efl_geometry_shape_stroke_location_get(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd)
2015-04-03 07:14:50 -07:00
{
return pd->stroke.centered;
2015-04-03 07:14:50 -07:00
}
void
2015-04-03 07:14:55 -07:00
_evas_vg_shape_efl_geometry_shape_stroke_dash_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
const Efl_Geometry_Dash *dash,
unsigned int length)
2015-04-03 07:14:50 -07:00
{
free(pd->stroke.dash);
pd->stroke.dash = NULL;
pd->stroke.dash_count = 0;
2015-04-03 07:14:55 -07:00
pd->stroke.dash = malloc(sizeof (Efl_Geometry_Dash) * length);
if (!pd->stroke.dash) return ;
2015-04-03 07:14:55 -07:00
memcpy(pd->stroke.dash, dash, sizeof (Efl_Geometry_Dash) * length);
pd->stroke.dash_count = length;
2015-04-03 07:14:50 -07:00
}
void
2015-04-03 07:14:55 -07:00
_evas_vg_shape_efl_geometry_shape_stroke_dash_get(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
const Efl_Geometry_Dash **dash,
unsigned int *length)
2015-04-03 07:14:50 -07:00
{
if (dash) *dash = pd->stroke.dash;
if (length) *length = pd->stroke.dash_count;
2015-04-03 07:14:50 -07:00
}
2015-04-03 07:14:50 -07:00
void
_evas_vg_shape_stroke_marker_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
2015-04-03 07:14:50 -07:00
Evas_VG_Shape *m)
{
Evas_VG_Node *tmp = pd->stroke.marker;
pd->stroke.marker = eo_ref(m);
eo_unref(tmp);
2015-04-03 07:14:50 -07:00
}
Evas_VG_Shape *
_evas_vg_shape_stroke_marker_get(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd)
2015-04-03 07:14:50 -07:00
{
return pd->stroke.marker;
2015-04-03 07:14:50 -07:00
}
2015-04-03 07:14:50 -07:00
void
2015-04-03 07:14:55 -07:00
_evas_vg_shape_efl_geometry_shape_stroke_cap_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
Efl_Geometry_Cap c)
2015-04-03 07:14:50 -07:00
{
pd->stroke.cap = c;
}
2015-04-03 07:14:50 -07:00
2015-04-03 07:14:55 -07:00
Efl_Geometry_Cap
_evas_vg_shape_efl_geometry_shape_stroke_cap_get(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd)
2015-04-03 07:14:50 -07:00
{
return pd->stroke.cap;
2015-04-03 07:14:50 -07:00
}
void
2015-04-03 07:14:55 -07:00
_evas_vg_shape_efl_geometry_shape_stroke_join_set(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd,
Efl_Geometry_Join j)
2015-04-03 07:14:50 -07:00
{
pd->stroke.join = j;
2015-04-03 07:14:50 -07:00
}
2015-04-03 07:14:55 -07:00
Efl_Geometry_Join
_evas_vg_shape_efl_geometry_shape_stroke_join_get(Eo *obj EINA_UNUSED,
Evas_VG_Shape_Data *pd)
2015-04-03 07:14:50 -07:00
{
return pd->stroke.join;
2015-04-03 07:14:50 -07:00
}
#include "evas_vg_shape.eo.c"