OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2011 Google Inc. | 2 * Copyright 2011 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 #include "GrGpuGL.h" | 8 #include "GrGpuGL.h" |
9 | 9 |
10 #include "GrProcessor.h" | 10 #include "GrProcessor.h" |
(...skipping 188 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
199 } | 199 } |
200 ++fCurrLRUStamp; | 200 ++fCurrLRUStamp; |
201 return entry->fProgram; | 201 return entry->fProgram; |
202 } | 202 } |
203 | 203 |
204 //////////////////////////////////////////////////////////////////////////////// | 204 //////////////////////////////////////////////////////////////////////////////// |
205 | 205 |
206 #define GL_CALL(X) GR_GL_CALL(this->glInterface(), X) | 206 #define GL_CALL(X) GR_GL_CALL(this->glInterface(), X) |
207 | 207 |
208 bool GrGpuGL::flushGraphicsState(DrawType type, const GrDeviceCoordTexture* dstC opy) { | 208 bool GrGpuGL::flushGraphicsState(DrawType type, const GrDeviceCoordTexture* dstC opy) { |
209 SkAutoTUnref<GrOptDrawState> optState(this->getDrawState().createOptState(*t his->caps())); | 209 SkAutoTUnref<GrOptDrawState> optState(GrOptDrawState::Create(this->getDrawSt ate(), |
210 *this->caps(), | |
211 type)); | |
212 | |
213 if (NULL == optState.get()) { | |
bsalomon
2014/10/06 20:40:20
howabout if (!optState) ?
| |
214 return false; | |
215 } | |
210 | 216 |
211 // GrGpu::setupClipAndFlushState should have already checked this and bailed if not true. | 217 // GrGpu::setupClipAndFlushState should have already checked this and bailed if not true. |
212 SkASSERT(optState->getRenderTarget()); | 218 SkASSERT(optState->getRenderTarget()); |
213 | 219 |
214 if (kStencilPath_DrawType == type) { | 220 if (kStencilPath_DrawType == type) { |
215 const GrRenderTarget* rt = optState->getRenderTarget(); | 221 const GrRenderTarget* rt = optState->getRenderTarget(); |
216 SkISize size; | 222 SkISize size; |
217 size.set(rt->width(), rt->height()); | 223 size.set(rt->width(), rt->height()); |
218 this->glPathRendering()->setProjectionMatrix(optState->getViewMatrix(), size, rt->origin()); | 224 this->glPathRendering()->setProjectionMatrix(optState->getViewMatrix(), size, rt->origin()); |
219 } else { | 225 } else { |
(...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
287 devRect = &devClipBounds; | 293 devRect = &devClipBounds; |
288 } | 294 } |
289 // This must come after textures are flushed because a texture may need | 295 // This must come after textures are flushed because a texture may need |
290 // to be msaa-resolved (which will modify bound FBO state). | 296 // to be msaa-resolved (which will modify bound FBO state). |
291 this->flushRenderTarget(glRT, devRect); | 297 this->flushRenderTarget(glRT, devRect); |
292 | 298 |
293 return true; | 299 return true; |
294 } | 300 } |
295 | 301 |
296 void GrGpuGL::setupGeometry(const DrawInfo& info, size_t* indexOffsetInBytes) { | 302 void GrGpuGL::setupGeometry(const DrawInfo& info, size_t* indexOffsetInBytes) { |
297 SkAutoTUnref<GrOptDrawState> optState(this->getDrawState().createOptState(*t his->caps())); | 303 SkAutoTUnref<GrOptDrawState> optState( |
304 GrOptDrawState::Create(this->getDrawState(), *this->caps(), | |
305 PrimTypeToDrawType(info.primitiveType()))); | |
306 | |
307 // If the optState would is NULL it should have been caught in flushGraphics State before getting | |
308 // here. | |
309 SkASSERT(optState.get()); | |
bsalomon
2014/10/06 20:40:20
SkASSERT(optState); (autotunref casts to bool)
| |
298 | 310 |
299 GrGLsizei stride = static_cast<GrGLsizei>(optState->getVertexStride()); | 311 GrGLsizei stride = static_cast<GrGLsizei>(optState->getVertexStride()); |
300 | 312 |
301 size_t vertexOffsetInBytes = stride * info.startVertex(); | 313 size_t vertexOffsetInBytes = stride * info.startVertex(); |
302 | 314 |
303 const GeometryPoolState& geoPoolState = this->getGeomPoolState(); | 315 const GeometryPoolState& geoPoolState = this->getGeomPoolState(); |
304 | 316 |
305 GrGLVertexBuffer* vbuf; | 317 GrGLVertexBuffer* vbuf; |
306 switch (this->getGeomSrc().fVertexSrc) { | 318 switch (this->getGeomSrc().fVertexSrc) { |
307 case kBuffer_GeometrySrcType: | 319 case kBuffer_GeometrySrcType: |
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
364 GrGLAttribTypeToLayout(attribType).fCount, | 376 GrGLAttribTypeToLayout(attribType).fCount, |
365 GrGLAttribTypeToLayout(attribType).fType, | 377 GrGLAttribTypeToLayout(attribType).fType, |
366 GrGLAttribTypeToLayout(attribType).fNormalized, | 378 GrGLAttribTypeToLayout(attribType).fNormalized, |
367 stride, | 379 stride, |
368 reinterpret_cast<GrGLvoid*>( | 380 reinterpret_cast<GrGLvoid*>( |
369 vertexOffsetInBytes + vertexAttrib->fOffset)); | 381 vertexOffsetInBytes + vertexAttrib->fOffset)); |
370 } | 382 } |
371 attribState->disableUnusedArrays(this, usedAttribArraysMask); | 383 attribState->disableUnusedArrays(this, usedAttribArraysMask); |
372 } | 384 } |
373 } | 385 } |
OLD | NEW |