f168b86d7f
This idea came while commenting on https://codereview.chromium.org/343583005/ Since SkBenchmark, SkBenchLogger and SkGMBench are not part of the Skia library, they should not have the Sk prefix. BUG=None TEST=make all R=mtklein@google.com Author: tfarina@chromium.org Review URL: https://codereview.chromium.org/347823004
107 lines
3.2 KiB
C++
107 lines
3.2 KiB
C++
/*
|
|
* Copyright 2012 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 "SkDeferredCanvas.h"
|
|
#include "SkDevice.h"
|
|
#include "SkString.h"
|
|
|
|
class DeferredCanvasBench : public Benchmark {
|
|
public:
|
|
DeferredCanvasBench(const char name[]) {
|
|
fName.printf("deferred_canvas_%s", name);
|
|
}
|
|
|
|
enum {
|
|
CANVAS_WIDTH = 200,
|
|
CANVAS_HEIGHT = 200,
|
|
};
|
|
protected:
|
|
virtual const char* onGetName() {
|
|
return fName.c_str();
|
|
}
|
|
|
|
virtual void onDraw(const int loops, SkCanvas* canvas) {
|
|
#if 0 // what specifically are we interested in timing here?
|
|
SkBaseDevice *device = canvas->getDevice()->createCompatibleDevice(
|
|
SkBitmap::kARGB_8888_Config, CANVAS_WIDTH, CANVAS_HEIGHT, false);
|
|
|
|
SkAutoTUnref<SkDeferredCanvas> deferredCanvas(SkDeferredCanvas::Create(device));
|
|
device->unref();
|
|
|
|
initDeferredCanvas(deferredCanvas);
|
|
drawInDeferredCanvas(loops, deferredCanvas);
|
|
finalizeDeferredCanvas(deferredCanvas);
|
|
deferredCanvas->flush();
|
|
#endif
|
|
}
|
|
|
|
virtual void initDeferredCanvas(SkDeferredCanvas* canvas) = 0;
|
|
virtual void drawInDeferredCanvas(const int loops, SkDeferredCanvas* canvas) = 0;
|
|
virtual void finalizeDeferredCanvas(SkDeferredCanvas* canvas) = 0;
|
|
|
|
SkString fName;
|
|
|
|
private:
|
|
typedef Benchmark INHERITED;
|
|
};
|
|
|
|
class SimpleNotificationClient : public SkDeferredCanvas::NotificationClient {
|
|
public:
|
|
SimpleNotificationClient() : fDummy(false) {}
|
|
|
|
//bogus virtual implementations that just do something small
|
|
virtual void prepareForDraw() SK_OVERRIDE {fDummy = true;}
|
|
virtual void storageAllocatedForRecordingChanged(size_t) SK_OVERRIDE {fDummy = false;}
|
|
virtual void flushedDrawCommands() SK_OVERRIDE {fDummy = !fDummy;}
|
|
private:
|
|
bool fDummy;
|
|
|
|
typedef SkDeferredCanvas::NotificationClient INHERITED;
|
|
};
|
|
|
|
// Test that records very simple draw operations.
|
|
// This benchmark aims to capture performance fluctuations in the recording
|
|
// overhead of SkDeferredCanvas
|
|
class DeferredRecordBench : public DeferredCanvasBench {
|
|
public:
|
|
DeferredRecordBench()
|
|
: INHERITED("record") {
|
|
}
|
|
|
|
protected:
|
|
|
|
virtual void initDeferredCanvas(SkDeferredCanvas* canvas) SK_OVERRIDE {
|
|
canvas->setNotificationClient(&fNotificationClient);
|
|
}
|
|
|
|
virtual void drawInDeferredCanvas(const int loops, SkDeferredCanvas* canvas) SK_OVERRIDE {
|
|
SkRect rect;
|
|
rect.setXYWH(0, 0, 10, 10);
|
|
SkPaint paint;
|
|
for (int i = 0; i < loops; i++) {
|
|
canvas->save();
|
|
canvas->translate(SkIntToScalar(i * 27 % CANVAS_WIDTH), SkIntToScalar(i * 13 % CANVAS_HEIGHT));
|
|
canvas->drawRect(rect, paint);
|
|
canvas->restore();
|
|
}
|
|
}
|
|
|
|
virtual void finalizeDeferredCanvas(SkDeferredCanvas* canvas) SK_OVERRIDE {
|
|
canvas->clear(0x0);
|
|
canvas->setNotificationClient(NULL);
|
|
}
|
|
|
|
private:
|
|
typedef DeferredCanvasBench INHERITED;
|
|
SimpleNotificationClient fNotificationClient;
|
|
};
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
DEF_BENCH( return new DeferredRecordBench(); )
|