30bc527fd6
This reverts commit7cda6f3743
. 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 commit1792b19485
. > > 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 commit0dacc6b7d3
. > > > > 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>
81 lines
2.3 KiB
C++
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);)
|