This source file includes following definitions.
- collectGradientAttributes
- centerPoint
- focalPoint
- radius
- focalRadius
- buildGradient
#include "config.h"
#include "core/rendering/svg/RenderSVGResourceRadialGradient.h"
#include "core/svg/SVGRadialGradientElement.h"
namespace WebCore {
const RenderSVGResourceType RenderSVGResourceRadialGradient::s_resourceType = RadialGradientResourceType;
RenderSVGResourceRadialGradient::RenderSVGResourceRadialGradient(SVGRadialGradientElement* node)
: RenderSVGResourceGradient(node)
{
}
RenderSVGResourceRadialGradient::~RenderSVGResourceRadialGradient()
{
}
bool RenderSVGResourceRadialGradient::collectGradientAttributes(SVGGradientElement* gradientElement)
{
m_attributes = RadialGradientAttributes();
return toSVGRadialGradientElement(gradientElement)->collectGradientAttributes(m_attributes);
}
FloatPoint RenderSVGResourceRadialGradient::centerPoint(const RadialGradientAttributes& attributes) const
{
return SVGLengthContext::resolvePoint(element(), attributes.gradientUnits(), attributes.cx(), attributes.cy());
}
FloatPoint RenderSVGResourceRadialGradient::focalPoint(const RadialGradientAttributes& attributes) const
{
return SVGLengthContext::resolvePoint(element(), attributes.gradientUnits(), attributes.fx(), attributes.fy());
}
float RenderSVGResourceRadialGradient::radius(const RadialGradientAttributes& attributes) const
{
return SVGLengthContext::resolveLength(element(), attributes.gradientUnits(), attributes.r());
}
float RenderSVGResourceRadialGradient::focalRadius(const RadialGradientAttributes& attributes) const
{
return SVGLengthContext::resolveLength(element(), attributes.gradientUnits(), attributes.fr());
}
void RenderSVGResourceRadialGradient::buildGradient(GradientData* gradientData) const
{
gradientData->gradient = Gradient::create(this->focalPoint(m_attributes),
this->focalRadius(m_attributes),
this->centerPoint(m_attributes),
this->radius(m_attributes));
gradientData->gradient->setSpreadMethod(platformSpreadMethodFromSVGType(m_attributes.spreadMethod()));
addStops(gradientData, m_attributes.stops());
}
}