skia2/gm/blurignorexform.cpp
Brian Salomon 9fa47cc1c6 Make class members that are static constexpr also be inline.
This is in prep for compiling with -std=c++14 and -Wno-c++17-extensions
when building with clang. Chrome has encountered problems with
third_party headers that are included both in Skia and other Chrome
sources that produce different code based on whether preprocessor macros
indicate a C++14 or C++17 compilation.

In C++17 they are already inline implicitly. When compiling with C++14
we can get linker errors unless they're explicitly inlined or defined
outside the class. With -Wno-c++17-extensions we can explicitly inline
them in the C++14 build because the warning that would be generated
about using a C++17 language extension is suppressed.

We cannot do this in public headers because we support compiling with
C++14 without suppressing the C++17 language extension warnings.

Bug: chromium:1257145
Change-Id: Iaf5f4c62a398f98dd4ca9b7dfb86f2d5cab21d66
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/457498
Reviewed-by: Ben Wagner <bungeman@google.com>
Reviewed-by: Herb Derby <herb@google.com>
Commit-Queue: Brian Salomon <bsalomon@google.com>
2021-10-11 16:22:59 +00:00

157 lines
5.0 KiB
C++

/*
* Copyright 2017 Google Inc.
*
* Use of this source code is governed by a BD-style license that can be
* found in the LICENSE file.
*/
#include "gm/gm.h"
#include "include/core/SkBlurTypes.h"
#include "include/core/SkCanvas.h"
#include "include/core/SkColor.h"
#include "include/core/SkFont.h"
#include "include/core/SkMaskFilter.h"
#include "include/core/SkPaint.h"
#include "include/core/SkRRect.h"
#include "include/core/SkRect.h"
#include "include/core/SkRefCnt.h"
#include "include/core/SkScalar.h"
#include "include/core/SkSize.h"
#include "include/core/SkString.h"
#include "include/core/SkTypeface.h"
#include "include/core/SkTypes.h"
#include "src/core/SkBlurMask.h"
#include "tools/ToolUtils.h"
// This GM tests out the SkBlurMaskFilter's kIgnoreTransform flag. That flag causes the blur mask
// filter to not apply the CTM to the blur's radius.
class BlurIgnoreXformGM : public skiagm::GM {
public:
enum class DrawType {
kCircle,
kRect,
kRRect,
};
BlurIgnoreXformGM(DrawType drawType) : fDrawType(drawType) { }
protected:
bool runAsBench() const override { return true; }
SkString onShortName() override {
SkString name;
name.printf("blur_ignore_xform_%s",
DrawType::kCircle == fDrawType ? "circle"
: DrawType::kRect == fDrawType ? "rect" : "rrect");
return name;
}
SkISize onISize() override {
return SkISize::Make(375, 475);
}
void onOnceBeforeDraw() override {
for (int i = 0; i < kNumBlurs; ++i) {
fBlurFilters[i] = SkMaskFilter::MakeBlur(
kNormal_SkBlurStyle,
SkBlurMask::ConvertRadiusToSigma(SkIntToScalar(20)),
kBlurFlags[i].fRespectCTM);
}
}
void onDraw(SkCanvas* canvas) override {
SkPaint paint;
paint.setColor(SK_ColorBLACK);
paint.setAntiAlias(true);
canvas->translate(10, 25);
canvas->save();
canvas->translate(80, 0);
for (size_t i = 0; i < kNumBlurs; ++i) {
SkAutoCanvasRestore autoRestore(canvas, true);
canvas->translate(SkIntToScalar(i * 150), 0);
for (auto scale : kMatrixScales) {
canvas->save();
canvas->scale(scale.fScale, scale.fScale);
static const SkScalar kRadius = 20.0f;
SkScalar coord = 50.0f * 1.0f / scale.fScale;
SkRect rect = SkRect::MakeXYWH(coord - kRadius , coord - kRadius,
2 * kRadius, 2 * kRadius);
SkRRect rrect = SkRRect::MakeRectXY(rect, kRadius/2.0f, kRadius/2.0f);
paint.setMaskFilter(fBlurFilters[i]);
for (int j = 0; j < 2; ++j) {
canvas->save();
canvas->translate(10 * (1 - j), 10 * (1 - j));
if (DrawType::kCircle == fDrawType) {
canvas->drawCircle(coord, coord, kRadius, paint);
} else if (DrawType::kRect == fDrawType) {
canvas->drawRect(rect, paint);
} else {
canvas->drawRRect(rrect, paint);
}
paint.setMaskFilter(nullptr);
canvas->restore();
}
canvas->restore();
canvas->translate(0, SkIntToScalar(150));
}
}
canvas->restore();
if (kBench_Mode != this->getMode()) {
this->drawOverlay(canvas);
}
}
void drawOverlay(SkCanvas* canvas) {
canvas->translate(10, 0);
SkFont font(ToolUtils::create_portable_typeface());
canvas->save();
for (int i = 0; i < kNumBlurs; ++i) {
canvas->drawString(kBlurFlags[i].fName, 100, 0, font, SkPaint());
canvas->translate(SkIntToScalar(130), 0);
}
canvas->restore();
for (auto scale : kMatrixScales) {
canvas->drawString(scale.fName, 0, 50, font, SkPaint());
canvas->translate(0, SkIntToScalar(150));
}
}
private:
inline static constexpr int kNumBlurs = 2;
static const struct BlurFlags {
bool fRespectCTM;
const char* fName;
} kBlurFlags[kNumBlurs];
static const struct MatrixScale {
float fScale;
const char* fName;
} kMatrixScales[3];
DrawType fDrawType;
sk_sp<SkMaskFilter> fBlurFilters[kNumBlurs];
using INHERITED = skiagm::GM;
};
const BlurIgnoreXformGM::BlurFlags BlurIgnoreXformGM::kBlurFlags[] = {
{true, "none"},
{false, "IgnoreTransform"}
};
const BlurIgnoreXformGM::MatrixScale BlurIgnoreXformGM::kMatrixScales[] = {
{1.0f, "Identity"},
{0.5f, "Scale = 0.5"},
{2.0f, "Scale = 2.0"}
};
DEF_GM(return new BlurIgnoreXformGM(BlurIgnoreXformGM::DrawType::kCircle);)
DEF_GM(return new BlurIgnoreXformGM(BlurIgnoreXformGM::DrawType::kRect);)
DEF_GM(return new BlurIgnoreXformGM(BlurIgnoreXformGM::DrawType::kRRect);)