blob: 54ea011acfadbe2aa757bce8d6bf36fb64082049 [file] [log] [blame]
Tyler Denniston187d8112021-01-12 09:34:23 -05001/*
2 * Copyright 2020 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
8#include "include/effects/SkImageFilters.h"
9#include "modules/svg/include/SkSVGAttributeParser.h"
10#include "modules/svg/include/SkSVGFeGaussianBlur.h"
11#include "modules/svg/include/SkSVGFilterContext.h"
12#include "modules/svg/include/SkSVGRenderContext.h"
13#include "modules/svg/include/SkSVGValue.h"
14
15bool SkSVGFeGaussianBlur::parseAndSetAttribute(const char* name, const char* value) {
16 return INHERITED::parseAndSetAttribute(name, value) ||
17 this->setStdDeviation(SkSVGAttributeParser::parse<SkSVGFeGaussianBlur::StdDeviation>(
18 "stdDeviation", name, value));
19}
20
21sk_sp<SkImageFilter> SkSVGFeGaussianBlur::onMakeImageFilter(const SkSVGRenderContext& ctx,
22 const SkSVGFilterContext& fctx) const {
23 SkScalar sigmaX = fStdDeviation.fX;
24 SkScalar sigmaY = fStdDeviation.fY;
25 if (fctx.primitiveUnits().type() == SkSVGObjectBoundingBoxUnits::Type::kObjectBoundingBox) {
26 SkASSERT(ctx.node());
27 const SkRect objBounds = ctx.node()->objectBoundingBox(ctx);
28 sigmaX *= objBounds.width();
29 sigmaY *= objBounds.height();
30 }
31
Tyler Dennistonc7e48242021-01-20 17:31:36 -050032 return SkImageFilters::Blur(
33 sigmaX, sigmaY,
34 fctx.resolveInput(ctx, this->getIn(), this->resolveColorspace(ctx, fctx)),
35 this->resolveFilterSubregion(ctx, fctx));
Tyler Denniston187d8112021-01-12 09:34:23 -050036}
37
38template <>
39bool SkSVGAttributeParser::parse<SkSVGFeGaussianBlur::StdDeviation>(
40 SkSVGFeGaussianBlur::StdDeviation* stdDeviation) {
41 std::vector<SkSVGNumberType> values;
42 if (!this->parse(&values)) {
43 return false;
44 }
45
46 stdDeviation->fX = values[0];
47 stdDeviation->fY = values.size() > 1 ? values[1] : values[0];
48 return true;
49}