blob: 4731cbbbe1d2f3bbdb60cad04a21b5cfe2de68a3 [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
cdalton93a379b2016-05-11 13:58:08 -070025GrPipelineBuilder::GrPipelineBuilder(const GrPaint& paint, GrRenderTarget* rt, const GrClip& clip)
26 : 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
joshualitt570d2f82015-02-25 13:19:48 -080041 fClip = clip;
bsalomon@google.com21c10c52013-06-13 17:44:07 +000042
bsalomond79c5492015-04-27 10:07:04 -070043 this->setState(GrPipelineBuilder::kHWAntialias_Flag,
vbuzinovdded6962015-06-12 08:59:45 -070044 rt->isUnifiedMultisampled() && paint.isAntiAlias());
brianosman64d094d2016-03-25 06:01:59 -070045 this->setState(GrPipelineBuilder::kDisableOutputConversionToSRGB_Flag,
46 paint.getDisableOutputConversionToSRGB());
brianosman898235c2016-04-06 07:38:23 -070047 this->setState(GrPipelineBuilder::kAllowSRGBInputs_Flag,
48 paint.getAllowSRGBInputs());
bsalomon@google.comaf84e742012-10-05 13:23:24 +000049}
bsalomon@google.com5b3e8902012-10-05 20:13:28 +000050
egdaniel21aed572014-08-26 12:24:06 -070051//////////////////////////////////////////////////////////////////////////////s
bsalomon@google.comd62e88e2013-02-01 14:19:27 +000052
bsalomon6a44c6a2015-05-26 09:49:05 -070053bool GrPipelineBuilder::willXPNeedDstTexture(const GrCaps& caps,
ethannicholasde4166a2015-11-30 08:57:38 -080054 const GrPipelineOptimizations& optimizations) const {
egdanielc4b72722015-11-23 13:20:41 -080055 if (this->getXPFactory()) {
cdalton3ccf2e72016-05-06 09:41:16 -070056 return this->getXPFactory()->willNeedDstTexture(caps, optimizations);
egdanielc4b72722015-11-23 13:20:41 -080057 }
cdalton3ccf2e72016-05-06 09:41:16 -070058 return GrPorterDuffXPFactory::SrcOverWillNeedDstTexture(caps, optimizations);
egdaniel89af44a2014-09-26 06:15:04 -070059}
60
joshualitt4421a4c2015-07-13 09:36:41 -070061void GrPipelineBuilder::AutoRestoreFragmentProcessorState::set(
joshualitt5e6ba212015-07-13 07:35:05 -070062 const GrPipelineBuilder* pipelineBuilder) {
egdaniel8dd688b2015-01-22 10:16:09 -080063 if (fPipelineBuilder) {
bsalomonac856c92015-08-27 06:30:17 -070064 int m = fPipelineBuilder->numColorFragmentProcessors() - fColorEffectCnt;
egdaniel21aed572014-08-26 12:24:06 -070065 SkASSERT(m >= 0);
bsalomonac856c92015-08-27 06:30:17 -070066 for (int i = 0; i < m; ++i) {
67 fPipelineBuilder->fColorFragmentProcessors.fromBack(i)->unref();
68 }
69 fPipelineBuilder->fColorFragmentProcessors.pop_back_n(m);
bsalomon@google.comd62e88e2013-02-01 14:19:27 +000070
bsalomonac856c92015-08-27 06:30:17 -070071 int n = fPipelineBuilder->numCoverageFragmentProcessors() - fCoverageEffectCnt;
egdaniel21aed572014-08-26 12:24:06 -070072 SkASSERT(n >= 0);
bsalomonac856c92015-08-27 06:30:17 -070073 for (int i = 0; i < n; ++i) {
74 fPipelineBuilder->fCoverageFragmentProcessors.fromBack(i)->unref();
75 }
76 fPipelineBuilder->fCoverageFragmentProcessors.pop_back_n(n);
egdaniel8dd688b2015-01-22 10:16:09 -080077 SkDEBUGCODE(--fPipelineBuilder->fBlockEffectRemovalCnt;)
bsalomon@google.comd62e88e2013-02-01 14:19:27 +000078 }
joshualitt5e6ba212015-07-13 07:35:05 -070079 fPipelineBuilder = const_cast<GrPipelineBuilder*>(pipelineBuilder);
halcanary96fcdcc2015-08-27 07:41:13 -070080 if (nullptr != pipelineBuilder) {
bsalomonac856c92015-08-27 06:30:17 -070081 fColorEffectCnt = pipelineBuilder->numColorFragmentProcessors();
82 fCoverageEffectCnt = pipelineBuilder->numCoverageFragmentProcessors();
egdaniel8dd688b2015-01-22 10:16:09 -080083 SkDEBUGCODE(++pipelineBuilder->fBlockEffectRemovalCnt;)
egdaniel21aed572014-08-26 12:24:06 -070084 }
bsalomon@google.comd62e88e2013-02-01 14:19:27 +000085}
86
jvanverth@google.comcc782382013-01-28 20:39:48 +000087////////////////////////////////////////////////////////////////////////////////
88
egdaniel8dd688b2015-01-22 10:16:09 -080089GrPipelineBuilder::~GrPipelineBuilder() {
egdaniel170f90b2014-09-16 12:54:40 -070090 SkASSERT(0 == fBlockEffectRemovalCnt);
bsalomonac856c92015-08-27 06:30:17 -070091 for (int i = 0; i < fColorFragmentProcessors.count(); ++i) {
92 fColorFragmentProcessors[i]->unref();
93 }
94 for (int i = 0; i < fCoverageFragmentProcessors.count(); ++i) {
95 fCoverageFragmentProcessors[i]->unref();
96 }
egdaniel170f90b2014-09-16 12:54:40 -070097}