Chromium Code Reviews| Index: include/gpu/GrInvariantOutput.h |
| diff --git a/include/gpu/GrInvariantOutput.h b/include/gpu/GrInvariantOutput.h |
| index 1d3eda1b2cd7f437dcc0345b2a9533e658871465..1e353cc7c157640d587bb7a8c047ed59508566e8 100644 |
| --- a/include/gpu/GrInvariantOutput.h |
| +++ b/include/gpu/GrInvariantOutput.h |
| @@ -10,6 +10,44 @@ |
| #include "GrColor.h" |
| +struct GrInitInvariantOutput { |
| + GrInitInvariantOutput() |
| + : fValidFlags(0) |
| + , fColor(0) |
| + , fIsSingleComponent(false) {} |
| + |
| + void setKnownComponents(GrColor color) { |
| + fColor = color; |
| + fValidFlags = kRGBA_GrColorComponentFlags; |
|
bsalomon
2014/12/09 20:39:50
fSingleComponent = (true if all the values the sam
|
| + } |
| + |
| + void setKnownAlpha(uint8_t alpha) { |
| + fColor |= (fColor >> GrColor_SHIFT_A) | alpha; |
|
bsalomon
2014/12/09 20:39:50
fColor = (alpha << SHIFT_A);
right?
|
| + fValidFlags |= kA_GrColorComponentFlag; |
|
bsalomon
2014/12/09 20:39:50
= not |=, right?
|
| + } |
|
bsalomon
2014/12/09 20:39:50
fSingleComponent = true;
|
| + |
| + void setUnknownAlpha() { |
| + fValidFlags &= ~kA_GrColorComponentFlag; |
|
bsalomon
2014/12/09 20:39:50
fValidFlags = 0;
fSingleComponent = true;
|
| + } |
| + |
| + void setUnknown() { |
| + fValidFlags = 0; |
|
bsalomon
2014/12/09 20:39:50
fSingleComponent = false;
Should we make the name
|
| + } |
| + |
| + void setOpaque() { |
| + fColor |= (fColor >> GrColor_SHIFT_A) | 0xFF; |
| + fValidFlags |= kA_GrColorComponentFlag; |
|
bsalomon
2014/12/09 20:39:50
fSingleComponent = false
|
| + } |
| + |
| + void setIsSingleComponent() { fIsSingleComponent = true; } |
|
bsalomon
2014/12/09 20:39:50
Do we need this two helpers? seems always implied
|
| + |
| + void setHasFourComponents() { fIsSingleComponent = false; } |
| + |
| + uint32_t fValidFlags; |
| + GrColor fColor; |
| + bool fIsSingleComponent; |
| +}; |
| + |
| class GrInvariantOutput { |
| public: |
| GrInvariantOutput(GrColor color, GrColorComponentFlags flags, bool isSingleComponent) |
| @@ -20,6 +58,13 @@ public: |
| , fWillUseInputColor(true) |
| , fIsLCDCoverage(false) {} |
| + GrInvariantOutput(const GrInitInvariantOutput& io) |
| + : fColor(io.fColor) |
| + , fValidFlags(io.fValidFlags) |
| + , fIsSingleComponent(io.fIsSingleComponent) |
| + , fNonMulStageFound(false) |
| + , fWillUseInputColor(false) {} |
| + |
| virtual ~GrInvariantOutput() {} |
| enum ReadInput { |
| @@ -34,7 +79,7 @@ public: |
| } else { |
| // Since the current state is not opaque we no longer care if the color being |
| // multiplied is opaque. |
| - this->mulByUnknownColor(); |
| + this->mulByUnknownColor(); |
| } |
| } |
| @@ -122,6 +167,14 @@ private: |
| fWillUseInputColor = true; |
| } |
| + void reset(const GrInitInvariantOutput& io) { |
| + fColor = io.fColor; |
| + fValidFlags = io.fValidFlags; |
| + fIsSingleComponent = io.fIsSingleComponent; |
| + fNonMulStageFound = false; |
| + fWillUseInputColor = true; |
| + } |
| + |
| void internalSetToTransparentBlack() { |
| fValidFlags = kRGBA_GrColorComponentFlags; |
| fColor = 0; |