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

Unified Diff: src/effects/SkArithmeticMode.cpp

Issue 1585813004: SkValue: SkXfermode (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: 2016-01-14 (Thursday) 16:27:56 EST 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 side-by-side diff with in-line comments
Download patch
Index: src/effects/SkArithmeticMode.cpp
diff --git a/src/effects/SkArithmeticMode.cpp b/src/effects/SkArithmeticMode.cpp
index 87af82efdbc6d51a1c014c1f8cbfdd9c37012014..0b8b2c94952c82b368b92fc5ab6fb6f2f6df61e8 100644
--- a/src/effects/SkArithmeticMode.cpp
+++ b/src/effects/SkArithmeticMode.cpp
@@ -11,6 +11,7 @@
#include "SkWriteBuffer.h"
#include "SkString.h"
#include "SkUnPreMultiply.h"
+#include "SkValueKeys.h"
#if SK_SUPPORT_GPU
#include "SkArithmeticMode_gpu.h"
#endif
@@ -37,6 +38,17 @@ public:
bool asXPFactory(GrXPFactory**) const override;
#endif
+ SkValue represent() const override {
mtklein 2016/01/14 22:58:28 I don't yet see a need for key enums to be visible
hal.canary 2016/01/14 23:43:10 done.
+ auto value = SkValue::Object(SkValue::ArithmeticXfermode);
+ value.set(SkValueKeys::ArithmeticXfermode_K0, SkValue::FromF32(fK[0]));
+ value.set(SkValueKeys::ArithmeticXfermode_K1, SkValue::FromF32(fK[1]));
+ value.set(SkValueKeys::ArithmeticXfermode_K2, SkValue::FromF32(fK[2]));
+ value.set(SkValueKeys::ArithmeticXfermode_K3, SkValue::FromF32(fK[3]));
+ value.set(SkValueKeys::ArithmeticXfermode_EnforcePMColor,
+ SkValue::FromS32(fEnforcePMColor ? 1 : 0));
+ return value;
+ }
+
private:
SkArithmeticMode_scalar(SkScalar k1, SkScalar k2, SkScalar k3, SkScalar k4, bool enforcePMColor) {
fK[0] = k1;

Powered by Google App Engine
This is Rietveld 408576698