OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2013 Google Inc. | 2 * Copyright 2013 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 "CrashHandler.h" | 8 #include "CrashHandler.h" |
9 #include "DMJsonWriter.h" | 9 #include "DMJsonWriter.h" |
10 #include "DMSrcSink.h" | 10 #include "DMSrcSink.h" |
(...skipping 242 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
253 if (!encoded) { | 253 if (!encoded) { |
254 SkDebugf("Couldn't read %s.", path.c_str()); | 254 SkDebugf("Couldn't read %s.", path.c_str()); |
255 return; | 255 return; |
256 } | 256 } |
257 SkAutoTDelete<SkCodec> codec(SkCodec::NewFromData(encoded)); | 257 SkAutoTDelete<SkCodec> codec(SkCodec::NewFromData(encoded)); |
258 if (nullptr == codec.get()) { | 258 if (nullptr == codec.get()) { |
259 SkDebugf("Couldn't create codec for %s.", path.c_str()); | 259 SkDebugf("Couldn't create codec for %s.", path.c_str()); |
260 return; | 260 return; |
261 } | 261 } |
262 | 262 |
263 // Choose scales for scaling tests. | 263 // Native Scales |
264 // TODO (msarett): Implement scaling tests for SkImageDecoder in order to co mpare with these | 264 // TODO (msarett): Implement scaling tests for SkImageDecoder in order to co mpare with these |
265 // tests. SkImageDecoder supports downscales by integer fac tors. | 265 // tests. SkImageDecoder supports downscales by integer fac tors. |
266 // SkJpegCodec natively supports scaling to: 0.125, 0.25, 0.375, 0.5, 0.625, 0.75, 0.875 | 266 // SkJpegCodec natively supports scaling to: 0.125, 0.25, 0.375, 0.5, 0.625, 0.75, 0.875 |
267 // 0.1, 0.16, 0.2 etc allow us to test SkScaledCodec with sampleSize 10, 6, 5, etc | 267 const float nativeScales[] = { 0.125f, 0.25f, 0.375f, 0.5f, 0.625f, 0.750f, 0.875f, 1.0f }; |
268 | |
269 // SkScaledCodec Scales | |
scroggo
2015/09/02 15:54:16
I think it would make more sense to move the SkSca
msarett
2015/09/02 18:16:16
Done.
| |
270 // The native scales are included to make sure that SkScaledCodec defaults t o the native | |
271 // scaling strategy when possible. | |
272 // 0.1, 0.16, 0.2 etc allow us to test SkScaledCodec with sampleSize 10, 6, 5, etc. | |
268 // 0.4, 0.7 etc allow to test what happens when the client requests a scale that | 273 // 0.4, 0.7 etc allow to test what happens when the client requests a scale that |
269 // does not exactly match a sampleSize or native scaling capability | 274 // does not exactly match a sampleSize or native scaling capability. |
270 const float scales[] = { 0.1f, 0.125f, 0.166f, 0.2f, 0.25f, 0.333f, 0.375f, 0.4f, 0.5f, 0.6f, | 275 const float samplingScales[] = { 0.1f, 0.125f, 0.166f, 0.2f, 0.25f, 0.333f, 0.375f, 0.4f, 0.5f, |
271 0.625f, 0.750f, 0.8f, 0.875f, 1.0f }; | 276 0.6f, 0.625f, 0.750f, 0.8f, 0.875f, 1.0f }; |
272 | 277 |
273 const CodecSrc::Mode modes[] = { CodecSrc::kCodec_Mode, CodecSrc::kScaledCod ec_Mode, | 278 const CodecSrc::Mode nativeModes[] = { CodecSrc::kCodec_Mode, CodecSrc::kSca nline_Mode, |
274 CodecSrc::kScanline_Mode, CodecSrc::kScanline_Subset_Mode, CodecSrc: :kStripe_Mode, | 279 CodecSrc::kScanline_Subset_Mode, CodecSrc::kStripe_Mode, CodecSrc::k Subset_Mode }; |
275 CodecSrc::kSubset_Mode }; | |
276 | 280 |
277 const CodecSrc::DstColorType colorTypes[] = { CodecSrc::kGetFromCanvas_DstCo lorType, | 281 const CodecSrc::Mode samplingModes[] = { CodecSrc::kScaledCodec_Mode }; |
278 CodecSrc::kGrayscale_Always_DstColorType, CodecSrc::kIndex8_Always_D stColorType }; | |
279 | 282 |
280 for (float scale : scales) { | 283 CodecSrc::DstColorType colorTypes[3]; |
284 uint32_t numColorTypes; | |
285 switch (codec->getInfo().colorType()) { | |
286 case kGray_8_SkColorType: | |
287 // FIXME: Is this a long term solution for testing wbmps decodes to kIndex8? | |
288 // Further discussion on this topic is at skbug.com/3683 | |
289 colorTypes[0] = CodecSrc::kGetFromCanvas_DstColorType; | |
290 colorTypes[1] = CodecSrc::kGrayscale_Always_DstColorType; | |
291 colorTypes[2] = CodecSrc::kIndex8_Always_DstColorType; | |
292 numColorTypes = 3; | |
293 break; | |
294 case kIndex_8_SkColorType: | |
295 colorTypes[0] = CodecSrc::kGetFromCanvas_DstColorType; | |
296 colorTypes[1] = CodecSrc::kIndex8_Always_DstColorType; | |
297 numColorTypes = 2; | |
298 break; | |
299 default: | |
300 colorTypes[0] = CodecSrc::kGetFromCanvas_DstColorType; | |
301 numColorTypes = 1; | |
302 break; | |
303 } | |
304 | |
305 for (float scale : nativeScales) { | |
281 if (scale != 1.0f && (path.endsWith(".webp") || path.endsWith(".WEBP"))) { | 306 if (scale != 1.0f && (path.endsWith(".webp") || path.endsWith(".WEBP"))) { |
282 // FIXME: skbug.com/4038 Scaling webp seems to leave some pixels uni nitialized/ | 307 // FIXME: skbug.com/4038 Scaling webp seems to leave some pixels uni nitialized/ |
283 // compute their colors based on uninitialized values. | 308 // compute their colors based on uninitialized values. |
284 continue; | 309 continue; |
285 } | 310 } |
286 | 311 |
287 for (CodecSrc::Mode mode : modes) { | 312 for (CodecSrc::Mode mode : nativeModes) { |
288 for (CodecSrc::DstColorType colorType : colorTypes) { | 313 for (uint32_t i = 0; i < numColorTypes; i++) { |
289 push_codec_src(path, mode, colorType, scale); | 314 push_codec_src(path, mode, colorTypes[i], scale); |
290 } | 315 } |
291 } | 316 } |
292 } | 317 } |
318 | |
319 for (float scale : samplingScales) { | |
320 if (scale != 1.0f && (path.endsWith(".webp") || path.endsWith(".WEBP"))) { | |
321 // FIXME: skbug.com/4038 Scaling webp seems to leave some pixels uni nitialized/ | |
322 // compute their colors based on uninitialized values. | |
323 continue; | |
324 } | |
325 | |
326 for (CodecSrc::Mode mode : samplingModes) { | |
scroggo
2015/09/02 15:54:16
There is only one mode in samplingModes. Would it
msarett
2015/09/02 18:16:16
I think we may want to add a mode when we add subs
| |
327 for (uint32_t i = 0; i < numColorTypes; i++) { | |
328 push_codec_src(path, mode, colorTypes[i], scale); | |
329 } | |
330 } | |
331 } | |
293 } | 332 } |
294 | 333 |
295 static bool codec_supported(const char* ext) { | 334 static bool codec_supported(const char* ext) { |
296 // FIXME: Once other versions of SkCodec are available, we can add them to t his | 335 // FIXME: Once other versions of SkCodec are available, we can add them to t his |
297 // list (and eventually we can remove this check once they are all supported ). | 336 // list (and eventually we can remove this check once they are all supported ). |
298 static const char* const exts[] = { | 337 static const char* const exts[] = { |
299 "bmp", "gif", "jpg", "jpeg", "png", "ico", "wbmp", "webp", | 338 "bmp", "gif", "jpg", "jpeg", "png", "ico", "wbmp", "webp", |
300 "BMP", "GIF", "JPG", "JPEG", "PNG", "ICO", "WBMP", "WEBP", | 339 "BMP", "GIF", "JPG", "JPEG", "PNG", "ICO", "WBMP", "WEBP", |
301 }; | 340 }; |
302 | 341 |
(...skipping 621 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
924 } | 963 } |
925 return 0; | 964 return 0; |
926 } | 965 } |
927 | 966 |
928 #if !defined(SK_BUILD_FOR_IOS) | 967 #if !defined(SK_BUILD_FOR_IOS) |
929 int main(int argc, char** argv) { | 968 int main(int argc, char** argv) { |
930 SkCommandLineFlags::Parse(argc, argv); | 969 SkCommandLineFlags::Parse(argc, argv); |
931 return dm_main(); | 970 return dm_main(); |
932 } | 971 } |
933 #endif | 972 #endif |
OLD | NEW |