OLD | NEW |
---|---|
1 | 1 |
2 /* | 2 /* |
3 * Copyright 2010 Google Inc. | 3 * Copyright 2010 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 "GrDrawTarget.h" | 9 #include "GrDrawTarget.h" |
10 | 10 |
(...skipping 145 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
156 | 156 |
157 this->onFlush(); | 157 this->onFlush(); |
158 | 158 |
159 this->getGpu()->restoreActiveTraceMarkers(); | 159 this->getGpu()->restoreActiveTraceMarkers(); |
160 | 160 |
161 fFlushing = false; | 161 fFlushing = false; |
162 this->reset(); | 162 this->reset(); |
163 } | 163 } |
164 | 164 |
165 void GrDrawTarget::drawBatch(GrPipelineBuilder* pipelineBuilder, | 165 void GrDrawTarget::drawBatch(GrPipelineBuilder* pipelineBuilder, |
166 GrBatch* batch, | 166 GrBatch* batch) { |
167 const SkRect* devBounds) { | |
168 SkASSERT(pipelineBuilder); | 167 SkASSERT(pipelineBuilder); |
169 // TODO some kind of checkdraw, but not at this level | 168 // TODO some kind of checkdraw, but not at this level |
170 | 169 |
170 // Batch bounds are tight, so for dev copies and clipping we outset; | |
171 SkRect bounds = batch->bounds(); | |
172 bounds.outset(0.5f, 0.5f); | |
173 | |
171 // Setup clip | 174 // Setup clip |
172 GrScissorState scissorState; | 175 GrScissorState scissorState; |
173 GrPipelineBuilder::AutoRestoreFragmentProcessors arfp; | 176 GrPipelineBuilder::AutoRestoreFragmentProcessors arfp; |
174 GrPipelineBuilder::AutoRestoreStencil ars; | 177 GrPipelineBuilder::AutoRestoreStencil ars; |
175 if (!this->setupClip(pipelineBuilder, &arfp, &ars, &scissorState, devBounds) ) { | 178 if (!this->setupClip(pipelineBuilder, &arfp, &ars, &scissorState, &bounds)) { |
bsalomon
2015/04/30 18:53:23
did you try doing the outsetting after clipping? W
joshualitt
2015/05/01 13:49:58
Acknowledged.
| |
176 return; | 179 return; |
177 } | 180 } |
178 | 181 |
179 GrDrawTarget::PipelineInfo pipelineInfo(pipelineBuilder, &scissorState, batc h, devBounds, this); | 182 GrDrawTarget::PipelineInfo pipelineInfo(pipelineBuilder, &scissorState, batc h, &bounds, this); |
bsalomon
2015/04/30 18:53:24
should the bounds be a required param now (non-ptr
joshualitt
2015/05/01 13:49:58
I can't do this until path is in batch
| |
180 if (pipelineInfo.mustSkipDraw()) { | 183 if (pipelineInfo.mustSkipDraw()) { |
181 return; | 184 return; |
182 } | 185 } |
183 | 186 |
184 this->onDrawBatch(batch, pipelineInfo); | 187 this->onDrawBatch(batch, pipelineInfo); |
185 } | 188 } |
186 | 189 |
187 static const GrStencilSettings& winding_path_stencil_settings() { | 190 static const GrStencilSettings& winding_path_stencil_settings() { |
188 GR_STATIC_CONST_SAME_STENCIL_STRUCT(gSettings, | 191 GR_STATIC_CONST_SAME_STENCIL_STRUCT(gSettings, |
189 kIncClamp_StencilOp, | 192 kIncClamp_StencilOp, |
(...skipping 595 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
785 GrPipelineBuilder::AutoRestoreFragmentProcessors* a rfp, | 788 GrPipelineBuilder::AutoRestoreFragmentProcessors* a rfp, |
786 GrPipelineBuilder::AutoRestoreStencil* ars, | 789 GrPipelineBuilder::AutoRestoreStencil* ars, |
787 GrScissorState* scissorState, | 790 GrScissorState* scissorState, |
788 const SkRect* devBounds) { | 791 const SkRect* devBounds) { |
789 return fClipMaskManager.setupClipping(pipelineBuilder, | 792 return fClipMaskManager.setupClipping(pipelineBuilder, |
790 arfp, | 793 arfp, |
791 ars, | 794 ars, |
792 scissorState, | 795 scissorState, |
793 devBounds); | 796 devBounds); |
794 } | 797 } |
OLD | NEW |