diff options
author | Florin Malita <fmalita@chromium.org> | 2017-05-01 16:27:02 -0400 |
---|---|---|
committer | Skia Commit-Bot <skia-commit-bot@chromium.org> | 2017-05-01 21:27:00 +0000 |
commit | c59a38d12dce287427f3d3fe1d4b3ad8052cda35 (patch) | |
tree | f7bdab61d54666368ade6378947331753f7511fc /bench/ClipMaskBench.cpp | |
parent | a6b72cb5729306fdd676d739c1e2c53afa0786a7 (diff) |
Add a clip mask bench
Change-Id: I230729492fc23e290136f7d62610abe5ca51c067
Reviewed-on: https://skia-review.googlesource.com/14941
Reviewed-by: Mike Reed <reed@google.com>
Commit-Queue: Florin Malita <fmalita@chromium.org>
Diffstat (limited to 'bench/ClipMaskBench.cpp')
-rw-r--r-- | bench/ClipMaskBench.cpp | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/bench/ClipMaskBench.cpp b/bench/ClipMaskBench.cpp new file mode 100644 index 0000000000..b678397816 --- /dev/null +++ b/bench/ClipMaskBench.cpp @@ -0,0 +1,68 @@ +/* + * Copyright 2017 Google Inc. + * + * Use of this source code is governed by a BSD-style license that can be + * found in the LICENSE file. + */ + +#include "Benchmark.h" +#include "sk_tool_utils.h" +#include "SkCanvas.h" +#include "SkColorSpace.h" +#include "SkImage.h" +#include "SkPictureRecorder.h" +#include "SkString.h" +#include "SkSurface.h" + +static void DrawMask(SkCanvas* canvas) { + sk_tool_utils::draw_checkerboard(canvas, SK_ColorTRANSPARENT, SK_ColorGREEN, 10); +} + +class ClipMaskBench : public Benchmark { +public: + using MaskMakerFunc = sk_sp<SkImage> (*)(int); + + ClipMaskBench(const char name[], const MaskMakerFunc maskMaker) + : fName(SkStringPrintf("clipmask_%s", name)) + , fClip(maskMaker(kSize)) {} + +protected: + const char* onGetName() override { return fName.c_str(); } + + void onDraw(int loops, SkCanvas* canvas) override { + SkCanvas::SaveLayerRec rec(nullptr, nullptr, nullptr, fClip, nullptr, 0); + + for (int i = 0; i < loops; ++i) { + canvas->saveLayer(rec); + canvas->drawColor(SK_ColorBLUE); + canvas->restore(); + } + } + +private: + static constexpr int kSize = 400; + + SkString fName; + sk_sp<SkImage> fClip; +}; + +DEF_BENCH(return new ClipMaskBench("a8", [](int size) -> sk_sp<SkImage> { + sk_sp<SkSurface> surface = SkSurface::MakeRaster(SkImageInfo::MakeA8(size, size)); + DrawMask(surface->getCanvas()); + return surface->makeImageSnapshot(); +});) + +DEF_BENCH(return new ClipMaskBench("8888", [](int size) -> sk_sp<SkImage> { + sk_sp<SkSurface> surface = SkSurface::MakeRasterN32Premul(size, size); + DrawMask(surface->getCanvas()); + return surface->makeImageSnapshot(); +});) + +DEF_BENCH(return new ClipMaskBench("picture", [](int size) -> sk_sp<SkImage> { + SkPictureRecorder recorder; + DrawMask(recorder.beginRecording(size, size)); + return SkImage::MakeFromPicture(recorder.finishRecordingAsPicture(), SkISize::Make(size, size), + nullptr, nullptr, SkImage::BitDepth::kU8, + SkColorSpace::MakeSRGB()); +});) + |