2014-04-10 20:16:13 +04:00
|
|
|
/*
|
|
|
|
* Copyright 2014 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
2014-06-19 23:32:29 +04:00
|
|
|
#include "Benchmark.h"
|
2014-04-10 20:16:13 +04:00
|
|
|
#include "SkBlurImageFilter.h"
|
|
|
|
#include "SkCanvas.h"
|
2014-06-19 23:32:29 +04:00
|
|
|
#include "SkMergeImageFilter.h"
|
2014-04-10 20:16:13 +04:00
|
|
|
|
|
|
|
enum { kNumInputs = 5 };
|
|
|
|
|
|
|
|
// Exercise a blur filter connected to 5 inputs of the same merge filter.
|
|
|
|
// This bench shows an improvement in performance once cacheing of re-used
|
|
|
|
// nodes is implemented, since the DAG is no longer flattened to a tree.
|
|
|
|
|
2014-06-19 23:32:29 +04:00
|
|
|
class ImageFilterDAGBench : public Benchmark {
|
2014-04-10 20:16:13 +04:00
|
|
|
public:
|
2014-07-01 19:43:42 +04:00
|
|
|
ImageFilterDAGBench() {}
|
2014-04-10 20:16:13 +04:00
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual const char* onGetName() SK_OVERRIDE {
|
|
|
|
return "image_filter_dag";
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual void onDraw(const int loops, SkCanvas* canvas) SK_OVERRIDE {
|
2014-07-01 19:43:42 +04:00
|
|
|
for (int j = 0; j < loops; j++) {
|
|
|
|
SkAutoTUnref<SkImageFilter> blur(SkBlurImageFilter::Create(20.0f, 20.0f));
|
|
|
|
SkImageFilter* inputs[kNumInputs];
|
|
|
|
for (int i = 0; i < kNumInputs; ++i) {
|
|
|
|
inputs[i] = blur.get();
|
|
|
|
}
|
|
|
|
SkAutoTUnref<SkImageFilter> merge(SkMergeImageFilter::Create(inputs, kNumInputs));
|
|
|
|
SkPaint paint;
|
|
|
|
paint.setImageFilter(merge);
|
|
|
|
SkRect rect = SkRect::Make(SkIRect::MakeWH(400, 400));
|
|
|
|
canvas->drawRect(rect, paint);
|
2014-04-10 20:16:13 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2014-06-19 23:32:29 +04:00
|
|
|
typedef Benchmark INHERITED;
|
2014-04-10 20:16:13 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
DEF_BENCH(return new ImageFilterDAGBench;)
|