| OLD | NEW |
| 1 | 1 |
| 2 /* | 2 /* |
| 3 * Copyright 2014 Google Inc. | 3 * Copyright 2014 Google Inc. |
| 4 * | 4 * |
| 5 * Use of this source code is governed by a BSD-style license that can be | 5 * Use of this source code is governed by a BSD-style license that can be |
| 6 * found in the LICENSE file. | 6 * found in the LICENSE file. |
| 7 */ | 7 */ |
| 8 | 8 |
| 9 #include "effects/GrCoverageSetOpXP.h" | 9 #include "effects/GrCoverageSetOpXP.h" |
| 10 #include "GrCaps.h" | 10 #include "GrCaps.h" |
| (...skipping 206 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 217 } | 217 } |
| 218 default: | 218 default: |
| 219 return NULL; | 219 return NULL; |
| 220 } | 220 } |
| 221 } | 221 } |
| 222 | 222 |
| 223 GrXferProcessor* | 223 GrXferProcessor* |
| 224 GrCoverageSetOpXPFactory::onCreateXferProcessor(const GrCaps& caps, | 224 GrCoverageSetOpXPFactory::onCreateXferProcessor(const GrCaps& caps, |
| 225 const GrProcOptInfo& colorPOI, | 225 const GrProcOptInfo& colorPOI, |
| 226 const GrProcOptInfo& covPOI, | 226 const GrProcOptInfo& covPOI, |
| 227 bool hasMixedSamples, |
| 227 const DstTexture* dst) const { | 228 const DstTexture* dst) const { |
| 229 // We don't support inverting coverage with mixed samples. We don't expect t
o ever want this in |
| 230 // the future, however we could at some point make this work using an invert
ed coverage |
| 231 // modulation table. Note that an inverted table still won't work if there a
re coverage procs. |
| 232 if (fInvertCoverage && hasMixedSamples) { |
| 233 SkASSERT(false); |
| 234 return NULL; |
| 235 } |
| 236 |
| 228 return CoverageSetOpXP::Create(fRegionOp, fInvertCoverage); | 237 return CoverageSetOpXP::Create(fRegionOp, fInvertCoverage); |
| 229 } | 238 } |
| 230 | 239 |
| 231 void GrCoverageSetOpXPFactory::getInvariantBlendedColor(const GrProcOptInfo& col
orPOI, | 240 void GrCoverageSetOpXPFactory::getInvariantBlendedColor(const GrProcOptInfo& col
orPOI, |
| 232 InvariantBlendedColor* b
lendedColor) const { | 241 InvariantBlendedColor* b
lendedColor) const { |
| 233 blendedColor->fWillBlendWithDst = SkRegion::kReplace_Op != fRegionOp; | 242 blendedColor->fWillBlendWithDst = SkRegion::kReplace_Op != fRegionOp; |
| 234 blendedColor->fKnownColorFlags = kNone_GrColorComponentFlags; | 243 blendedColor->fKnownColorFlags = kNone_GrColorComponentFlags; |
| 235 } | 244 } |
| 236 | 245 |
| 237 GR_DEFINE_XP_FACTORY_TEST(GrCoverageSetOpXPFactory); | 246 GR_DEFINE_XP_FACTORY_TEST(GrCoverageSetOpXPFactory); |
| 238 | 247 |
| 239 GrXPFactory* GrCoverageSetOpXPFactory::TestCreate(SkRandom* random, | 248 GrXPFactory* GrCoverageSetOpXPFactory::TestCreate(SkRandom* random, |
| 240 GrContext*, | 249 GrContext*, |
| 241 const GrCaps&, | 250 const GrCaps&, |
| 242 GrTexture*[]) { | 251 GrTexture*[]) { |
| 243 SkRegion::Op regionOp = SkRegion::Op(random->nextULessThan(SkRegion::kLastOp
+ 1)); | 252 SkRegion::Op regionOp = SkRegion::Op(random->nextULessThan(SkRegion::kLastOp
+ 1)); |
| 244 bool invertCoverage = random->nextBool(); | 253 bool invertCoverage = random->nextBool(); |
| 245 return GrCoverageSetOpXPFactory::Create(regionOp, invertCoverage); | 254 return GrCoverageSetOpXPFactory::Create(regionOp, invertCoverage); |
| 246 } | 255 } |
| 247 | 256 |
| OLD | NEW |