OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2014 Google Inc. | 2 * Copyright 2014 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 "SkTypes.h" | 8 #include "SkTypes.h" |
9 #include "Resources.h" | |
9 #include "Test.h" | 10 #include "Test.h" |
10 | 11 |
11 #if SK_SUPPORT_GPU | 12 #if SK_SUPPORT_GPU |
12 #include "GrContext.h" | 13 #include "GrContext.h" |
13 #endif | 14 #endif |
14 #include "SkImage.h" | 15 #include "SkImage.h" |
15 #include "SkSurface.h" | 16 #include "SkSurface.h" |
16 #include "SkReadBuffer.h" | 17 #include "SkReadBuffer.h" |
17 #include "SkWriteBuffer.h" | 18 #include "SkWriteBuffer.h" |
18 | 19 |
19 static void test_flatten(skiatest::Reporter* reporter, const SkImageInfo& info) { | 20 static void test_flatten(skiatest::Reporter* reporter, const SkImageInfo& info) { |
20 // just need a safe amount of storage, but ensure that it is 4-byte aligned. | 21 // just need a safe amount of storage, but ensure that it is 4-byte aligned. |
21 int32_t storage[(sizeof(SkImageInfo)*2) / sizeof(int32_t)]; | 22 int32_t storage[2000]; |
msarett
2016/07/29 15:31:27
Is this going to annoy Google3?
mtklein
2016/07/29 15:32:12
Probably. This is a test... just malloc it.
msarett
2016/07/29 15:37:15
SGTM. Done.
| |
22 SkBinaryWriteBuffer wb(storage, sizeof(storage)); | 23 SkBinaryWriteBuffer wb(storage, sizeof(storage)); |
23 info.flatten(wb); | 24 info.flatten(wb); |
24 SkASSERT(wb.bytesWritten() < sizeof(storage)); | 25 SkASSERT(wb.bytesWritten() < sizeof(storage)); |
25 | 26 |
26 SkReadBuffer rb(storage, wb.bytesWritten()); | 27 SkReadBuffer rb(storage, wb.bytesWritten()); |
27 | 28 |
28 // pick a noisy byte pattern, so we ensure that unflatten sets all of our fi elds | 29 // pick a noisy byte pattern, so we ensure that unflatten sets all of our fi elds |
29 SkImageInfo info2 = SkImageInfo::Make(0xB8, 0xB8, (SkColorType) 0xB8, (SkAlp haType) 0xB8); | 30 SkImageInfo info2 = SkImageInfo::Make(0xB8, 0xB8, (SkColorType) 0xB8, (SkAlp haType) 0xB8); |
30 | 31 |
31 info2.unflatten(rb); | 32 info2.unflatten(rb); |
32 REPORTER_ASSERT(reporter, rb.offset() == wb.bytesWritten()); | 33 REPORTER_ASSERT(reporter, rb.offset() == wb.bytesWritten()); |
33 | 34 |
34 REPORTER_ASSERT(reporter, info == info2); | 35 REPORTER_ASSERT(reporter, info == info2); |
35 } | 36 } |
36 | 37 |
37 DEF_TEST(ImageInfo_flattening, reporter) { | 38 DEF_TEST(ImageInfo_flattening, reporter) { |
39 sk_sp<SkData> data = | |
40 SkData::MakeFromFileName(GetResourcePath("icc_profiles/HP_ZR30w.icc ").c_str()); | |
41 sk_sp<SkColorSpace> space0 = SkColorSpace::NewICC(data->data(), data->size() ); | |
42 data = SkData::MakeFromFileName( GetResourcePath("icc_profiles/HP_Z32x.icc") .c_str()); | |
43 sk_sp<SkColorSpace> space1 = SkColorSpace::NewICC(data->data(), data->size() ); | |
44 data = SkData::MakeFromFileName(GetResourcePath("icc_profiles/upperLeft.icc" ).c_str()); | |
45 sk_sp<SkColorSpace> space2 = SkColorSpace::NewICC(data->data(), data->size() ); | |
46 data = SkData::MakeFromFileName(GetResourcePath("icc_profiles/upperRight.icc ").c_str()); | |
47 sk_sp<SkColorSpace> space3 = SkColorSpace::NewICC(data->data(), data->size() ); | |
48 | |
38 sk_sp<SkColorSpace> spaces[] = { | 49 sk_sp<SkColorSpace> spaces[] = { |
39 nullptr, | 50 nullptr, |
40 SkColorSpace::NewNamed(SkColorSpace::kSRGB_Named), | 51 SkColorSpace::NewNamed(SkColorSpace::kSRGB_Named), |
41 SkColorSpace::NewNamed(SkColorSpace::kAdobeRGB_Named), | 52 SkColorSpace::NewNamed(SkColorSpace::kAdobeRGB_Named), |
53 space0, | |
54 space1, | |
55 space2, | |
56 space3, | |
42 }; | 57 }; |
43 | 58 |
44 for (int ct = 0; ct <= kLastEnum_SkColorType; ++ct) { | 59 for (int ct = 0; ct <= kLastEnum_SkColorType; ++ct) { |
45 for (int at = 0; at <= kLastEnum_SkAlphaType; ++at) { | 60 for (int at = 0; at <= kLastEnum_SkAlphaType; ++at) { |
46 for (auto& cs : spaces) { | 61 for (auto& cs : spaces) { |
47 SkImageInfo info = SkImageInfo::Make(100, 200, | 62 SkImageInfo info = SkImageInfo::Make(100, 200, |
48 static_cast<SkColorType>(ct ), | 63 static_cast<SkColorType>(ct ), |
49 static_cast<SkAlphaType>(at ), | 64 static_cast<SkAlphaType>(at ), |
50 cs); | 65 cs); |
51 test_flatten(reporter, info); | 66 test_flatten(reporter, info); |
(...skipping 26 matching lines...) Expand all Loading... | |
78 auto surfaceTransparent(SkSurface::MakeRenderTarget(context, SkBudgeted::kNo , infoTransparent)); | 93 auto surfaceTransparent(SkSurface::MakeRenderTarget(context, SkBudgeted::kNo , infoTransparent)); |
79 check_isopaque(reporter, surfaceTransparent, false); | 94 check_isopaque(reporter, surfaceTransparent, false); |
80 | 95 |
81 SkImageInfo infoOpaque = SkImageInfo::MakeN32(5, 5, kOpaque_SkAlphaType); | 96 SkImageInfo infoOpaque = SkImageInfo::MakeN32(5, 5, kOpaque_SkAlphaType); |
82 auto surfaceOpaque(SkSurface::MakeRenderTarget(context,SkBudgeted::kNo, info Opaque)); | 97 auto surfaceOpaque(SkSurface::MakeRenderTarget(context,SkBudgeted::kNo, info Opaque)); |
83 | 98 |
84 check_isopaque(reporter, surfaceOpaque, true); | 99 check_isopaque(reporter, surfaceOpaque, true); |
85 } | 100 } |
86 | 101 |
87 #endif | 102 #endif |
OLD | NEW |