aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/core/SkShader.cpp
diff options
context:
space:
mode:
authorGravatar reed <reed@google.com>2016-01-21 15:29:10 -0800
committerGravatar Commit bot <commit-bot@chromium.org>2016-01-21 15:29:10 -0800
commit353c148d8e8c9031daca34c6f9d6bcc6f08706c7 (patch)
tree2688f89d13fd991cefaf2a6e9cd79e48fa31417c /src/core/SkShader.cpp
parent07caf56e723ec04a024f952177f7f4daba06c82c (diff)
experiment: float color components
Diffstat (limited to 'src/core/SkShader.cpp')
-rw-r--r--src/core/SkShader.cpp16
1 files changed, 15 insertions, 1 deletions
diff --git a/src/core/SkShader.cpp b/src/core/SkShader.cpp
index bd3876a69b..856b659213 100644
--- a/src/core/SkShader.cpp
+++ b/src/core/SkShader.cpp
@@ -117,6 +117,10 @@ SkShader::Context::ShadeProc SkShader::Context::asAShadeProc(void** ctx) {
return nullptr;
}
+void SkShader::Context::shadeSpan4f(int x, int y, SkPM4f[], int count) {
+ SkASSERT(false && "shadeSpan4f called but not implemented");
+}
+
#include "SkColorPriv.h"
#define kTempColorQuadCount 6 // balance between speed (larger) and saving stack-space
@@ -279,7 +283,11 @@ SkColorShader::ColorShaderContext::ColorShaderContext(const SkColorShader& shade
}
fPMColor = SkPackARGB32(a, r, g, b);
- fFlags = kConstInY32_Flag;
+ SkColor4f c4 = SkColor4f::FromColor(shader.fColor);
+ c4.fA *= rec.fPaint->getAlpha() / 255.0f;
+ fPM4f = c4.premul();
+
+ fFlags = kConstInY32_Flag | kSupports4f_Flag;
if (255 == a) {
fFlags |= kOpaqueAlpha_Flag;
}
@@ -293,6 +301,12 @@ void SkColorShader::ColorShaderContext::shadeSpanAlpha(int x, int y, uint8_t alp
memset(alpha, SkGetPackedA32(fPMColor), count);
}
+void SkColorShader::ColorShaderContext::shadeSpan4f(int x, int y, SkPM4f span[], int count) {
+ for (int i = 0; i < count; ++i) {
+ span[i] = fPM4f;
+ }
+}
+
SkShader::GradientType SkColorShader::asAGradient(GradientInfo* info) const {
if (info) {
if (info->fColors && info->fColorCount >= 1) {