Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(97)

Unified Diff: tools/VisualBench/VisualSKPBench.cpp

Issue 1443263002: Optimize visualbench offscreen blits (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Fix msvc warnings Created 5 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « tools/VisualBench/VisualSKPBench.h ('k') | tools/VisualBench/WrappedBenchmark.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tools/VisualBench/VisualSKPBench.cpp
diff --git a/tools/VisualBench/VisualSKPBench.cpp b/tools/VisualBench/VisualSKPBench.cpp
index 628265e53e103d9a485fd4d5c6dc76fc01c960a8..5d15d7ef2071c6ea7d35ccd027ff423d598e12b2 100644
--- a/tools/VisualBench/VisualSKPBench.cpp
+++ b/tools/VisualBench/VisualSKPBench.cpp
@@ -14,6 +14,7 @@
VisualSKPBench::VisualSKPBench(const char* name, const SkPicture* pic)
: fPic(SkRef(pic))
+ , fCullRect(fPic->cullRect().roundOut())
, fName(name) {
fUniqueName.printf("%s", name);
}
@@ -30,7 +31,17 @@ bool VisualSKPBench::isSuitableFor(Backend backend) {
return backend != kNonRendering_Backend;
}
+SkIPoint VisualSKPBench::onGetSize() {
+ return SkIPoint::Make(fCullRect.width(), fCullRect.height());
+}
+
void VisualSKPBench::onDraw(int loops, SkCanvas* canvas) {
+ bool isOffset = SkToBool(fCullRect.left() | fCullRect.top());
+ if (isOffset) {
+ canvas->save();
+ canvas->translate(SkIntToScalar(-fCullRect.left()), SkIntToScalar(-fCullRect.top()));
+ }
+
for (int i = 0; i < loops; i++) {
canvas->drawPicture(fPic);
#if SK_SUPPORT_GPU
@@ -40,4 +51,8 @@ void VisualSKPBench::onDraw(int loops, SkCanvas* canvas) {
}
#endif
}
+
+ if (isOffset) {
+ canvas->restore();
+ }
}
« no previous file with comments | « tools/VisualBench/VisualSKPBench.h ('k') | tools/VisualBench/WrappedBenchmark.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698