Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 /* | |
| 2 * Copyright 2016 Google Inc. | |
| 3 * | |
| 4 * Use of this source code is governed by a BSD-style license that can be | |
| 5 * found in the LICENSE file. | |
| 6 */ | |
| 7 | |
| 8 #include "SkArithmeticMode.h" | |
| 9 #include "SkLerpXfermode.h" | |
| 10 #include "SkMatrix.h" | |
| 11 #include "SkPixelXorXfermode.h" | |
| 12 #include "SkToFromValue.h" | |
| 13 #include "SkValueKeys.h" | |
| 14 #include "SkXfermode.h" | |
| 15 | |
| 16 //////////////////////////////////////////////////////////////////////////////// | |
| 17 | |
| 18 #define REQUIRE(cond) do { if (!(cond)) { SkASSERT(false); return false; } } whi le (false) | |
| 19 | |
| 20 #define OPTIONAL_KEY(VAL, KEY, PTR) \ | |
|
mtklein
2016/01/21 17:46:19
Update the spacing now that you've added _KEY?
hal.canary
2016/01/21 18:35:21
done.
| |
| 21 do { \ | |
| 22 if (auto v = (VAL).get(KEY)) { \ | |
| 23 REQUIRE(SkFromValue(*v, PTR)); \ | |
| 24 } \ | |
| 25 } while (false) | |
| 26 | |
| 27 #define MANDATORY_KEY(VAL, KEY, PTR) \ | |
| 28 do { \ | |
| 29 auto v = (VAL).get(KEY); \ | |
| 30 REQUIRE(v && SkFromValue(*v, PTR)); \ | |
| 31 } while (false) | |
| 32 | |
| 33 template<> bool SkFromValue<float>(const SkValue& val, float* f) { | |
| 34 REQUIRE(val.type() == SkValue::F32); | |
| 35 *f = val.f32(); | |
| 36 return true; | |
| 37 } | |
| 38 | |
| 39 template<> bool SkFromValue<int32_t>(const SkValue& val, int32_t* x) { | |
| 40 REQUIRE(val.type() == SkValue::S32); | |
| 41 *x = val.s32(); | |
| 42 return true; | |
| 43 } | |
| 44 | |
| 45 template<> bool SkFromValue<uint32_t>(const SkValue& val, uint32_t* x) { | |
| 46 REQUIRE(val.type() == SkValue::U32); | |
| 47 *x = val.u32(); | |
| 48 return true; | |
| 49 } | |
| 50 | |
| 51 //////////////////////////////////////////////////////////////////////////////// | |
| 52 | |
| 53 template<> SkValue SkToValue<SkMatrix>(const SkMatrix& mat) { | |
| 54 auto val = SkValue::Object(SkValue::Matrix); | |
| 55 for (int i = 0; i < 9; ++i) { | |
| 56 if (mat[i] != SkMatrix::I()[i]) { | |
| 57 val.set(i, SkValue::FromF32(mat[i])); | |
| 58 } | |
| 59 } | |
| 60 return val; | |
| 61 } | |
| 62 | |
| 63 template<> bool SkFromValue<SkMatrix>(const SkValue& val, SkMatrix* m){ | |
| 64 REQUIRE(val.type() == SkValue::Matrix); | |
| 65 *m = SkMatrix::I(); | |
| 66 for (int i = 0; i < 9; i++) { | |
| 67 OPTIONAL_KEY(val, i, &(*m)[i]); | |
| 68 } | |
| 69 return true; | |
| 70 } | |
| 71 | |
| 72 //////////////////////////////////////////////////////////////////////////////// | |
| 73 | |
| 74 template<> SkValue SkToValue<SkXfermode>(const SkXfermode* x) { | |
| 75 return x ? x->asValue() : SkValue::Object(SkValue::DefaultXfermode); | |
| 76 } | |
| 77 | |
| 78 template<> bool SkFromValue< SkAutoTUnref<SkXfermode> >( | |
| 79 const SkValue& val, SkAutoTUnref<SkXfermode>* dst) { | |
| 80 SkXfermode* mode; | |
| 81 REQUIRE(SkFromValue(val, &mode)); | |
| 82 dst->reset(mode); | |
| 83 return true; | |
| 84 } | |
| 85 | |
| 86 template<> bool SkFromValue<SkXfermode*>(const SkValue& val, SkXfermode** dst) { | |
| 87 switch (val.type()) { | |
|
mtklein
2016/01/21 17:46:19
I think we'll be happier in the long term if we sp
hal.canary
2016/01/21 18:35:21
I was considering that, but never got around to it
| |
| 88 case SkValue::DefaultXfermode: | |
| 89 *dst = nullptr; | |
| 90 return true; | |
| 91 case SkValue::ArithmeticXfermode: { | |
| 92 float k[4] = {0.0f, 0.0f, 0.0f, 0.0f}; | |
|
mtklein
2016/01/21 17:46:19
There's no need to initialize mandatory things, ri
hal.canary
2016/01/21 18:35:21
right. that was leftover.
| |
| 93 int32_t enforce = true; | |
| 94 MANDATORY_KEY(val, SkValueKeys::ArithmeticXfermode::kK0, &k[0]); | |
| 95 MANDATORY_KEY(val, SkValueKeys::ArithmeticXfermode::kK1, &k[1]); | |
| 96 MANDATORY_KEY(val, SkValueKeys::ArithmeticXfermode::kK2, &k[2]); | |
| 97 MANDATORY_KEY(val, SkValueKeys::ArithmeticXfermode::kK3, &k[3]); | |
| 98 OPTIONAL_KEY(val, SkValueKeys::ArithmeticXfermode::kEnforcePMColor, &enforce); | |
| 99 *dst = SkArithmeticMode::Create( | |
| 100 k[0], k[1], k[2], k[3], SkToBool(enforce)); | |
| 101 return true; | |
| 102 } | |
| 103 case SkValue::LerpXfermode: { | |
| 104 float scale = 0; | |
| 105 MANDATORY_KEY(val, SkValueKeys::LerpXfermode::kScale, &scale); | |
| 106 *dst = SkLerpXfermode::Create(scale); | |
| 107 return true; | |
| 108 } | |
| 109 case SkValue::PixelXorXfermode: { | |
| 110 uint32_t opColor = 0; | |
| 111 MANDATORY_KEY(val, SkValueKeys::PixelXorXfermode::kOpColor, &opColor ); | |
| 112 *dst = SkPixelXorXfermode::Create(opColor); | |
| 113 return true; | |
| 114 } | |
| 115 case SkValue::ProcCoeffXfermode: { | |
| 116 uint32_t mode = 0; | |
| 117 MANDATORY_KEY(val, SkValueKeys::ProcCoeffXfermode::kMode, &mode); | |
| 118 *dst = SkXfermode::Create((SkXfermode::Mode)mode); | |
| 119 return true; | |
| 120 } | |
| 121 default: | |
| 122 SkASSERT(false); | |
| 123 return false; | |
| 124 } | |
| 125 } | |
| 126 | |
| 127 //////////////////////////////////////////////////////////////////////////////// | |
| 128 | |
| 129 #undef REQUIRE | |
| 130 #undef OPTIONAL_KEY | |
| 131 #undef MANDATORY_KEY | |
| 132 | |
| OLD | NEW |