skia2/bench/BlurRectsBench.cpp
Mike Reed 30bc527fd6 Revert "Reland "Revert "Use flat version of path-direction enum"""
This reverts commit 7cda6f3743.

Reason for revert: legacy convexity code removed -- google3 should be ok

Original change's description:
> Reland "Revert "Use flat version of path-direction enum""
>
> This reverts commit 1792b19485.
>
> Reason for revert: need to update legacy_convexity, still used by google3
>
> Original change's description:
> > Revert "Revert "Use flat version of path-direction enum""
> >
> > This reverts commit 0dacc6b7d3.
> >
> > Change-Id: Ie103e9f36b07e4ee256a3688a4decf3a6dd74314
> > Reviewed-on: https://skia-review.googlesource.com/c/skia/+/255832
> > Auto-Submit: Mike Reed <reed@google.com>
> > Reviewed-by: Mike Reed <reed@google.com>
> > Commit-Queue: Mike Reed <reed@google.com>
>
> TBR=reed@google.com
>
> Change-Id: I0ecea0eb8a237298c6b908cc4bfd1cacdfc5b900
> No-Presubmit: true
> No-Tree-Checks: true
> No-Try: true
> Reviewed-on: https://skia-review.googlesource.com/c/skia/+/255976
> Reviewed-by: Mike Reed <reed@google.com>
> Commit-Queue: Mike Reed <reed@google.com>

TBR=reed@google.com

Change-Id: I3529139bb391c4f62ce5cd0744cdf38a13b71d78
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/255984
Commit-Queue: Mike Reed <reed@google.com>
Reviewed-by: Mike Reed <reed@google.com>
2019-11-22 19:09:54 +00:00

81 lines
2.3 KiB
C++

/*
* Copyright 2014 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#include "bench/Benchmark.h"
#include "include/core/SkCanvas.h"
#include "include/core/SkMaskFilter.h"
#include "include/core/SkPaint.h"
#include "include/core/SkPath.h"
#include "include/core/SkRect.h"
#include "include/core/SkString.h"
class BlurRectsBench : public Benchmark {
public:
BlurRectsBench(SkRect outer, SkRect inner, SkScalar radius) {
fRadius = radius;
fOuter = outer;
fInner = inner;
}
const char* onGetName() override {
return fName.c_str();
}
void setName(const SkString& name) {
fName = name;
}
void onDraw(int loops, SkCanvas* canvas) override {
SkPaint paint;
paint.setMaskFilter(SkMaskFilter::MakeBlur(kNormal_SkBlurStyle, fRadius));
SkPath path;
path.addRect(fOuter, SkPathDirection::kCW);
path.addRect(fInner, SkPathDirection::kCW);
for (int i = 0; i < loops; i++) {
canvas->drawPath(path, paint);
}
}
private:
SkString fName;
SkRect fOuter;
SkRect fInner;
SkScalar fRadius;
typedef Benchmark INHERITED;
};
class BlurRectsNinePatchBench: public BlurRectsBench {
public:
BlurRectsNinePatchBench(SkRect outer, SkRect inner, SkScalar radius)
: INHERITED(outer, inner, radius) {
this->setName(SkString("blurrectsninepatch"));
}
private:
typedef BlurRectsBench INHERITED;
};
class BlurRectsNonNinePatchBench: public BlurRectsBench {
public:
BlurRectsNonNinePatchBench(SkRect outer, SkRect inner, SkScalar radius)
: INHERITED(outer, inner, radius) {
SkString name;
this->setName(SkString("blurrectsnonninepatch"));
}
private:
typedef BlurRectsBench INHERITED;
};
DEF_BENCH(return new BlurRectsNinePatchBench(SkRect::MakeXYWH(10, 10, 100, 100),
SkRect::MakeXYWH(20, 20, 60, 60),
2.3f);)
DEF_BENCH(return new BlurRectsNonNinePatchBench(SkRect::MakeXYWH(10, 10, 100, 100),
SkRect::MakeXYWH(50, 50, 10, 10),
4.3f);)