 Chromium Code Reviews
 Chromium Code Reviews Issue 1121463002:
  Move bounds to GrBatch  (Closed) 
  Base URL: https://skia.googlesource.com/skia.git@master
    
  
    Issue 1121463002:
  Move bounds to GrBatch  (Closed) 
  Base URL: https://skia.googlesource.com/skia.git@master| 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 |