blob: 7d7cd8ccc75563ec84f85d9bf52ea50cd1f0a2a0 [file] [log] [blame]
Florin Malitacc6cc292017-10-09 16:05:30 -04001/*
2 * Copyright 2017 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
Mike Kleinc0bd9f92019-04-23 12:05:21 -05008#include "include/effects/SkGradientShader.h"
Florin Malitab3418102020-10-15 18:10:29 -04009#include "modules/svg/include/SkSVGRadialGradient.h"
10#include "modules/svg/include/SkSVGRenderContext.h"
11#include "modules/svg/include/SkSVGValue.h"
Florin Malitacc6cc292017-10-09 16:05:30 -040012
13SkSVGRadialGradient::SkSVGRadialGradient() : INHERITED(SkSVGTag::kRadialGradient) {}
14
Tyler Dennistona0a51462020-11-10 13:13:28 -050015bool SkSVGRadialGradient::parseAndSetAttribute(const char* name, const char* value) {
16 return INHERITED::parseAndSetAttribute(name, value) ||
17 this->setCx(SkSVGAttributeParser::parse<SkSVGLength>("cx", name, value)) ||
18 this->setCy(SkSVGAttributeParser::parse<SkSVGLength>("cy", name, value)) ||
19 this->setR(SkSVGAttributeParser::parse<SkSVGLength>("r", name, value)) ||
20 this->setFx(SkSVGAttributeParser::parse<SkSVGLength>("fx", name, value)) ||
21 this->setFy(SkSVGAttributeParser::parse<SkSVGLength>("fy", name, value));
Florin Malitacc6cc292017-10-09 16:05:30 -040022}
23
24sk_sp<SkShader> SkSVGRadialGradient::onMakeShader(const SkSVGRenderContext& ctx,
Florin Malitaea27de52021-01-19 12:51:12 -050025 const SkColor4f* colors, const SkScalar* pos,
Mike Reedfae8fce2019-04-03 10:27:45 -040026 int count, SkTileMode tm,
Florin Malitacc6cc292017-10-09 16:05:30 -040027 const SkMatrix& m) const {
Tyler Dennistonf548a022020-10-27 15:02:02 -040028 const SkSVGLengthContext lctx =
Tyler Dennistona0a51462020-11-10 13:13:28 -050029 this->getGradientUnits().type() == SkSVGObjectBoundingBoxUnits::Type::kObjectBoundingBox
Tyler Dennistonf548a022020-10-27 15:02:02 -040030 ? SkSVGLengthContext({1, 1})
31 : ctx.lengthContext();
32
Florin Malitacc6cc292017-10-09 16:05:30 -040033 const auto r = lctx.resolve(fR , SkSVGLengthContext::LengthType::kOther);
34 const auto center = SkPoint::Make(
35 lctx.resolve(fCx, SkSVGLengthContext::LengthType::kHorizontal),
36 lctx.resolve(fCy, SkSVGLengthContext::LengthType::kVertical));
37 const auto focal = SkPoint::Make(
John Stilesa008b0f2020-08-16 08:48:02 -040038 fFx.isValid() ? lctx.resolve(*fFx, SkSVGLengthContext::LengthType::kHorizontal)
Florin Malitacc6cc292017-10-09 16:05:30 -040039 : center.x(),
John Stilesa008b0f2020-08-16 08:48:02 -040040 fFy.isValid() ? lctx.resolve(*fFy, SkSVGLengthContext::LengthType::kVertical)
Florin Malitacc6cc292017-10-09 16:05:30 -040041 : center.y());
42
Florin Malita9a5aa0a2020-11-20 15:35:09 -050043 if (r == 0) {
Florin Malitaea27de52021-01-19 12:51:12 -050044 const auto last_color = count > 0 ? colors[count - 1] : SkColors::kBlack;
45 return SkShaders::Color(last_color, nullptr);
Florin Malita9a5aa0a2020-11-20 15:35:09 -050046 }
Tyler Dennistonf548a022020-10-27 15:02:02 -040047
Florin Malitacc6cc292017-10-09 16:05:30 -040048 return center == focal
Florin Malitaea27de52021-01-19 12:51:12 -050049 ? SkGradientShader::MakeRadial(center, r, colors, nullptr, pos, count, tm, 0, &m)
50 : SkGradientShader::MakeTwoPointConical(focal, 0, center, r, colors, nullptr, pos,
51 count, tm, 0, &m);
Florin Malitacc6cc292017-10-09 16:05:30 -040052}