Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(582)

Side by Side Diff: src/effects/SkToFromValue.cpp

Issue 1585813004: SkValue: SkXfermode (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: comments from mtklein Created 4 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(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
OLDNEW
« src/core/SkValueKeys.h ('K') | « src/effects/SkToFromValue.h ('k') | tests/ValueTest.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698