Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(163)

Side by Side Diff: src/gpu/effects/GrCoverageSetOpXP.cpp

Issue 1161273005: Update XPF invariant info to not account for conflation (Closed) Base URL: https://skia.googlesource.com/skia.git@upload_reenablebea
Patch Set: rebase Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « src/gpu/GrProcOptInfo.h ('k') | src/gpu/effects/GrCustomXfermode.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 212 matching lines...) Expand 10 before | Expand all | Expand 10 after
223 } 223 }
224 224
225 GrXferProcessor* 225 GrXferProcessor*
226 GrCoverageSetOpXPFactory::onCreateXferProcessor(const GrCaps& caps, 226 GrCoverageSetOpXPFactory::onCreateXferProcessor(const GrCaps& caps,
227 const GrProcOptInfo& colorPOI, 227 const GrProcOptInfo& colorPOI,
228 const GrProcOptInfo& covPOI, 228 const GrProcOptInfo& covPOI,
229 const DstTexture* dst) const { 229 const DstTexture* dst) const {
230 return CoverageSetOpXP::Create(fRegionOp, fInvertCoverage); 230 return CoverageSetOpXP::Create(fRegionOp, fInvertCoverage);
231 } 231 }
232 232
233 void GrCoverageSetOpXPFactory::getInvariantOutput(const GrProcOptInfo& colorPOI, 233 void GrCoverageSetOpXPFactory::getInvariantBlendedColor(const GrProcOptInfo& col orPOI,
234 const GrProcOptInfo& coverageP OI, 234 InvariantBlendedColor* b lendedColor) const {
235 GrXPFactory::InvariantOutput* output) const { 235 blendedColor->fWillBlendWithDst = SkRegion::kReplace_Op != fRegionOp;
236 if (SkRegion::kReplace_Op == fRegionOp) { 236 blendedColor->fKnownColorFlags = kNone_GrColorComponentFlags;
237 if (coveragePOI.isSolidWhite()) {
238 output->fBlendedColor = GrColor_WHITE;
239 output->fBlendedColorFlags = kRGBA_GrColorComponentFlags;
240 } else {
241 output->fBlendedColorFlags = 0;
242 }
243
244 output->fWillBlendWithDst = false;
245 } else {
246 output->fBlendedColorFlags = 0;
247 output->fWillBlendWithDst = true;
248 }
249 } 237 }
250 238
251 GR_DEFINE_XP_FACTORY_TEST(GrCoverageSetOpXPFactory); 239 GR_DEFINE_XP_FACTORY_TEST(GrCoverageSetOpXPFactory);
252 240
253 GrXPFactory* GrCoverageSetOpXPFactory::TestCreate(SkRandom* random, 241 GrXPFactory* GrCoverageSetOpXPFactory::TestCreate(SkRandom* random,
254 GrContext*, 242 GrContext*,
255 const GrCaps&, 243 const GrCaps&,
256 GrTexture*[]) { 244 GrTexture*[]) {
257 SkRegion::Op regionOp = SkRegion::Op(random->nextULessThan(SkRegion::kLastOp + 1)); 245 SkRegion::Op regionOp = SkRegion::Op(random->nextULessThan(SkRegion::kLastOp + 1));
258 bool invertCoverage = random->nextBool(); 246 bool invertCoverage = random->nextBool();
259 return GrCoverageSetOpXPFactory::Create(regionOp, invertCoverage); 247 return GrCoverageSetOpXPFactory::Create(regionOp, invertCoverage);
260 } 248 }
261 249
OLDNEW
« no previous file with comments | « src/gpu/GrProcOptInfo.h ('k') | src/gpu/effects/GrCustomXfermode.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698