Index: src/core/Sk4px.h |
diff --git a/src/core/Sk4px.h b/src/core/Sk4px.h |
index 830e60a156567c2859a382a799926077cd6522ef..af078ca92b3151b6f7578d20161d5b7cd7d5dc0b 100644 |
--- a/src/core/Sk4px.h |
+++ b/src/core/Sk4px.h |
@@ -14,14 +14,22 @@ |
// 1, 2 or 4 SkPMColors, generally vectorized. |
class Sk4px : public Sk16b { |
public: |
- Sk4px(SkPMColor); // Duplicate 4x. |
- Sk4px(const Sk16b& v) : Sk16b(v) {} |
+ Sk4px(SkAlpha a) : INHERITED(a) {} // Duplicate 16x. |
+ Sk4px(SkPMColor); // Duplicate 4x. |
+ Sk4px(const Sk16b& v) : INHERITED(v) {} |
+ |
+ // ARGB argb XYZW xyzw -> AAAA aaaa XXXX xxxx |
+ Sk4px alphas() const; |
// When loading or storing fewer than 4 SkPMColors, we use the low lanes. |
static Sk4px Load4(const SkPMColor[4]); |
static Sk4px Load2(const SkPMColor[2]); |
static Sk4px Load1(const SkPMColor[1]); |
+ // Ditto for Alphas... Load2Alphas fills the low two lanes of Sk4px. |
+ static Sk4px Load4Alphas(const SkAlpha[4]); // AaXx -> AAAA aaaa XXXX xxxx |
+ static Sk4px Load2Alphas(const SkAlpha[2]); // Aa -> AAAA aaaa 0000 0000 |
+ |
void store4(SkPMColor[4]) const; |
void store2(SkPMColor[2]) const; |
void store1(SkPMColor[1]) const; |
@@ -111,13 +119,10 @@ public: |
template <typename Fn> |
static void MapDstSrcAlpha( |
int count, SkPMColor* dst, const SkPMColor* src, const SkAlpha* a, Fn fn) { |
- // TODO: find a terser / faster way to construct Sk16b alphas. |
while (count > 0) { |
if (count >= 8) { |
- Sk16b alpha0(a[0],a[0],a[0],a[0], a[1],a[1],a[1],a[1], |
- a[2],a[2],a[2],a[2], a[3],a[3],a[3],a[3]), |
- alpha4(a[4],a[4],a[4],a[4], a[5],a[5],a[5],a[5], |
- a[6],a[6],a[6],a[6], a[7],a[7],a[7],a[7]); |
+ Sk4px alpha0 = Load4Alphas(a+0), |
+ alpha4 = Load4Alphas(a+4); |
Sk4px dst0 = fn(Load4(dst+0), Load4(src+0), alpha0), |
dst4 = fn(Load4(dst+4), Load4(src+4), alpha4); |
dst0.store4(dst+0); |
@@ -127,18 +132,17 @@ public: |
} |
SkASSERT(count <= 7); |
if (count >= 4) { |
- Sk16b alpha(a[0],a[0],a[0],a[0], a[1],a[1],a[1],a[1], |
- a[2],a[2],a[2],a[2], a[3],a[3],a[3],a[3]); |
+ Sk4px alpha = Load4Alphas(a); |
fn(Load4(dst), Load4(src), alpha).store4(dst); |
dst += 4; src += 4; a += 4; count -= 4; |
} |
if (count >= 2) { |
- Sk16b alpha(a[0],a[0],a[0],a[0], a[1],a[1],a[1],a[1], 0,0,0,0, 0,0,0,0); |
+ Sk4px alpha = Load2Alphas(a); |
fn(Load2(dst), Load2(src), alpha).store2(dst); |
dst += 2; src += 2; a += 2; count -= 2; |
} |
if (count >= 1) { |
- Sk16b alpha(a[0],a[0],a[0],a[0], 0,0,0,0, 0,0,0,0, 0,0,0,0); |
+ Sk4px alpha(*a); |
fn(Load1(dst), Load1(src), alpha).store1(dst); |
} |
break; |