Index: src/gpu/GrSwizzle.h |
diff --git a/src/gpu/GrSwizzle.h b/src/gpu/GrSwizzle.h |
index 87ea9534b9e021bfc6d5b1d0e942b1c5168307fd..6509362187cb89026814d1e6e716db77c06c1aaf 100644 |
--- a/src/gpu/GrSwizzle.h |
+++ b/src/gpu/GrSwizzle.h |
@@ -9,6 +9,7 @@ |
#define GrSwizzle_DEFINED |
#include "GrTypes.h" |
+#include "GrColor.h" |
/** Represents a rgba swizzle. It can be converted either into a string or a eight bit int. |
Currently there is no way to specify an arbitrary swizzle, just some static swizzles and an |
@@ -17,6 +18,17 @@ class GrSwizzle { |
public: |
GrSwizzle() { *this = RGBA(); } |
+ GrSwizzle(const GrSwizzle& that) { *this = that; } |
+ |
+ void setFromKey(uint8_t key) { |
+ fKey = key; |
+ for (int i = 0; i < 4; ++i) { |
+ fSwiz[i] = IdxToChar(key & 3); |
+ key >>= 2; |
+ } |
+ SkASSERT(fSwiz[4] == 0); |
+ } |
+ |
GrSwizzle& operator=(const GrSwizzle& that) { |
memcpy(this, &that, sizeof(GrSwizzle)); |
return *this; |
@@ -32,6 +44,29 @@ public: |
/** 4 char null terminated string consisting only of chars 'r', 'g', 'b', 'a'. */ |
const char* c_str() const { return fSwiz; } |
+ GrColor applyTo(GrColor color) const { |
+ int idx; |
+ uint32_t key = fKey; |
+ |
+ // Index of the input color that should be mapped to output r. |
+ idx = (key & 3); |
+ uint32_t outR = (color >> idx * 8) & 0xFF; |
+ key >>= 2; |
+ |
+ idx = (key & 3); |
+ uint32_t outG = (color >> idx * 8) & 0xFF; |
+ key >>= 2; |
+ |
+ idx = (key & 3); |
+ uint32_t outB = (color >> idx * 8) & 0xFF; |
+ key >>= 2; |
+ |
+ idx = (key & 3); |
+ uint32_t outA = (color >> idx * 8) & 0xFF; |
+ |
+ return GrColorPackRGBA(outR, outG, outB, outA); |
+ } |
+ |
static const GrSwizzle& RGBA() { |
static GrSwizzle gRGBA("rgba"); |
return gRGBA; |
@@ -59,19 +94,32 @@ private: |
static int CharToIdx(char c) { |
switch (c) { |
case 'r': |
- return 0; |
+ return (GrColor_SHIFT_R / 8); |
case 'g': |
- return 1; |
+ return (GrColor_SHIFT_G / 8); |
case 'b': |
- return 2; |
+ return (GrColor_SHIFT_B/ 8); |
case 'a': |
- return 3; |
+ return (GrColor_SHIFT_A / 8); |
default: |
SkFAIL("Invalid swizzle char"); |
return 0; |
} |
} |
+ static /* constexpr */ char IToC(int idx) { |
+ return (8*idx) == GrColor_SHIFT_R ? 'r' : |
+ (8*idx) == GrColor_SHIFT_G ? 'g' : |
+ (8*idx) == GrColor_SHIFT_B ? 'b' : |
+ 'a'; |
+ } |
+ |
+ static char IdxToChar(int c) { |
+ // Hopefully this array gets computed at compile time. |
+ static const char gStr[4] = { IToC(0), IToC(1), IToC(2), IToC(3) }; |
+ return gStr[c]; |
+ } |
+ |
explicit GrSwizzle(const char* str) { |
SkASSERT(strlen(str) == 4); |
fSwiz[0] = str[0]; |
@@ -83,7 +131,6 @@ private: |
(CharToIdx(fSwiz[2]) << 4) | (CharToIdx(fSwiz[3]) << 6)); |
} |
- uint32_t* asUIntPtr() { return SkTCast<uint32_t*>(fSwiz); } |
uint32_t asUInt() const { return *SkTCast<const uint32_t*>(fSwiz); } |
GR_STATIC_ASSERT(sizeof(char[4]) == sizeof(uint32_t)); |