epoger@google.com | ec3ed6a | 2011-07-28 14:26:00 +0000 | [diff] [blame] | 1 | |
| 2 | /* |
| 3 | * Copyright 2011 Google Inc. |
| 4 | * |
| 5 | * Use of this source code is governed by a BSD-style license that can be |
| 6 | * found in the LICENSE file. |
| 7 | */ |
reed@google.com | 43c50c8 | 2011-04-14 15:50:52 +0000 | [diff] [blame] | 8 | #include "Test.h" |
| 9 | #include "SkColor.h" |
| 10 | #include "SkColorFilter.h" |
| 11 | #include "SkRandom.h" |
| 12 | #include "SkXfermode.h" |
| 13 | |
| 14 | static SkFlattenable* reincarnate_flattenable(SkFlattenable* obj) { |
reed@google.com | 43c50c8 | 2011-04-14 15:50:52 +0000 | [diff] [blame] | 15 | SkFlattenableWriteBuffer wb(1024); |
djsollen@google.com | cefc865 | 2012-03-26 15:52:10 +0000 | [diff] [blame] | 16 | wb.writeFlattenable(obj); |
reed@google.com | 43c50c8 | 2011-04-14 15:50:52 +0000 | [diff] [blame] | 17 | |
| 18 | size_t size = wb.size(); |
| 19 | SkAutoSMalloc<1024> storage(size); |
| 20 | // make a copy into storage |
| 21 | wb.flatten(storage.get()); |
| 22 | |
| 23 | SkFlattenableReadBuffer rb(storage.get(), size); |
djsollen@google.com | cefc865 | 2012-03-26 15:52:10 +0000 | [diff] [blame] | 24 | return rb.readFlattenable(); |
reed@google.com | 43c50c8 | 2011-04-14 15:50:52 +0000 | [diff] [blame] | 25 | } |
| 26 | |
| 27 | template <typename T> T* reincarnate(T* obj) { |
| 28 | return (T*)reincarnate_flattenable(obj); |
| 29 | } |
| 30 | |
| 31 | /////////////////////////////////////////////////////////////////////////////// |
| 32 | |
| 33 | #define ILLEGAL_MODE ((SkXfermode::Mode)-1) |
| 34 | |
| 35 | static void test_asColorMode(skiatest::Reporter* reporter) { |
| 36 | SkRandom rand; |
| 37 | |
| 38 | for (int mode = 0; mode <= SkXfermode::kLastMode; mode++) { |
| 39 | SkColor color = rand.nextU(); |
| 40 | |
| 41 | // ensure we always get a filter, by avoiding the possibility of a |
| 42 | // special case that would return NULL (if color's alpha is 0 or 0xFF) |
| 43 | color = SkColorSetA(color, 0x7F); |
| 44 | |
| 45 | SkColorFilter* cf = SkColorFilter::CreateModeFilter(color, |
| 46 | (SkXfermode::Mode)mode); |
| 47 | |
| 48 | // allow for no filter if we're in Dst mode (its a no op) |
| 49 | if (SkXfermode::kDst_Mode == mode && NULL == cf) { |
| 50 | continue; |
| 51 | } |
| 52 | |
| 53 | SkAutoUnref aur(cf); |
| 54 | REPORTER_ASSERT(reporter, cf); |
| 55 | |
| 56 | SkColor c = ~color; |
| 57 | SkXfermode::Mode m = ILLEGAL_MODE; |
| 58 | |
| 59 | SkColor expectedColor = color; |
| 60 | SkXfermode::Mode expectedMode = (SkXfermode::Mode)mode; |
| 61 | |
| 62 | // SkDebugf("--- mc [%d %x] ", mode, color); |
| 63 | |
| 64 | REPORTER_ASSERT(reporter, cf->asColorMode(&c, &m)); |
| 65 | // handle special-case folding by the factory |
| 66 | if (SkXfermode::kClear_Mode == mode) { |
| 67 | if (c != expectedColor) { |
| 68 | expectedColor = 0; |
| 69 | } |
| 70 | if (m != expectedMode) { |
| 71 | expectedMode = SkXfermode::kSrc_Mode; |
| 72 | } |
| 73 | } |
| 74 | |
| 75 | // SkDebugf("--- got [%d %x] expected [%d %x]\n", m, c, expectedMode, expectedColor); |
| 76 | |
| 77 | REPORTER_ASSERT(reporter, c == expectedColor); |
| 78 | REPORTER_ASSERT(reporter, m == expectedMode); |
| 79 | |
| 80 | { |
| 81 | SkColorFilter* cf2 = reincarnate(cf); |
| 82 | SkAutoUnref aur2(cf2); |
| 83 | REPORTER_ASSERT(reporter, cf2); |
| 84 | |
| 85 | SkColor c2 = ~color; |
| 86 | SkXfermode::Mode m2 = ILLEGAL_MODE; |
| 87 | REPORTER_ASSERT(reporter, cf2->asColorMode(&c2, &m2)); |
| 88 | REPORTER_ASSERT(reporter, c2 == expectedColor); |
| 89 | REPORTER_ASSERT(reporter, m2 == expectedMode); |
| 90 | } |
| 91 | } |
| 92 | } |
| 93 | |
| 94 | #include "TestClassDef.h" |
| 95 | DEFINE_TESTCLASS("ColorFilter", ColorFilterTestClass, test_asColorMode) |