Chromium Code Reviews| Index: include/gpu/GrInvariantOutput.h |
| diff --git a/include/gpu/GrInvariantOutput.h b/include/gpu/GrInvariantOutput.h |
| index 1d3eda1b2cd7f437dcc0345b2a9533e658871465..77890a047d38643578f4924dae399363b2dd1787 100644 |
| --- a/include/gpu/GrInvariantOutput.h |
| +++ b/include/gpu/GrInvariantOutput.h |
| @@ -10,6 +10,49 @@ |
| #include "GrColor.h" |
| +struct GrInitInvariantOutput { |
| + GrInitInvariantOutput() |
| + : fValidFlags(0) |
| + , fColor(0) |
| + , fIsSingleComponent(false) |
| + , fIsLCDCoverage(false) {} |
| + |
| + void setIsKnownFourComponents(GrColor color) { |
|
bsalomon
2014/12/10 15:26:59
Maybe it's just me, but I find the setIs language
|
| + fColor = color; |
| + fValidFlags = kRGBA_GrColorComponentFlags; |
| + fIsSingleComponent = false; |
| + } |
| + |
| + void setIsUnknownFourComponents() { |
| + fValidFlags = 0; |
| + fIsSingleComponent = false; |
| + } |
| + |
| + void setIsUnknownAndOpaqueFourComponents() { |
|
bsalomon
2014/12/10 15:26:59
UnknownOpaqueFourComponents?
|
| + fColor = 0xff << GrColor_SHIFT_A; |
| + fValidFlags = kA_GrColorComponentFlag; |
| + fIsSingleComponent = false; |
| + } |
| + |
| + void setIsKnownSingleComponent(uint8_t alpha) { |
| + fColor = alpha << GrColor_SHIFT_A; |
|
bsalomon
2014/12/10 15:26:59
I think this should have alpha replicated across a
egdaniel
2014/12/10 15:54:30
Yes we need the alpha replicated across all channe
|
| + fValidFlags = kA_GrColorComponentFlag; |
| + fIsSingleComponent = true; |
| + } |
| + |
| + void setIsUnknownSingleComponent() { |
| + fValidFlags = 0; |
| + fIsSingleComponent = true; |
| + } |
| + |
| + void setUsingLCDCoverage() { fIsLCDCoverage = true; } |
| + |
| + uint32_t fValidFlags; |
| + GrColor fColor; |
| + bool fIsSingleComponent; |
| + bool fIsLCDCoverage; // Temorary data member until texture pixel configs are updated |
| +}; |
| + |
| class GrInvariantOutput { |
| public: |
| GrInvariantOutput(GrColor color, GrColorComponentFlags flags, bool isSingleComponent) |
| @@ -20,6 +63,14 @@ public: |
| , fWillUseInputColor(true) |
| , fIsLCDCoverage(false) {} |
| + GrInvariantOutput(const GrInitInvariantOutput& io) |
| + : fColor(io.fColor) |
| + , fValidFlags(io.fValidFlags) |
| + , fIsSingleComponent(io.fIsSingleComponent) |
| + , fNonMulStageFound(false) |
| + , fWillUseInputColor(false) |
| + , fIsLCDCoverage(io.fIsLCDCoverage) {} |
| + |
| virtual ~GrInvariantOutput() {} |
| enum ReadInput { |
| @@ -34,7 +85,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 +173,15 @@ private: |
| fWillUseInputColor = true; |
| } |
| + void reset(const GrInitInvariantOutput& io) { |
| + fColor = io.fColor; |
| + fValidFlags = io.fValidFlags; |
| + fIsSingleComponent = io.fIsSingleComponent; |
| + fNonMulStageFound = false; |
| + fWillUseInputColor = true; |
| + fIsLCDCoverage = io.fIsLCDCoverage; |
| + } |
| + |
| void internalSetToTransparentBlack() { |
| fValidFlags = kRGBA_GrColorComponentFlags; |
| fColor = 0; |