2015-04-03 07:31:45 -07:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include "config.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <Eina.h>
|
|
|
|
#include <Ector.h>
|
|
|
|
#include <software/Ector_Software.h>
|
|
|
|
|
|
|
|
#include "ector_private.h"
|
|
|
|
#include "ector_software_private.h"
|
|
|
|
|
|
|
|
static Eina_Bool
|
2016-05-11 04:57:06 -07:00
|
|
|
_ector_renderer_software_gradient_radial_ector_renderer_prepare(Eo *obj, Ector_Renderer_Software_Gradient_Data *pd)
|
2015-04-03 07:31:45 -07:00
|
|
|
{
|
|
|
|
if (!pd->surface)
|
|
|
|
{
|
2016-05-11 04:57:06 -07:00
|
|
|
Ector_Renderer_Data *base;
|
2015-04-03 07:31:45 -07:00
|
|
|
|
2016-08-15 06:44:41 -07:00
|
|
|
base = efl_data_scope_get(obj, ECTOR_RENDERER_CLASS);
|
|
|
|
pd->surface = efl_data_xref(base->surface, ECTOR_SOFTWARE_SURFACE_CLASS, obj);
|
2015-04-03 07:31:45 -07:00
|
|
|
}
|
|
|
|
|
2017-09-17 11:46:09 -07:00
|
|
|
ector_software_gradient_color_update(pd);
|
2015-10-20 15:55:32 -07:00
|
|
|
|
|
|
|
pd->radial.cx = pd->grd->radial.x;
|
|
|
|
pd->radial.cy = pd->grd->radial.y;
|
|
|
|
pd->radial.cradius = pd->grd->radius;
|
|
|
|
|
2017-01-06 09:57:46 -08:00
|
|
|
if (EINA_DBL_EQ(pd->grd->focal.x, 0.0))
|
2015-10-20 15:55:32 -07:00
|
|
|
pd->radial.fx = pd->grd->radial.x;
|
|
|
|
else
|
|
|
|
pd->radial.fx = pd->grd->focal.x;
|
|
|
|
|
2017-01-06 09:57:46 -08:00
|
|
|
if (EINA_DBL_EQ(pd->grd->focal.y, 0.0))
|
2015-10-20 15:55:32 -07:00
|
|
|
pd->radial.fy = pd->grd->radial.y;
|
|
|
|
else
|
|
|
|
pd->radial.fy = pd->grd->focal.y;
|
|
|
|
|
|
|
|
pd->radial.fradius = 0;
|
|
|
|
|
|
|
|
pd->radial.dx = pd->radial.cx - pd->radial.fx;
|
|
|
|
pd->radial.dy = pd->radial.cy - pd->radial.fy;
|
|
|
|
|
|
|
|
pd->radial.dr = pd->radial.cradius - pd->radial.fradius;
|
|
|
|
pd->radial.sqrfr = pd->radial.fradius * pd->radial.fradius;
|
|
|
|
|
|
|
|
pd->radial.a = pd->radial.dr * pd->radial.dr -
|
|
|
|
pd->radial.dx * pd->radial.dx -
|
|
|
|
pd->radial.dy * pd->radial.dy;
|
|
|
|
pd->radial.inv2a = 1 / (2 * pd->radial.a);
|
|
|
|
|
|
|
|
pd->radial.extended = (pd->radial.fradius >= 0.00001f) || pd->radial.a >= 0.00001f;
|
|
|
|
|
2015-04-03 07:31:45 -07:00
|
|
|
return EINA_FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Clearly duplicated and should be in a common place...
|
|
|
|
static Eina_Bool
|
2016-05-11 04:57:06 -07:00
|
|
|
_ector_renderer_software_gradient_radial_ector_renderer_draw(Eo *obj EINA_UNUSED,
|
2017-09-17 11:46:09 -07:00
|
|
|
Ector_Renderer_Software_Gradient_Data *pd EINA_UNUSED,
|
|
|
|
Efl_Gfx_Render_Op op EINA_UNUSED, Eina_Array *clips EINA_UNUSED,
|
|
|
|
unsigned int mul_col EINA_UNUSED)
|
2015-04-03 07:31:45 -07:00
|
|
|
{
|
|
|
|
return EINA_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Clearly duplicated and should be in a common place...
|
|
|
|
static Eina_Bool
|
2018-02-12 10:23:25 -08:00
|
|
|
_ector_renderer_software_gradient_radial_ector_renderer_software_op_fill(Eo *obj EINA_UNUSED, Ector_Renderer_Software_Gradient_Data *pd)
|
2015-04-03 07:31:45 -07:00
|
|
|
{
|
2015-12-02 01:46:29 -08:00
|
|
|
ector_software_rasterizer_radial_gradient_set(pd->surface->rasterizer, pd);
|
2017-09-17 11:46:09 -07:00
|
|
|
ector_software_gradient_color_update(pd);
|
2015-04-03 07:31:45 -07:00
|
|
|
return EINA_TRUE;
|
|
|
|
}
|
|
|
|
|
2015-05-19 03:41:27 -07:00
|
|
|
Eo *
|
2016-08-10 07:23:04 -07:00
|
|
|
_ector_renderer_software_gradient_radial_efl_object_constructor(Eo *obj,
|
2015-04-03 07:31:45 -07:00
|
|
|
Ector_Renderer_Software_Gradient_Data *pd)
|
|
|
|
{
|
2016-08-15 06:44:41 -07:00
|
|
|
obj = efl_constructor(efl_super(obj, ECTOR_RENDERER_SOFTWARE_GRADIENT_RADIAL_CLASS));
|
|
|
|
pd->gd = efl_data_xref(obj, ECTOR_RENDERER_GRADIENT_MIXIN, obj);
|
|
|
|
pd->gld = efl_data_xref(obj, ECTOR_RENDERER_GRADIENT_RADIAL_MIXIN, obj);
|
2017-09-17 11:46:09 -07:00
|
|
|
pd->done = EINA_TRUE;
|
2015-05-19 03:41:27 -07:00
|
|
|
|
|
|
|
return obj;
|
2015-04-03 07:31:45 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2016-08-10 07:23:04 -07:00
|
|
|
_ector_renderer_software_gradient_radial_efl_object_destructor(Eo *obj,
|
2015-04-03 07:31:45 -07:00
|
|
|
Ector_Renderer_Software_Gradient_Data *pd)
|
|
|
|
{
|
2016-05-11 04:57:06 -07:00
|
|
|
Ector_Renderer_Data *base;
|
2015-04-03 07:31:45 -07:00
|
|
|
|
|
|
|
destroy_color_table(pd);
|
|
|
|
|
2016-08-15 06:44:41 -07:00
|
|
|
base = efl_data_scope_get(obj, ECTOR_RENDERER_CLASS);
|
|
|
|
efl_data_xunref(base->surface, pd->surface, obj);
|
2015-04-03 07:31:45 -07:00
|
|
|
|
2016-08-15 06:44:41 -07:00
|
|
|
efl_data_xunref(obj, pd->gd, obj);
|
|
|
|
efl_data_xunref(obj, pd->gld, obj);
|
2015-04-03 07:31:45 -07:00
|
|
|
|
2016-08-15 06:44:41 -07:00
|
|
|
efl_destructor(efl_super(obj, ECTOR_RENDERER_SOFTWARE_GRADIENT_RADIAL_CLASS));
|
2015-04-03 07:31:45 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2016-05-10 07:06:04 -07:00
|
|
|
_ector_renderer_software_gradient_radial_efl_gfx_gradient_stop_set(Eo *obj, Ector_Renderer_Software_Gradient_Data *pd, const Efl_Gfx_Gradient_Stop *colors, unsigned int length)
|
2015-04-03 07:31:45 -07:00
|
|
|
{
|
2016-08-15 06:44:41 -07:00
|
|
|
efl_gfx_gradient_stop_set(efl_super(obj, ECTOR_RENDERER_SOFTWARE_GRADIENT_RADIAL_CLASS), colors, length);
|
2015-04-03 07:31:45 -07:00
|
|
|
|
|
|
|
destroy_color_table(pd);
|
|
|
|
}
|
|
|
|
|
2015-09-16 22:55:52 -07:00
|
|
|
static unsigned int
|
2016-05-11 04:57:06 -07:00
|
|
|
_ector_renderer_software_gradient_radial_ector_renderer_crc_get(Eo *obj, Ector_Renderer_Software_Gradient_Data *pd)
|
2015-09-16 22:55:52 -07:00
|
|
|
{
|
|
|
|
unsigned int crc;
|
|
|
|
|
2016-08-15 06:44:41 -07:00
|
|
|
crc = ector_renderer_crc_get(efl_super(obj, ECTOR_RENDERER_SOFTWARE_GRADIENT_RADIAL_CLASS));
|
2015-09-16 22:55:52 -07:00
|
|
|
|
|
|
|
crc = eina_crc((void*) pd->gd->s, sizeof (Efl_Gfx_Gradient_Spread), crc, EINA_FALSE);
|
|
|
|
if (pd->gd->colors_count)
|
|
|
|
crc = eina_crc((void*) pd->gd->colors, sizeof (Efl_Gfx_Gradient_Stop) * pd->gd->colors_count, crc, EINA_FALSE);
|
2016-05-11 04:57:06 -07:00
|
|
|
crc = eina_crc((void*) pd->gld, sizeof (Ector_Renderer_Gradient_Radial_Data), crc, EINA_FALSE);
|
2015-09-16 22:55:52 -07:00
|
|
|
|
|
|
|
return crc;
|
|
|
|
}
|
|
|
|
|
2015-04-03 07:31:45 -07:00
|
|
|
#include "ector_renderer_software_gradient_radial.eo.c"
|