d6cf56fd34
This reverts commit 6fc4106a9d
.
Reason for revert: Blocking the Android roll
Original change's description:
> [svg] Relocate out of experimental
>
> Move the SVG rendering code to modules/svg, and componentize.
> Also split into include/src/utils.
>
> As external clients still reference the old header locations,
> introduce temporary forwarding headers to facilitate the migration.
>
> Change-Id: Ib289dbdcd80c16a01c47805e7242f2e08bebc165
> Reviewed-on: https://skia-review.googlesource.com/c/skia/+/326948
> Reviewed-by: Tyler Denniston <tdenniston@google.com>
> Commit-Queue: Florin Malita <fmalita@google.com>
TBR=fmalita@chromium.org,fmalita@google.com,tdenniston@google.com
Change-Id: I386cf77a15a9e1d392029804abaf937dae53f435
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/327342
Reviewed-by: Robert Phillips <robertphillips@google.com>
Commit-Queue: Robert Phillips <robertphillips@google.com>
83 lines
2.3 KiB
C++
83 lines
2.3 KiB
C++
/*
|
|
* Copyright 2016 Google Inc.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*/
|
|
|
|
#include "experimental/svg/model/SkSVGLine.h"
|
|
#include "experimental/svg/model/SkSVGRenderContext.h"
|
|
#include "experimental/svg/model/SkSVGValue.h"
|
|
#include "include/core/SkCanvas.h"
|
|
|
|
SkSVGLine::SkSVGLine() : INHERITED(SkSVGTag::kLine) {}
|
|
|
|
void SkSVGLine::setX1(const SkSVGLength& x1) {
|
|
fX1 = x1;
|
|
}
|
|
|
|
void SkSVGLine::setY1(const SkSVGLength& y1) {
|
|
fY1 = y1;
|
|
}
|
|
|
|
void SkSVGLine::setX2(const SkSVGLength& x2) {
|
|
fX2 = x2;
|
|
}
|
|
|
|
void SkSVGLine::setY2(const SkSVGLength& y2) {
|
|
fY2 = y2;
|
|
}
|
|
|
|
void SkSVGLine::onSetAttribute(SkSVGAttribute attr, const SkSVGValue& v) {
|
|
switch (attr) {
|
|
case SkSVGAttribute::kX1:
|
|
if (const auto* x1 = v.as<SkSVGLengthValue>()) {
|
|
this->setX1(*x1);
|
|
}
|
|
break;
|
|
case SkSVGAttribute::kY1:
|
|
if (const auto* y1 = v.as<SkSVGLengthValue>()) {
|
|
this->setY1(*y1);
|
|
}
|
|
break;
|
|
case SkSVGAttribute::kX2:
|
|
if (const auto* x2 = v.as<SkSVGLengthValue>()) {
|
|
this->setX2(*x2);
|
|
}
|
|
break;
|
|
case SkSVGAttribute::kY2:
|
|
if (const auto* y2 = v.as<SkSVGLengthValue>()) {
|
|
this->setY2(*y2);
|
|
}
|
|
break;
|
|
default:
|
|
this->INHERITED::onSetAttribute(attr, v);
|
|
}
|
|
}
|
|
|
|
std::tuple<SkPoint, SkPoint> SkSVGLine::resolve(const SkSVGLengthContext& lctx) const {
|
|
return std::make_tuple(
|
|
SkPoint::Make(lctx.resolve(fX1, SkSVGLengthContext::LengthType::kHorizontal),
|
|
lctx.resolve(fY1, SkSVGLengthContext::LengthType::kVertical)),
|
|
SkPoint::Make(lctx.resolve(fX2, SkSVGLengthContext::LengthType::kHorizontal),
|
|
lctx.resolve(fY2, SkSVGLengthContext::LengthType::kVertical)));
|
|
}
|
|
|
|
void SkSVGLine::onDraw(SkCanvas* canvas, const SkSVGLengthContext& lctx,
|
|
const SkPaint& paint, SkPathFillType) const {
|
|
SkPoint p0, p1;
|
|
std::tie(p0, p1) = this->resolve(lctx);
|
|
|
|
canvas->drawLine(p0, p1, paint);
|
|
}
|
|
|
|
SkPath SkSVGLine::onAsPath(const SkSVGRenderContext& ctx) const {
|
|
SkPoint p0, p1;
|
|
std::tie(p0, p1) = this->resolve(ctx.lengthContext());
|
|
|
|
SkPath path = SkPath::Line(p0, p1);
|
|
this->mapToParent(&path);
|
|
|
|
return path;
|
|
}
|