OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2010 Google Inc. | 2 * Copyright 2010 Google Inc. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
6 */ | 6 */ |
7 | 7 |
8 #ifndef GrDrawTarget_DEFINED | 8 #ifndef GrDrawTarget_DEFINED |
9 #define GrDrawTarget_DEFINED | 9 #define GrDrawTarget_DEFINED |
10 | 10 |
(...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
98 * Together these two functions flush all queued up draws to the Gpu. | 98 * Together these two functions flush all queued up draws to the Gpu. |
99 */ | 99 */ |
100 void prepareBatches(GrBatchFlushState* flushState); | 100 void prepareBatches(GrBatchFlushState* flushState); |
101 void drawBatches(GrBatchFlushState* flushState); | 101 void drawBatches(GrBatchFlushState* flushState); |
102 | 102 |
103 /** | 103 /** |
104 * Gets the capabilities of the draw target. | 104 * Gets the capabilities of the draw target. |
105 */ | 105 */ |
106 const GrCaps* caps() const { return fGpu->caps(); } | 106 const GrCaps* caps() const { return fGpu->caps(); } |
107 | 107 |
108 void drawBatch(const GrPipelineBuilder&, GrDrawBatch*, const SkIRect* scisso
rRect = nullptr); | 108 void drawBatch(const GrPipelineBuilder&, const GrClip&, GrDrawBatch*); |
109 | 109 |
110 /** | 110 /** |
111 * Draws path into the stencil buffer. The fill must be either even/odd or | 111 * Draws path into the stencil buffer. The fill must be either even/odd or |
112 * winding (not inverse or hairline). It will respect the HW antialias flag | 112 * winding (not inverse or hairline). It will respect the HW antialias flag |
113 * on the GrPipelineBuilder (if possible in the 3D API). Note, we will neve
r have an inverse | 113 * on the GrPipelineBuilder (if possible in the 3D API). Note, we will neve
r have an inverse |
114 * fill with stencil path | 114 * fill with stencil path |
115 */ | 115 */ |
116 void stencilPath(const GrPipelineBuilder&, const SkMatrix& viewMatrix, const
GrPath*, | 116 void stencilPath(const GrPipelineBuilder&, const GrClip&, const SkMatrix& vi
ewMatrix, |
117 GrPathRendering::FillType); | 117 const GrPath*, GrPathRendering::FillType); |
118 | 118 |
119 /** | 119 /** |
120 * Clear the passed in render target. Ignores the GrPipelineBuilder and clip
. Clears the whole | 120 * Clear the passed in render target. Ignores the GrPipelineBuilder and clip
. Clears the whole |
121 * thing if rect is nullptr, otherwise just the rect. If canIgnoreRect is se
t then the entire | 121 * thing if rect is nullptr, otherwise just the rect. If canIgnoreRect is se
t then the entire |
122 * render target can be optionally cleared. | 122 * render target can be optionally cleared. |
123 */ | 123 */ |
124 void clear(const SkIRect* rect, | 124 void clear(const SkIRect* rect, |
125 GrColor color, | 125 GrColor color, |
126 bool canIgnoreRect, | 126 bool canIgnoreRect, |
127 GrRenderTarget* renderTarget); | 127 GrRenderTarget* renderTarget); |
(...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
210 } | 210 } |
211 }; | 211 }; |
212 | 212 |
213 void recordBatch(GrBatch*); | 213 void recordBatch(GrBatch*); |
214 void forwardCombine(); | 214 void forwardCombine(); |
215 | 215 |
216 // Makes a copy of the dst if it is necessary for the draw. Returns false if
a copy is required | 216 // Makes a copy of the dst if it is necessary for the draw. Returns false if
a copy is required |
217 // but couldn't be made. Otherwise, returns true. This method needs to be p
rotected because it | 217 // but couldn't be made. Otherwise, returns true. This method needs to be p
rotected because it |
218 // needs to be accessed by GLPrograms to setup a correct drawstate | 218 // needs to be accessed by GLPrograms to setup a correct drawstate |
219 bool setupDstReadIfNecessary(const GrPipelineBuilder&, | 219 bool setupDstReadIfNecessary(const GrPipelineBuilder&, |
| 220 const GrClip&, |
220 const GrPipelineOptimizations& optimizations, | 221 const GrPipelineOptimizations& optimizations, |
221 GrXferProcessor::DstTexture*, | 222 GrXferProcessor::DstTexture*, |
222 const SkRect& batchBounds); | 223 const SkRect& batchBounds); |
223 | 224 |
224 void addDependency(GrDrawTarget* dependedOn); | 225 void addDependency(GrDrawTarget* dependedOn); |
225 | 226 |
226 // Used only by CMM. | 227 // Used only by CMM. |
227 void clearStencilClip(const SkIRect&, bool insideClip, GrRenderTarget*); | 228 void clearStencilClip(const SkIRect&, bool insideClip, GrRenderTarget*); |
228 | 229 |
229 SkSTArray<256, SkAutoTUnref<GrBatch>, true> fBatches; | 230 SkSTArray<256, SkAutoTUnref<GrBatch>, true> fBatches; |
230 SkAutoTDelete<GrClipMaskManager> fClipMaskManager; | 231 SkAutoTDelete<GrClipMaskManager> fClipMaskManager; |
231 // The context is only in service of the clip mask manager, remove once CMM
doesn't need this. | 232 // The context is only in service of the clip mask manager, remove once CMM
doesn't need this. |
232 GrContext* fContext; | 233 GrContext* fContext; |
233 GrGpu* fGpu; | 234 GrGpu* fGpu; |
234 GrResourceProvider* fResourceProvider; | 235 GrResourceProvider* fResourceProvider; |
235 GrAuditTrail* fAuditTrail; | 236 GrAuditTrail* fAuditTrail; |
236 | 237 |
237 SkDEBUGCODE(int fDebugID;) | 238 SkDEBUGCODE(int fDebugID;) |
238 uint32_t fFlags; | 239 uint32_t fFlags; |
239 | 240 |
240 // 'this' drawTarget relies on the output of the drawTargets in 'fDependenci
es' | 241 // 'this' drawTarget relies on the output of the drawTargets in 'fDependenci
es' |
241 SkTDArray<GrDrawTarget*> fDependencies; | 242 SkTDArray<GrDrawTarget*> fDependencies; |
242 GrRenderTarget* fRenderTarget; | 243 GrRenderTarget* fRenderTarget; |
243 | 244 |
| 245 bool fClipBatchToBounds; |
244 bool fDrawBatchBounds; | 246 bool fDrawBatchBounds; |
245 int fMaxBatchLookback; | 247 int fMaxBatchLookback; |
246 int fMaxBatchLookahead; | 248 int fMaxBatchLookahead; |
247 | 249 |
248 typedef SkRefCnt INHERITED; | 250 typedef SkRefCnt INHERITED; |
249 }; | 251 }; |
250 | 252 |
251 #endif | 253 #endif |
OLD | NEW |