OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2015 Google Inc. | 2 * Copyright 2015 Google Inc. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
6 */ | 6 */ |
7 | 7 |
8 #include "SkCodec.h" | 8 #include "SkCodec.h" |
9 #include "SkCodecPriv.h" | 9 #include "SkCodecPriv.h" |
10 #include "SkMath.h" | 10 #include "SkMath.h" |
(...skipping 240 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
251 | 251 |
252 sampler->setSampleY(sampleY); | 252 sampler->setSampleY(sampleY); |
253 | 253 |
254 int rowsDecoded; | 254 int rowsDecoded; |
255 const SkCodec::Result incResult = this->codec()->incrementalDecode(&
rowsDecoded); | 255 const SkCodec::Result incResult = this->codec()->incrementalDecode(&
rowsDecoded); |
256 if (incResult == SkCodec::kSuccess) { | 256 if (incResult == SkCodec::kSuccess) { |
257 return SkCodec::kSuccess; | 257 return SkCodec::kSuccess; |
258 } | 258 } |
259 SkASSERT(incResult == SkCodec::kIncompleteInput); | 259 SkASSERT(incResult == SkCodec::kIncompleteInput); |
260 | 260 |
261 // Count the rows that we decoded, and also did not skip. | 261 SkASSERT(rowsDecoded <= info.height()); |
262 const int trueRowsDecoded = (rowsDecoded + sampleY - 1) / sampleY; | |
263 this->codec()->fillIncompleteImage(info, pixels, rowBytes, options.f
ZeroInitialized, | 262 this->codec()->fillIncompleteImage(info, pixels, rowBytes, options.f
ZeroInitialized, |
264 info.height(), trueRowsDecoded); | 263 info.height(), rowsDecoded); |
265 return SkCodec::kIncompleteInput; | 264 return SkCodec::kIncompleteInput; |
266 } else if (startResult != SkCodec::kUnimplemented) { | 265 } else if (startResult != SkCodec::kUnimplemented) { |
267 return startResult; | 266 return startResult; |
268 } // kUnimplemented means use the old method. | 267 } // kUnimplemented means use the old method. |
269 } | 268 } |
270 | 269 |
271 // Start the scanline decode. | 270 // Start the scanline decode. |
272 SkCodec::Result result = this->codec()->startScanlineDecode(nativeInfo, | 271 SkCodec::Result result = this->codec()->startScanlineDecode(nativeInfo, |
273 &sampledOptions, options.fColorPtr, options.fColorCount); | 272 &sampledOptions, options.fColorPtr, options.fColorCount); |
274 if (SkCodec::kSuccess != result) { | 273 if (SkCodec::kSuccess != result) { |
(...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
349 void* rowPtr = SkTAddOffset<void>(pixels, rowBytes * get_dst_coo
rd(srcY, sampleY)); | 348 void* rowPtr = SkTAddOffset<void>(pixels, rowBytes * get_dst_coo
rd(srcY, sampleY)); |
350 SkSampler::Fill(fillInfo, rowPtr, rowBytes, fillValue, options.f
ZeroInitialized); | 349 SkSampler::Fill(fillInfo, rowPtr, rowBytes, fillValue, options.f
ZeroInitialized); |
351 } | 350 } |
352 return SkCodec::kIncompleteInput; | 351 return SkCodec::kIncompleteInput; |
353 } | 352 } |
354 default: | 353 default: |
355 SkASSERT(false); | 354 SkASSERT(false); |
356 return SkCodec::kUnimplemented; | 355 return SkCodec::kUnimplemented; |
357 } | 356 } |
358 } | 357 } |
OLD | NEW |