blob: fd97e58ab880b7413f86c51232fa047791c12c46 [file] [log] [blame]
bsalomon@google.comaf84e742012-10-05 13:23:24 +00001/*
egdaniel8dd688b2015-01-22 10:16:09 -08002 * Copyright 2015 Google Inc.
bsalomon@google.comaf84e742012-10-05 13:23:24 +00003 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
egdaniel8dd688b2015-01-22 10:16:09 -08008#include "GrPipelineBuilder.h"
egdaniel3658f382014-09-15 07:01:59 -07009
egdanielb1cff032014-11-13 06:19:25 -080010#include "GrBlend.h"
egdaniel3658f382014-09-15 07:01:59 -070011#include "GrPaint.h"
egdaniel8dd688b2015-01-22 10:16:09 -080012#include "GrPipeline.h"
egdanielb6cbc382014-11-13 11:00:34 -080013#include "GrProcOptInfo.h"
egdaniel378092f2014-12-03 10:40:13 -080014#include "GrXferProcessor.h"
joshualitt74417822015-08-07 11:42:16 -070015#include "batches/GrBatch.h"
egdaniel378092f2014-12-03 10:40:13 -080016#include "effects/GrPorterDuffXferProcessor.h"
egdaniel3658f382014-09-15 07:01:59 -070017
egdaniel8dd688b2015-01-22 10:16:09 -080018GrPipelineBuilder::GrPipelineBuilder()
cdalton93a379b2016-05-11 13:58:08 -070019 : fFlags(0x0),
20 fUserStencilSettings(&GrUserStencilSettings::kUnused),
21 fDrawFace(kBoth_DrawFace) {
joshualitt2fdeda02015-01-22 07:11:44 -080022 SkDEBUGCODE(fBlockEffectRemovalCnt = 0;)
egdaniel89af44a2014-09-26 06:15:04 -070023}
24
cdalton862cff32016-05-12 15:09:48 -070025GrPipelineBuilder::GrPipelineBuilder(const GrPaint& paint, GrRenderTarget* rt)
cdalton93a379b2016-05-11 13:58:08 -070026 : GrPipelineBuilder() {
joshualitt7b670db2015-07-09 13:25:02 -070027 SkDEBUGCODE(fBlockEffectRemovalCnt = 0;)
bsalomon@google.comeb6879f2013-06-13 19:34:18 +000028
bsalomonac856c92015-08-27 06:30:17 -070029 for (int i = 0; i < paint.numColorFragmentProcessors(); ++i) {
30 fColorFragmentProcessors.push_back(SkRef(paint.getColorFragmentProcessor(i)));
bsalomon@google.comaf84e742012-10-05 13:23:24 +000031 }
32
bsalomonac856c92015-08-27 06:30:17 -070033 for (int i = 0; i < paint.numCoverageFragmentProcessors(); ++i) {
34 fCoverageFragmentProcessors.push_back(SkRef(paint.getCoverageFragmentProcessor(i)));
bsalomon@google.comaf84e742012-10-05 13:23:24 +000035 }
36
egdanielc4b72722015-11-23 13:20:41 -080037 fXPFactory.reset(SkSafeRef(paint.getXPFactory()));
egdaniel378092f2014-12-03 10:40:13 -080038
commit-bot@chromium.orgbb6a3172013-05-28 17:25:49 +000039 this->setRenderTarget(rt);
bsalomon@google.comaf84e742012-10-05 13:23:24 +000040
bsalomond79c5492015-04-27 10:07:04 -070041 this->setState(GrPipelineBuilder::kHWAntialias_Flag,
vbuzinovdded6962015-06-12 08:59:45 -070042 rt->isUnifiedMultisampled() && paint.isAntiAlias());
brianosman64d094d2016-03-25 06:01:59 -070043 this->setState(GrPipelineBuilder::kDisableOutputConversionToSRGB_Flag,
44 paint.getDisableOutputConversionToSRGB());
brianosman898235c2016-04-06 07:38:23 -070045 this->setState(GrPipelineBuilder::kAllowSRGBInputs_Flag,
46 paint.getAllowSRGBInputs());
bsalomon@google.comaf84e742012-10-05 13:23:24 +000047}
bsalomon@google.com5b3e8902012-10-05 20:13:28 +000048
egdaniel21aed572014-08-26 12:24:06 -070049//////////////////////////////////////////////////////////////////////////////s
bsalomon@google.comd62e88e2013-02-01 14:19:27 +000050
bsalomon6a44c6a2015-05-26 09:49:05 -070051bool GrPipelineBuilder::willXPNeedDstTexture(const GrCaps& caps,
ethannicholasde4166a2015-11-30 08:57:38 -080052 const GrPipelineOptimizations& optimizations) const {
egdanielc4b72722015-11-23 13:20:41 -080053 if (this->getXPFactory()) {
cdalton3ccf2e72016-05-06 09:41:16 -070054 return this->getXPFactory()->willNeedDstTexture(caps, optimizations);
egdanielc4b72722015-11-23 13:20:41 -080055 }
cdalton3ccf2e72016-05-06 09:41:16 -070056 return GrPorterDuffXPFactory::SrcOverWillNeedDstTexture(caps, optimizations);
egdaniel89af44a2014-09-26 06:15:04 -070057}
58
joshualitt4421a4c2015-07-13 09:36:41 -070059void GrPipelineBuilder::AutoRestoreFragmentProcessorState::set(
joshualitt5e6ba212015-07-13 07:35:05 -070060 const GrPipelineBuilder* pipelineBuilder) {
egdaniel8dd688b2015-01-22 10:16:09 -080061 if (fPipelineBuilder) {
bsalomonac856c92015-08-27 06:30:17 -070062 int m = fPipelineBuilder->numColorFragmentProcessors() - fColorEffectCnt;
egdaniel21aed572014-08-26 12:24:06 -070063 SkASSERT(m >= 0);
bsalomonac856c92015-08-27 06:30:17 -070064 for (int i = 0; i < m; ++i) {
65 fPipelineBuilder->fColorFragmentProcessors.fromBack(i)->unref();
66 }
67 fPipelineBuilder->fColorFragmentProcessors.pop_back_n(m);
bsalomon@google.comd62e88e2013-02-01 14:19:27 +000068
bsalomonac856c92015-08-27 06:30:17 -070069 int n = fPipelineBuilder->numCoverageFragmentProcessors() - fCoverageEffectCnt;
egdaniel21aed572014-08-26 12:24:06 -070070 SkASSERT(n >= 0);
bsalomonac856c92015-08-27 06:30:17 -070071 for (int i = 0; i < n; ++i) {
72 fPipelineBuilder->fCoverageFragmentProcessors.fromBack(i)->unref();
73 }
74 fPipelineBuilder->fCoverageFragmentProcessors.pop_back_n(n);
egdaniel8dd688b2015-01-22 10:16:09 -080075 SkDEBUGCODE(--fPipelineBuilder->fBlockEffectRemovalCnt;)
bsalomon@google.comd62e88e2013-02-01 14:19:27 +000076 }
joshualitt5e6ba212015-07-13 07:35:05 -070077 fPipelineBuilder = const_cast<GrPipelineBuilder*>(pipelineBuilder);
halcanary96fcdcc2015-08-27 07:41:13 -070078 if (nullptr != pipelineBuilder) {
bsalomonac856c92015-08-27 06:30:17 -070079 fColorEffectCnt = pipelineBuilder->numColorFragmentProcessors();
80 fCoverageEffectCnt = pipelineBuilder->numCoverageFragmentProcessors();
egdaniel8dd688b2015-01-22 10:16:09 -080081 SkDEBUGCODE(++pipelineBuilder->fBlockEffectRemovalCnt;)
egdaniel21aed572014-08-26 12:24:06 -070082 }
bsalomon@google.comd62e88e2013-02-01 14:19:27 +000083}
84
jvanverth@google.comcc782382013-01-28 20:39:48 +000085////////////////////////////////////////////////////////////////////////////////
86
egdaniel8dd688b2015-01-22 10:16:09 -080087GrPipelineBuilder::~GrPipelineBuilder() {
egdaniel170f90b2014-09-16 12:54:40 -070088 SkASSERT(0 == fBlockEffectRemovalCnt);
bsalomonac856c92015-08-27 06:30:17 -070089 for (int i = 0; i < fColorFragmentProcessors.count(); ++i) {
90 fColorFragmentProcessors[i]->unref();
91 }
92 for (int i = 0; i < fCoverageFragmentProcessors.count(); ++i) {
93 fCoverageFragmentProcessors[i]->unref();
94 }
egdaniel170f90b2014-09-16 12:54:40 -070095}