2014-08-01 14:46:52 +00: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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "SKPBench.h"
|
2014-10-21 19:29:25 +00:00
|
|
|
#include "SkCommandLineFlags.h"
|
2014-11-21 14:19:36 +00:00
|
|
|
#include "SkMultiPictureDraw.h"
|
|
|
|
#include "SkSurface.h"
|
2014-10-21 19:29:25 +00:00
|
|
|
|
2014-10-29 21:15:10 +00:00
|
|
|
DEFINE_int32(benchTile, 256, "Tile dimension used for SKP playback.");
|
2014-08-01 14:46:52 +00:00
|
|
|
|
2014-11-21 14:19:36 +00:00
|
|
|
SKPBench::SKPBench(const char* name, const SkPicture* pic, const SkIRect& clip, SkScalar scale,
|
|
|
|
bool useMultiPictureDraw)
|
2014-08-01 14:46:52 +00:00
|
|
|
: fPic(SkRef(pic))
|
|
|
|
, fClip(clip)
|
2014-09-10 19:05:59 +00:00
|
|
|
, fScale(scale)
|
2014-11-21 14:19:36 +00:00
|
|
|
, fName(name)
|
|
|
|
, fUseMultiPictureDraw(useMultiPictureDraw) {
|
2014-09-10 19:05:59 +00:00
|
|
|
fUniqueName.printf("%s_%.2g", name, scale); // Scale makes this unqiue for skiaperf.com traces.
|
2014-11-21 14:19:36 +00:00
|
|
|
if (useMultiPictureDraw) {
|
|
|
|
fUniqueName.append("_mpd");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
SKPBench::~SKPBench() {
|
|
|
|
for (int i = 0; i < fSurfaces.count(); ++i) {
|
|
|
|
fSurfaces[i]->unref();
|
|
|
|
}
|
2014-08-01 14:46:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const char* SKPBench::onGetName() {
|
|
|
|
return fName.c_str();
|
|
|
|
}
|
|
|
|
|
2014-09-10 19:05:59 +00:00
|
|
|
const char* SKPBench::onGetUniqueName() {
|
|
|
|
return fUniqueName.c_str();
|
|
|
|
}
|
|
|
|
|
2014-11-21 14:19:36 +00:00
|
|
|
void SKPBench::onPerCanvasPreDraw(SkCanvas* canvas) {
|
|
|
|
if (!fUseMultiPictureDraw) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
SkIRect bounds;
|
|
|
|
SkAssertResult(canvas->getClipDeviceBounds(&bounds));
|
|
|
|
|
|
|
|
int xTiles = SkScalarCeilToInt(bounds.width() / SkIntToScalar(FLAGS_benchTile));
|
|
|
|
int yTiles = SkScalarCeilToInt(bounds.height() / SkIntToScalar(FLAGS_benchTile));
|
|
|
|
|
|
|
|
fSurfaces.setReserve(xTiles * yTiles);
|
|
|
|
fTileRects.setReserve(xTiles * yTiles);
|
|
|
|
|
|
|
|
SkImageInfo ii = canvas->imageInfo().makeWH(FLAGS_benchTile, FLAGS_benchTile);
|
|
|
|
|
|
|
|
for (int y = bounds.fTop; y < bounds.fBottom; y += FLAGS_benchTile) {
|
|
|
|
for (int x = bounds.fLeft; x < bounds.fRight; x += FLAGS_benchTile) {
|
|
|
|
*fTileRects.append() = SkIRect::MakeXYWH(x, y, FLAGS_benchTile, FLAGS_benchTile);
|
|
|
|
*fSurfaces.push() = canvas->newSurface(ii);
|
|
|
|
fSurfaces.top()->getCanvas()->setMatrix(canvas->getTotalMatrix());
|
|
|
|
fSurfaces.top()->getCanvas()->scale(fScale, fScale);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void SKPBench::onPerCanvasPostDraw(SkCanvas* canvas) {
|
|
|
|
if (!fUseMultiPictureDraw) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Draw the last set of tiles into the master canvas in case we're
|
|
|
|
// saving the images
|
|
|
|
for (int i = 0; i < fTileRects.count(); ++i) {
|
|
|
|
canvas->drawImage(fSurfaces[i]->newImageSnapshot(),
|
|
|
|
SkIntToScalar(fTileRects[i].fLeft), SkIntToScalar(fTileRects[i].fTop));
|
|
|
|
SkSafeSetNull(fSurfaces[i]);
|
|
|
|
}
|
|
|
|
|
|
|
|
fSurfaces.rewind();
|
|
|
|
fTileRects.rewind();
|
|
|
|
}
|
|
|
|
|
2014-08-01 14:46:52 +00:00
|
|
|
bool SKPBench::isSuitableFor(Backend backend) {
|
|
|
|
return backend != kNonRendering_Backend;
|
|
|
|
}
|
|
|
|
|
|
|
|
SkIPoint SKPBench::onGetSize() {
|
|
|
|
return SkIPoint::Make(fClip.width(), fClip.height());
|
|
|
|
}
|
|
|
|
|
|
|
|
void SKPBench::onDraw(const int loops, SkCanvas* canvas) {
|
2014-11-21 14:19:36 +00:00
|
|
|
if (fUseMultiPictureDraw) {
|
|
|
|
for (int i = 0; i < loops; i++) {
|
|
|
|
SkMultiPictureDraw mpd;
|
2014-11-21 13:35:54 +00:00
|
|
|
|
2014-11-21 14:19:36 +00:00
|
|
|
for (int i = 0; i < fTileRects.count(); ++i) {
|
|
|
|
SkMatrix trans;
|
|
|
|
trans.setTranslate(-fTileRects[i].fLeft/fScale,
|
|
|
|
-fTileRects[i].fTop/fScale);
|
|
|
|
mpd.add(fSurfaces[i]->getCanvas(), fPic, &trans);
|
|
|
|
}
|
|
|
|
|
|
|
|
mpd.draw();
|
2014-11-21 13:35:54 +00:00
|
|
|
|
2014-11-21 14:19:36 +00:00
|
|
|
for (int i = 0; i < fTileRects.count(); ++i) {
|
|
|
|
fSurfaces[i]->getCanvas()->flush();
|
2014-11-21 13:35:54 +00:00
|
|
|
}
|
|
|
|
}
|
2014-11-21 14:19:36 +00:00
|
|
|
} else {
|
|
|
|
SkIRect bounds;
|
|
|
|
SkAssertResult(canvas->getClipDeviceBounds(&bounds));
|
|
|
|
|
|
|
|
SkAutoCanvasRestore overall(canvas, true/*save now*/);
|
|
|
|
canvas->scale(fScale, fScale);
|
|
|
|
|
|
|
|
for (int i = 0; i < loops; i++) {
|
|
|
|
for (int y = bounds.fTop; y < bounds.fBottom; y += FLAGS_benchTile) {
|
|
|
|
for (int x = bounds.fLeft; x < bounds.fRight; x += FLAGS_benchTile) {
|
|
|
|
SkAutoCanvasRestore perTile(canvas, true/*save now*/);
|
|
|
|
canvas->clipRect(SkRect::Make(
|
|
|
|
SkIRect::MakeXYWH(x, y, FLAGS_benchTile, FLAGS_benchTile)));
|
|
|
|
fPic->playback(canvas);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
canvas->flush();
|
|
|
|
}
|
2014-10-21 19:29:25 +00:00
|
|
|
}
|
2014-08-01 14:46:52 +00:00
|
|
|
}
|