OLD | NEW |
---|---|
1 #include "Test.h" | 1 #include "Test.h" |
2 #include "TestClassDef.h" | 2 #include "TestClassDef.h" |
3 | 3 |
4 #include "SkPixelRef.h" | 4 #include "SkPixelRef.h" |
5 #include "SkMallocPixelRef.h" | 5 #include "SkMallocPixelRef.h" |
6 | 6 |
7 static void test_info(skiatest::Reporter* reporter) { | |
8 static const struct { | |
9 SkBitmap::Config fConfig; | |
10 SkAlphaType fAlphaType; | |
11 SkColorType fExpectedColorType; | |
12 bool fExpectedSuccess; | |
13 } gRec[] = { | |
14 { SkBitmap::kNo_Config, kPremul_SkAlphaType, kPMColor_SkColor Type, false }, | |
scroggo
2013/12/09 21:33:41
Why isn't kIndex8_Config tested here?
reed1
2013/12/09 21:46:14
Done.
| |
15 { SkBitmap::kARGB_8888_Config, kPremul_SkAlphaType, kPMColor_SkColor Type, true }, | |
16 { SkBitmap::kARGB_8888_Config, kOpaque_SkAlphaType, kPMColor_SkColor Type, true }, | |
17 { SkBitmap::kRGB_565_Config, kOpaque_SkAlphaType, kRGB_565_SkColor Type, true }, | |
18 { SkBitmap::kARGB_4444_Config, kPremul_SkAlphaType, kARGB_4444_SkCol orType, true }, | |
19 { SkBitmap::kARGB_4444_Config, kOpaque_SkAlphaType, kARGB_4444_SkCol orType, true }, | |
20 { SkBitmap::kA8_Config, kPremul_SkAlphaType, kAlpha_8_SkColor Type, true }, | |
21 { SkBitmap::kA8_Config, kOpaque_SkAlphaType, kAlpha_8_SkColor Type, true }, | |
22 }; | |
23 | |
24 SkBitmap bitmap; | |
25 SkImageInfo info; | |
26 | |
27 for (size_t i = 0; i < SK_ARRAY_COUNT(gRec); ++i) { | |
28 bool success = bitmap.setConfig(gRec[i].fConfig, 10, 10, 0, gRec[i].fAlp haType); | |
29 REPORTER_ASSERT(reporter, success); | |
30 success = bitmap.asImageInfo(&info); | |
31 REPORTER_ASSERT(reporter, success == gRec[i].fExpectedSuccess); | |
32 if (gRec[i].fExpectedSuccess) { | |
33 REPORTER_ASSERT(reporter, info.fAlphaType == gRec[i].fAlphaType); | |
34 REPORTER_ASSERT(reporter, info.fColorType == gRec[i].fExpectedColorT ype); | |
35 } | |
36 } | |
37 } | |
38 | |
7 namespace { | 39 namespace { |
8 | 40 |
9 class TestListener : public SkPixelRef::GenIDChangeListener { | 41 class TestListener : public SkPixelRef::GenIDChangeListener { |
10 public: | 42 public: |
11 explicit TestListener(int* ptr) : fPtr(ptr) {} | 43 explicit TestListener(int* ptr) : fPtr(ptr) {} |
12 void onChange() SK_OVERRIDE { (*fPtr)++; } | 44 void onChange() SK_OVERRIDE { (*fPtr)++; } |
13 private: | 45 private: |
14 int* fPtr; | 46 int* fPtr; |
15 }; | 47 }; |
16 | 48 |
(...skipping 22 matching lines...) Expand all Loading... | |
39 // Force the generation ID to be recalculated, then add a listener. | 71 // Force the generation ID to be recalculated, then add a listener. |
40 REPORTER_ASSERT(r, 0 != pixelRef.getGenerationID()); | 72 REPORTER_ASSERT(r, 0 != pixelRef.getGenerationID()); |
41 pixelRef.addGenIDChangeListener(SkNEW_ARGS(TestListener, (&count))); | 73 pixelRef.addGenIDChangeListener(SkNEW_ARGS(TestListener, (&count))); |
42 pixelRef.notifyPixelsChanged(); | 74 pixelRef.notifyPixelsChanged(); |
43 REPORTER_ASSERT(r, 1 == count); | 75 REPORTER_ASSERT(r, 1 == count); |
44 | 76 |
45 // Quick check that NULL is safe. | 77 // Quick check that NULL is safe. |
46 REPORTER_ASSERT(r, 0 != pixelRef.getGenerationID()); | 78 REPORTER_ASSERT(r, 0 != pixelRef.getGenerationID()); |
47 pixelRef.addGenIDChangeListener(NULL); | 79 pixelRef.addGenIDChangeListener(NULL); |
48 pixelRef.notifyPixelsChanged(); | 80 pixelRef.notifyPixelsChanged(); |
81 | |
82 test_info(r); | |
49 } | 83 } |
OLD | NEW |