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 19:01:23
How far do you think we can get without having mor
hal.canary
2016/01/21 19:33:40
almost. OPTIONAL_KEY should still return false if
mtklein
2016/01/21 20:01:33
Why? We have a default value already, so it's not
| |
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 static bool defaultxfermode_from_value(const SkValue& val, | |
mtklein
2016/01/21 19:01:23
I'd slightly prefer from_value_DefaultXfermode, et
hal.canary
2016/01/21 19:33:40
done.
| |
79 SkAutoTUnref<SkXfermode>* dst) { | |
80 dst->reset(nullptr); | |
81 return true; | |
82 } | |
83 | |
84 static bool arithmeticxfermode_from_value(const SkValue& val, | |
85 SkAutoTUnref<SkXfermode>* dst) { | |
86 float k[4]; | |
87 int32_t enforce = true; | |
mtklein
2016/01/21 19:15:31
One of my goals in reducing the number of macros w
| |
88 using namespace SkValueKeys::ArithmeticXfermode; | |
89 MANDATORY_KEY(val, kK0, &k[0]); | |
90 MANDATORY_KEY(val, kK1, &k[1]); | |
91 MANDATORY_KEY(val, kK2, &k[2]); | |
92 MANDATORY_KEY(val, kK3, &k[3]); | |
93 OPTIONAL_KEY(val, kEnforcePMColor, &enforce); | |
94 dst->reset(SkArithmeticMode::Create( | |
95 k[0], k[1], k[2], k[3], SkToBool(enforce))); | |
96 return true; | |
97 } | |
98 | |
99 static bool lerpxfermode_from_value(const SkValue& val, | |
100 SkAutoTUnref<SkXfermode>* dst) { | |
101 float scale = 0; | |
102 MANDATORY_KEY(val, SkValueKeys::LerpXfermode::kScale, &scale); | |
103 dst->reset(SkLerpXfermode::Create(scale)); | |
104 return true; | |
105 } | |
106 | |
107 static bool pixelxorxfermode_from_value(const SkValue& val, | |
108 SkAutoTUnref<SkXfermode>* dst) { | |
109 uint32_t opColor = 0; | |
mtklein
2016/01/21 19:15:31
Same deal here:
uint32_t color;
REQUIRE(getT(val,
| |
110 MANDATORY_KEY(val, SkValueKeys::PixelXorXfermode::kOpColor, &opColor); | |
111 dst->reset(SkPixelXorXfermode::Create(opColor)); | |
112 return true; | |
113 } | |
114 | |
115 static bool proccoeffxfermode_from_value(const SkValue& val, | |
116 SkAutoTUnref<SkXfermode>* dst) { | |
117 uint32_t mode = 0; | |
mtklein
2016/01/21 19:15:31
Same deal here:
auto mode = val.get(kMode);
REQUI
| |
118 MANDATORY_KEY(val, SkValueKeys::ProcCoeffXfermode::kMode, &mode); | |
119 dst->reset(SkXfermode::Create((SkXfermode::Mode)mode)); | |
120 return true; | |
121 } | |
122 | |
123 template<> bool SkFromValue< SkAutoTUnref<SkXfermode> >( | |
124 const SkValue& val, SkAutoTUnref<SkXfermode>* dst) { | |
125 switch (val.type()) { | |
126 case SkValue::DefaultXfermode: | |
127 return defaultxfermode_from_value(val, dst); | |
mtklein
2016/01/21 19:01:23
This would be easier to read if they were each one
hal.canary
2016/01/21 19:33:40
done.
| |
128 case SkValue::ArithmeticXfermode: | |
129 return arithmeticxfermode_from_value(val, dst); | |
130 case SkValue::LerpXfermode: | |
131 return lerpxfermode_from_value(val, dst); | |
132 case SkValue::PixelXorXfermode: | |
133 return pixelxorxfermode_from_value(val, dst); | |
134 case SkValue::ProcCoeffXfermode: | |
135 return proccoeffxfermode_from_value(val, dst); | |
136 default: | |
137 REQUIRE(false); | |
138 } | |
139 } | |
140 | |
141 //////////////////////////////////////////////////////////////////////////////// | |
142 | |
143 #undef REQUIRE | |
144 #undef OPTIONAL_KEY | |
145 #undef MANDATORY_KEY | |
146 | |
OLD | NEW |