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

Unified Diff: bench/subset/SubsetZoomBench.cpp

Issue 1387233002: Update Subset benches to support interlacing and fix bugs (Closed) Base URL: https://skia.googlesource.com/skia.git@limitScaled
Patch Set: Initialize colorCount before reading from it. Created 5 years, 2 months 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
Index: bench/subset/SubsetZoomBench.cpp
diff --git a/bench/subset/SubsetZoomBench.cpp b/bench/subset/SubsetZoomBench.cpp
index ffd86703ec2271e40fdc27c1679fe914f4b958ac..901fbb6082c4b83dc776228d6db33cafb7708378 100644
--- a/bench/subset/SubsetZoomBench.cpp
+++ b/bench/subset/SubsetZoomBench.cpp
@@ -62,14 +62,20 @@ void SubsetZoomBench::onDraw(int n, SkCanvas* canvas) {
for (int count = 0; count < n; count++) {
SkAutoTDelete<SkCodec> codec(SkCodec::NewFromStream(fStream->duplicate()));
const SkImageInfo info = codec->getInfo().makeColorType(fColorType);
- SkAutoTDeleteArray<uint8_t> row(new uint8_t[info.minRowBytes()]);
- codec->startScanlineDecode(info, nullptr, colors, &colorCount);
+ SkAutoTDeleteArray<uint8_t> row(nullptr);
+ if (codec->getScanlineOrder() == SkCodec::kTopDown_SkScanlineOrder) {
+ row.reset(new uint8_t[info.minRowBytes()]);
+ }
const int centerX = info.width() / 2;
const int centerY = info.height() / 2;
int w = fSubsetWidth;
int h = fSubsetHeight;
do {
+ SkDEBUGCODE(SkCodec::Result result = )
+ codec->startScanlineDecode(info, nullptr, colors, &colorCount);
+ SkASSERT(SkCodec::kSuccess == result);
+
const int subsetStartX = SkTMax(0, centerX - w / 2);
const int subsetStartY = SkTMax(0, centerY - h / 2);
const int subsetWidth = SkTMin(w, info.width() - subsetStartX);
@@ -81,12 +87,44 @@ void SubsetZoomBench::onDraw(int n, SkCanvas* canvas) {
alloc_pixels(&bitmap, subsetInfo, colors, colorCount);
scroggo 2015/10/08 18:29:08 Since we do a new allocation each time, we can alw
msarett 2015/10/08 18:52:42 Acknowledged.
uint32_t bpp = info.bytesPerPixel();
- codec->skipScanlines(subsetStartY);
- for (int y = 0; y < subsetHeight; y++) {
- codec->getScanlines(row.get(), 1, 0);
- memcpy(bitmap.getAddr(0, y), row.get() + subsetStartX * bpp,
- subsetWidth * bpp);
+
+ SkDEBUGCODE(result = ) codec->skipScanlines(subsetStartY);
+ SkASSERT(SkCodec::kSuccess == result);
+
+ switch (codec->getScanlineOrder()) {
+ case SkCodec::kTopDown_SkScanlineOrder:
+ for (int y = 0; y < subsetHeight; y++) {
+ SkDEBUGCODE(result = ) codec->getScanlines(row.get(), 1, 0);
+ SkASSERT(SkCodec::kSuccess == result);
+
+ memcpy(bitmap.getAddr(0, y), row.get() + subsetStartX * bpp,
+ subsetWidth * bpp);
+ }
+ break;
+ case SkCodec::kNone_SkScanlineOrder: {
+ // decode all scanlines that intersect the subset, and copy the subset
+ // into the output.
+ SkImageInfo stripeInfo = info.makeWH(info.width(), subsetHeight);
+ SkBitmap stripeBm;
+ alloc_pixels(&stripeBm, stripeInfo, colors, colorCount);
scroggo 2015/10/08 18:29:08 Here and in SubsetTranslateBench, we're doing some
msarett 2015/10/08 18:52:41 This is probably the right decision. In general,
+
+ SkDEBUGCODE(result = ) codec->getScanlines(stripeBm.getPixels(),
+ subsetHeight, stripeBm.rowBytes());
+ SkASSERT(SkCodec::kSuccess == result);
+
+ for (int y = 0; y < subsetHeight; y++) {
+ memcpy(bitmap.getAddr(0, y),
+ stripeBm.getAddr(subsetStartX, y),
+ subsetWidth * bpp);
+ }
+ break;
+ }
+ default:
+ // We currently are only testing kTopDown and kNone, which are the only
+ // two used by the subsets we care about. skbug.com/4428
+ SkASSERT(false);
}
+
w <<= 1;
h <<= 1;
} while (w < 2 * info.width() || h < 2 * info.height());
@@ -95,7 +133,7 @@ void SubsetZoomBench::onDraw(int n, SkCanvas* canvas) {
for (int count = 0; count < n; count++) {
int width, height;
SkAutoTDelete<SkImageDecoder> decoder(SkImageDecoder::Factory(fStream));
- decoder->buildTileIndex(fStream->duplicate(), &width, &height);
+ SkAssertResult(decoder->buildTileIndex(fStream->duplicate(), &width, &height));
const int centerX = width / 2;
const int centerY = height / 2;
@@ -109,7 +147,7 @@ void SubsetZoomBench::onDraw(int n, SkCanvas* canvas) {
SkBitmap bitmap;
SkIRect rect = SkIRect::MakeXYWH(subsetStartX, subsetStartY, subsetWidth,
subsetHeight);
- decoder->decodeSubset(&bitmap, rect, fColorType);
+ SkAssertResult(decoder->decodeSubset(&bitmap, rect, fColorType));
w <<= 1;
h <<= 1;
} while (w < 2 * width || h < 2 * height);
« bench/subset/SubsetTranslateBench.cpp ('K') | « bench/subset/SubsetTranslateBench.cpp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698