| 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 | 9 |
| 10 | 10 |
| (...skipping 289 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 300 | 300 |
| 301 this->geometrySourceWillPop(fGeoSrcStateStack.fromBack(1)); | 301 this->geometrySourceWillPop(fGeoSrcStateStack.fromBack(1)); |
| 302 this->releasePreviousVertexSource(); | 302 this->releasePreviousVertexSource(); |
| 303 this->releasePreviousIndexSource(); | 303 this->releasePreviousIndexSource(); |
| 304 fGeoSrcStateStack.pop_back(); | 304 fGeoSrcStateStack.pop_back(); |
| 305 } | 305 } |
| 306 | 306 |
| 307 //////////////////////////////////////////////////////////////////////////////// | 307 //////////////////////////////////////////////////////////////////////////////// |
| 308 | 308 |
| 309 bool GrDrawTarget::checkDraw(const GrDrawState& drawState, | 309 bool GrDrawTarget::checkDraw(const GrDrawState& drawState, |
| 310 const GrGeometryProcessor* gp, |
| 310 GrPrimitiveType type, | 311 GrPrimitiveType type, |
| 311 int startVertex, | 312 int startVertex, |
| 312 int startIndex, | 313 int startIndex, |
| 313 int vertexCount, | 314 int vertexCount, |
| 314 int indexCount) const { | 315 int indexCount) const { |
| 315 #ifdef SK_DEBUG | 316 #ifdef SK_DEBUG |
| 316 const GeometrySrcState& geoSrc = fGeoSrcStateStack.back(); | 317 const GeometrySrcState& geoSrc = fGeoSrcStateStack.back(); |
| 317 int maxVertex = startVertex + vertexCount; | 318 int maxVertex = startVertex + vertexCount; |
| 318 int maxValidVertex; | 319 int maxValidVertex; |
| 319 switch (geoSrc.fVertexSrc) { | 320 switch (geoSrc.fVertexSrc) { |
| (...skipping 22 matching lines...) Expand all Loading... |
| 342 maxValidIndex = static_cast<int>(geoSrc.fIndexBuffer->gpuMemoryS
ize() / sizeof(uint16_t)); | 343 maxValidIndex = static_cast<int>(geoSrc.fIndexBuffer->gpuMemoryS
ize() / sizeof(uint16_t)); |
| 343 break; | 344 break; |
| 344 } | 345 } |
| 345 if (maxIndex > maxValidIndex) { | 346 if (maxIndex > maxValidIndex) { |
| 346 SkFAIL("Index reads outside valid index range."); | 347 SkFAIL("Index reads outside valid index range."); |
| 347 } | 348 } |
| 348 } | 349 } |
| 349 | 350 |
| 350 SkASSERT(drawState.getRenderTarget()); | 351 SkASSERT(drawState.getRenderTarget()); |
| 351 | 352 |
| 352 if (drawState.hasGeometryProcessor()) { | 353 if (gp) { |
| 353 const GrGeometryProcessor* gp = drawState.getGeometryProcessor(); | |
| 354 int numTextures = gp->numTextures(); | 354 int numTextures = gp->numTextures(); |
| 355 for (int t = 0; t < numTextures; ++t) { | 355 for (int t = 0; t < numTextures; ++t) { |
| 356 GrTexture* texture = gp->texture(t); | 356 GrTexture* texture = gp->texture(t); |
| 357 SkASSERT(texture->asRenderTarget() != drawState.getRenderTarget()); | 357 SkASSERT(texture->asRenderTarget() != drawState.getRenderTarget()); |
| 358 } | 358 } |
| 359 } | 359 } |
| 360 | 360 |
| 361 for (int s = 0; s < drawState.numColorStages(); ++s) { | 361 for (int s = 0; s < drawState.numColorStages(); ++s) { |
| 362 const GrProcessor* effect = drawState.getColorStage(s).getProcessor(); | 362 const GrProcessor* effect = drawState.getColorStage(s).getProcessor(); |
| 363 int numTextures = effect->numTextures(); | 363 int numTextures = effect->numTextures(); |
| (...skipping 12 matching lines...) Expand all Loading... |
| 376 } | 376 } |
| 377 | 377 |
| 378 #endif | 378 #endif |
| 379 if (NULL == drawState.getRenderTarget()) { | 379 if (NULL == drawState.getRenderTarget()) { |
| 380 return false; | 380 return false; |
| 381 } | 381 } |
| 382 return true; | 382 return true; |
| 383 } | 383 } |
| 384 | 384 |
| 385 bool GrDrawTarget::setupDstReadIfNecessary(GrDrawState* ds, | 385 bool GrDrawTarget::setupDstReadIfNecessary(GrDrawState* ds, |
| 386 GrColor color, | 386 const GrPrimitiveProcessor* primProc, |
| 387 uint8_t coverage, | |
| 388 GrDeviceCoordTexture* dstCopy, | 387 GrDeviceCoordTexture* dstCopy, |
| 389 const SkRect* drawBounds) { | 388 const SkRect* drawBounds) { |
| 390 GrColor c = GrColorPackRGBA(coverage, coverage, coverage, coverage); | 389 if (this->caps()->dstReadInShaderSupport() || !ds->willEffectReadDstColor(pr
imProc)) { |
| 391 if (this->caps()->dstReadInShaderSupport() || !ds->willEffectReadDstColor(co
lor, c)) { | |
| 392 return true; | 390 return true; |
| 393 } | 391 } |
| 394 SkIRect copyRect; | 392 SkIRect copyRect; |
| 395 const GrClipData* clip = this->getClip(); | 393 const GrClipData* clip = this->getClip(); |
| 396 GrRenderTarget* rt = ds->getRenderTarget(); | 394 GrRenderTarget* rt = ds->getRenderTarget(); |
| 397 clip->getConservativeBounds(rt, ©Rect); | 395 clip->getConservativeBounds(rt, ©Rect); |
| 398 | 396 |
| 399 if (drawBounds) { | 397 if (drawBounds) { |
| 400 SkIRect drawIBounds; | 398 SkIRect drawIBounds; |
| 401 drawBounds->roundOut(&drawIBounds); | 399 drawBounds->roundOut(&drawIBounds); |
| (...skipping 27 matching lines...) Expand all Loading... |
| 429 if (this->copySurface(copy, rt, copyRect, dstPoint)) { | 427 if (this->copySurface(copy, rt, copyRect, dstPoint)) { |
| 430 dstCopy->setTexture(copy); | 428 dstCopy->setTexture(copy); |
| 431 dstCopy->setOffset(copyRect.fLeft, copyRect.fTop); | 429 dstCopy->setOffset(copyRect.fLeft, copyRect.fTop); |
| 432 return true; | 430 return true; |
| 433 } else { | 431 } else { |
| 434 return false; | 432 return false; |
| 435 } | 433 } |
| 436 } | 434 } |
| 437 | 435 |
| 438 void GrDrawTarget::drawIndexed(GrDrawState* ds, | 436 void GrDrawTarget::drawIndexed(GrDrawState* ds, |
| 437 const GrGeometryProcessor* gp, |
| 439 GrPrimitiveType type, | 438 GrPrimitiveType type, |
| 440 int startVertex, | 439 int startVertex, |
| 441 int startIndex, | 440 int startIndex, |
| 442 int vertexCount, | 441 int vertexCount, |
| 443 int indexCount, | 442 int indexCount, |
| 444 const SkRect* devBounds) { | 443 const SkRect* devBounds) { |
| 445 SkASSERT(ds); | 444 SkASSERT(ds); |
| 446 if (indexCount > 0 && | 445 if (indexCount > 0 && |
| 447 this->checkDraw(*ds, type, startVertex, startIndex, vertexCount, indexCo
unt)) { | 446 this->checkDraw(*ds, gp, type, startVertex, startIndex, vertexCount, ind
exCount)) { |
| 448 | 447 |
| 449 // Setup clip | 448 // Setup clip |
| 450 GrClipMaskManager::ScissorState scissorState; | 449 GrClipMaskManager::ScissorState scissorState; |
| 451 GrDrawState::AutoRestoreEffects are; | 450 GrDrawState::AutoRestoreEffects are; |
| 452 GrDrawState::AutoRestoreStencil ars; | 451 GrDrawState::AutoRestoreStencil ars; |
| 453 if (!this->setupClip(devBounds, &are, &ars, ds, &scissorState)) { | 452 if (!this->setupClip(devBounds, &are, &ars, ds, &scissorState)) { |
| 454 return; | 453 return; |
| 455 } | 454 } |
| 456 | 455 |
| 457 DrawInfo info; | 456 DrawInfo info; |
| 458 info.fPrimitiveType = type; | 457 info.fPrimitiveType = type; |
| 459 info.fStartVertex = startVertex; | 458 info.fStartVertex = startVertex; |
| 460 info.fStartIndex = startIndex; | 459 info.fStartIndex = startIndex; |
| 461 info.fVertexCount = vertexCount; | 460 info.fVertexCount = vertexCount; |
| 462 info.fIndexCount = indexCount; | 461 info.fIndexCount = indexCount; |
| 463 | 462 |
| 464 info.fInstanceCount = 0; | 463 info.fInstanceCount = 0; |
| 465 info.fVerticesPerInstance = 0; | 464 info.fVerticesPerInstance = 0; |
| 466 info.fIndicesPerInstance = 0; | 465 info.fIndicesPerInstance = 0; |
| 467 | 466 |
| 468 if (devBounds) { | 467 if (devBounds) { |
| 469 info.setDevBounds(*devBounds); | 468 info.setDevBounds(*devBounds); |
| 470 } | 469 } |
| 471 | 470 |
| 472 // TODO: We should continue with incorrect blending. | 471 // TODO: We should continue with incorrect blending. |
| 473 GrDeviceCoordTexture dstCopy; | 472 GrDeviceCoordTexture dstCopy; |
| 474 const GrGeometryProcessor* gp = ds->getGeometryProcessor(); | 473 if (!this->setupDstReadIfNecessary(ds, gp, &dstCopy, devBounds)) { |
| 475 if (!this->setupDstReadIfNecessary(ds, gp->getColor(), gp->getCoverage()
, &dstCopy, | |
| 476 devBounds)) { | |
| 477 return; | 474 return; |
| 478 } | 475 } |
| 479 this->setDrawBuffers(&info, gp->getVertexStride()); | 476 this->setDrawBuffers(&info, gp->getVertexStride()); |
| 480 | 477 |
| 481 this->onDraw(*ds, info, scissorState, dstCopy.texture() ? &dstCopy : NUL
L); | 478 this->onDraw(*ds, gp, info, scissorState, dstCopy.texture() ? &dstCopy :
NULL); |
| 482 } | 479 } |
| 483 } | 480 } |
| 484 | 481 |
| 485 void GrDrawTarget::drawNonIndexed(GrDrawState* ds, | 482 void GrDrawTarget::drawNonIndexed(GrDrawState* ds, |
| 483 const GrGeometryProcessor* gp, |
| 486 GrPrimitiveType type, | 484 GrPrimitiveType type, |
| 487 int startVertex, | 485 int startVertex, |
| 488 int vertexCount, | 486 int vertexCount, |
| 489 const SkRect* devBounds) { | 487 const SkRect* devBounds) { |
| 490 SkASSERT(ds); | 488 SkASSERT(ds); |
| 491 if (vertexCount > 0 && this->checkDraw(*ds, type, startVertex, -1, vertexCou
nt, -1)) { | 489 if (vertexCount > 0 && this->checkDraw(*ds, gp, type, startVertex, -1, verte
xCount, -1)) { |
| 492 | 490 |
| 493 // Setup clip | 491 // Setup clip |
| 494 GrClipMaskManager::ScissorState scissorState; | 492 GrClipMaskManager::ScissorState scissorState; |
| 495 GrDrawState::AutoRestoreEffects are; | 493 GrDrawState::AutoRestoreEffects are; |
| 496 GrDrawState::AutoRestoreStencil ars; | 494 GrDrawState::AutoRestoreStencil ars; |
| 497 if (!this->setupClip(devBounds, &are, &ars, ds, &scissorState)) { | 495 if (!this->setupClip(devBounds, &are, &ars, ds, &scissorState)) { |
| 498 return; | 496 return; |
| 499 } | 497 } |
| 500 | 498 |
| 501 DrawInfo info; | 499 DrawInfo info; |
| 502 info.fPrimitiveType = type; | 500 info.fPrimitiveType = type; |
| 503 info.fStartVertex = startVertex; | 501 info.fStartVertex = startVertex; |
| 504 info.fStartIndex = 0; | 502 info.fStartIndex = 0; |
| 505 info.fVertexCount = vertexCount; | 503 info.fVertexCount = vertexCount; |
| 506 info.fIndexCount = 0; | 504 info.fIndexCount = 0; |
| 507 | 505 |
| 508 info.fInstanceCount = 0; | 506 info.fInstanceCount = 0; |
| 509 info.fVerticesPerInstance = 0; | 507 info.fVerticesPerInstance = 0; |
| 510 info.fIndicesPerInstance = 0; | 508 info.fIndicesPerInstance = 0; |
| 511 | 509 |
| 512 if (devBounds) { | 510 if (devBounds) { |
| 513 info.setDevBounds(*devBounds); | 511 info.setDevBounds(*devBounds); |
| 514 } | 512 } |
| 515 | 513 |
| 516 // TODO: We should continue with incorrect blending. | 514 // TODO: We should continue with incorrect blending. |
| 517 GrDeviceCoordTexture dstCopy; | 515 GrDeviceCoordTexture dstCopy; |
| 518 const GrGeometryProcessor* gp = ds->getGeometryProcessor(); | 516 if (!this->setupDstReadIfNecessary(ds, gp, &dstCopy, devBounds)) { |
| 519 if (!this->setupDstReadIfNecessary(ds, gp->getColor(), gp->getCoverage()
, &dstCopy, | |
| 520 devBounds)) { | |
| 521 return; | 517 return; |
| 522 } | 518 } |
| 523 | 519 |
| 524 this->setDrawBuffers(&info, gp->getVertexStride()); | 520 this->setDrawBuffers(&info, gp->getVertexStride()); |
| 525 | 521 |
| 526 this->onDraw(*ds, info, scissorState, dstCopy.texture() ? &dstCopy : NUL
L); | 522 this->onDraw(*ds, gp, info, scissorState, dstCopy.texture() ? &dstCopy :
NULL); |
| 527 } | 523 } |
| 528 } | 524 } |
| 529 | 525 |
| 530 static const GrStencilSettings& winding_path_stencil_settings() { | 526 static const GrStencilSettings& winding_path_stencil_settings() { |
| 531 GR_STATIC_CONST_SAME_STENCIL_STRUCT(gSettings, | 527 GR_STATIC_CONST_SAME_STENCIL_STRUCT(gSettings, |
| 532 kIncClamp_StencilOp, | 528 kIncClamp_StencilOp, |
| 533 kIncClamp_StencilOp, | 529 kIncClamp_StencilOp, |
| 534 kAlwaysIfInClip_StencilFunc, | 530 kAlwaysIfInClip_StencilFunc, |
| 535 0xFFFF, 0xFFFF, 0xFFFF); | 531 0xFFFF, 0xFFFF, 0xFFFF); |
| 536 return *GR_CONST_STENCIL_SETTINGS_PTR_FROM_STRUCT_PTR(&gSettings); | 532 return *GR_CONST_STENCIL_SETTINGS_PTR_FROM_STRUCT_PTR(&gSettings); |
| (...skipping 19 matching lines...) Expand all Loading... |
| 556 *outStencilSettings = winding_path_stencil_settings(); | 552 *outStencilSettings = winding_path_stencil_settings(); |
| 557 break; | 553 break; |
| 558 case GrPathRendering::kEvenOdd_FillType: | 554 case GrPathRendering::kEvenOdd_FillType: |
| 559 *outStencilSettings = even_odd_path_stencil_settings(); | 555 *outStencilSettings = even_odd_path_stencil_settings(); |
| 560 break; | 556 break; |
| 561 } | 557 } |
| 562 this->clipMaskManager()->adjustPathStencilParams(sb, outStencilSettings); | 558 this->clipMaskManager()->adjustPathStencilParams(sb, outStencilSettings); |
| 563 } | 559 } |
| 564 | 560 |
| 565 void GrDrawTarget::stencilPath(GrDrawState* ds, | 561 void GrDrawTarget::stencilPath(GrDrawState* ds, |
| 562 const GrPathProcessor* pathProc, |
| 566 const GrPath* path, | 563 const GrPath* path, |
| 567 GrPathRendering::FillType fill) { | 564 GrPathRendering::FillType fill) { |
| 568 // TODO: extract portions of checkDraw that are relevant to path stenciling. | 565 // TODO: extract portions of checkDraw that are relevant to path stenciling. |
| 569 SkASSERT(path); | 566 SkASSERT(path); |
| 570 SkASSERT(this->caps()->pathRenderingSupport()); | 567 SkASSERT(this->caps()->pathRenderingSupport()); |
| 571 SkASSERT(ds); | 568 SkASSERT(ds); |
| 572 | 569 |
| 573 // Setup clip | 570 // Setup clip |
| 574 GrClipMaskManager::ScissorState scissorState; | 571 GrClipMaskManager::ScissorState scissorState; |
| 575 GrDrawState::AutoRestoreEffects are; | 572 GrDrawState::AutoRestoreEffects are; |
| 576 GrDrawState::AutoRestoreStencil ars; | 573 GrDrawState::AutoRestoreStencil ars; |
| 577 if (!this->setupClip(NULL, &are, &ars, ds, &scissorState)) { | 574 if (!this->setupClip(NULL, &are, &ars, ds, &scissorState)) { |
| 578 return; | 575 return; |
| 579 } | 576 } |
| 580 | 577 |
| 581 // set stencil settings for path | 578 // set stencil settings for path |
| 582 GrStencilSettings stencilSettings; | 579 GrStencilSettings stencilSettings; |
| 583 this->getPathStencilSettingsForFilltype(fill, | 580 this->getPathStencilSettingsForFilltype(fill, |
| 584 ds->getRenderTarget()->getStencilBuf
fer(), | 581 ds->getRenderTarget()->getStencilBuf
fer(), |
| 585 &stencilSettings); | 582 &stencilSettings); |
| 586 | 583 |
| 587 this->onStencilPath(*ds, path, scissorState, stencilSettings); | 584 this->onStencilPath(*ds, pathProc, path, scissorState, stencilSettings); |
| 588 } | 585 } |
| 589 | 586 |
| 590 void GrDrawTarget::drawPath(GrDrawState* ds, | 587 void GrDrawTarget::drawPath(GrDrawState* ds, |
| 591 GrColor color, | 588 const GrPathProcessor* pathProc, |
| 592 const GrPath* path, | 589 const GrPath* path, |
| 593 GrPathRendering::FillType fill) { | 590 GrPathRendering::FillType fill) { |
| 594 // TODO: extract portions of checkDraw that are relevant to path rendering. | 591 // TODO: extract portions of checkDraw that are relevant to path rendering. |
| 595 SkASSERT(path); | 592 SkASSERT(path); |
| 596 SkASSERT(this->caps()->pathRenderingSupport()); | 593 SkASSERT(this->caps()->pathRenderingSupport()); |
| 597 SkASSERT(ds); | 594 SkASSERT(ds); |
| 598 | 595 |
| 599 SkRect devBounds = path->getBounds(); | 596 SkRect devBounds = path->getBounds(); |
| 600 SkMatrix viewM = ds->getViewMatrix(); | 597 SkMatrix viewM = ds->getViewMatrix(); |
| 601 viewM.mapRect(&devBounds); | 598 viewM.mapRect(&devBounds); |
| 602 | 599 |
| 603 // Setup clip | 600 // Setup clip |
| 604 GrClipMaskManager::ScissorState scissorState; | 601 GrClipMaskManager::ScissorState scissorState; |
| 605 GrDrawState::AutoRestoreEffects are; | 602 GrDrawState::AutoRestoreEffects are; |
| 606 GrDrawState::AutoRestoreStencil ars; | 603 GrDrawState::AutoRestoreStencil ars; |
| 607 if (!this->setupClip(&devBounds, &are, &ars, ds, &scissorState)) { | 604 if (!this->setupClip(&devBounds, &are, &ars, ds, &scissorState)) { |
| 608 return; | 605 return; |
| 609 } | 606 } |
| 610 | 607 |
| 611 // set stencil settings for path | 608 // set stencil settings for path |
| 612 GrStencilSettings stencilSettings; | 609 GrStencilSettings stencilSettings; |
| 613 this->getPathStencilSettingsForFilltype(fill, | 610 this->getPathStencilSettingsForFilltype(fill, |
| 614 ds->getRenderTarget()->getStencilBuf
fer(), | 611 ds->getRenderTarget()->getStencilBuf
fer(), |
| 615 &stencilSettings); | 612 &stencilSettings); |
| 616 | 613 |
| 617 GrDeviceCoordTexture dstCopy; | 614 GrDeviceCoordTexture dstCopy; |
| 618 if (!this->setupDstReadIfNecessary(ds, color, 0xff, &dstCopy, &devBounds)) { | 615 if (!this->setupDstReadIfNecessary(ds, pathProc, &dstCopy, &devBounds)) { |
| 619 return; | 616 return; |
| 620 } | 617 } |
| 621 | 618 |
| 622 this->onDrawPath(*ds, color, path, scissorState, stencilSettings, dstCopy.te
xture() ? &dstCopy : | 619 this->onDrawPath(*ds, pathProc, path, scissorState, stencilSettings, dstCopy
.texture() ? &dstCopy : |
| 623
NULL); | 620
NULL); |
| 624 } | 621 } |
| 625 | 622 |
| 626 void GrDrawTarget::drawPaths(GrDrawState* ds, | 623 void GrDrawTarget::drawPaths(GrDrawState* ds, |
| 627 GrColor color, | 624 const GrPathProcessor* pathProc, |
| 628 const GrPathRange* pathRange, | 625 const GrPathRange* pathRange, |
| 629 const void* indices, | 626 const void* indices, |
| 630 PathIndexType indexType, | 627 PathIndexType indexType, |
| 631 const float transformValues[], | 628 const float transformValues[], |
| 632 PathTransformType transformType, | 629 PathTransformType transformType, |
| 633 int count, | 630 int count, |
| 634 GrPathRendering::FillType fill) { | 631 GrPathRendering::FillType fill) { |
| 635 SkASSERT(this->caps()->pathRenderingSupport()); | 632 SkASSERT(this->caps()->pathRenderingSupport()); |
| 636 SkASSERT(pathRange); | 633 SkASSERT(pathRange); |
| 637 SkASSERT(indices); | 634 SkASSERT(indices); |
| (...skipping 14 matching lines...) Expand all Loading... |
| 652 GrStencilSettings stencilSettings; | 649 GrStencilSettings stencilSettings; |
| 653 this->getPathStencilSettingsForFilltype(fill, | 650 this->getPathStencilSettingsForFilltype(fill, |
| 654 ds->getRenderTarget()->getStencilBuf
fer(), | 651 ds->getRenderTarget()->getStencilBuf
fer(), |
| 655 &stencilSettings); | 652 &stencilSettings); |
| 656 | 653 |
| 657 // Don't compute a bounding box for setupDstReadIfNecessary(), we'll opt | 654 // Don't compute a bounding box for setupDstReadIfNecessary(), we'll opt |
| 658 // instead for it to just copy the entire dst. Realistically this is a moot | 655 // instead for it to just copy the entire dst. Realistically this is a moot |
| 659 // point, because any context that supports NV_path_rendering will also | 656 // point, because any context that supports NV_path_rendering will also |
| 660 // support NV_blend_equation_advanced. | 657 // support NV_blend_equation_advanced. |
| 661 GrDeviceCoordTexture dstCopy; | 658 GrDeviceCoordTexture dstCopy; |
| 662 if (!this->setupDstReadIfNecessary(ds, color, 0xff, &dstCopy, NULL)) { | 659 if (!this->setupDstReadIfNecessary(ds, pathProc, &dstCopy, NULL)) { |
| 663 return; | 660 return; |
| 664 } | 661 } |
| 665 | 662 |
| 666 this->onDrawPaths(*ds, color, pathRange, indices, indexType, transformValues
, transformType, | 663 this->onDrawPaths(*ds, pathProc, pathRange, indices, indexType, transformVal
ues, transformType, |
| 667 count, scissorState, stencilSettings, dstCopy.texture() ?
&dstCopy : NULL); | 664 count, scissorState, stencilSettings, dstCopy.texture() ?
&dstCopy : NULL); |
| 668 } | 665 } |
| 669 | 666 |
| 670 void GrDrawTarget::clear(const SkIRect* rect, | 667 void GrDrawTarget::clear(const SkIRect* rect, |
| 671 GrColor color, | 668 GrColor color, |
| 672 bool canIgnoreRect, | 669 bool canIgnoreRect, |
| 673 GrRenderTarget* renderTarget) { | 670 GrRenderTarget* renderTarget) { |
| 674 if (fCaps->useDrawInsteadOfClear()) { | 671 if (fCaps->useDrawInsteadOfClear()) { |
| 675 // This works around a driver bug with clear by drawing a rect instead. | 672 // This works around a driver bug with clear by drawing a rect instead. |
| 676 // The driver will ignore a clear if it is the only thing rendered to a | 673 // The driver will ignore a clear if it is the only thing rendered to a |
| (...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 726 if (this->caps()->gpuTracingSupport()) { | 723 if (this->caps()->gpuTracingSupport()) { |
| 727 SkASSERT(fGpuTraceMarkerCount >= 1); | 724 SkASSERT(fGpuTraceMarkerCount >= 1); |
| 728 this->fActiveTraceMarkers.remove(*marker); | 725 this->fActiveTraceMarkers.remove(*marker); |
| 729 --fGpuTraceMarkerCount; | 726 --fGpuTraceMarkerCount; |
| 730 } | 727 } |
| 731 } | 728 } |
| 732 | 729 |
| 733 //////////////////////////////////////////////////////////////////////////////// | 730 //////////////////////////////////////////////////////////////////////////////// |
| 734 | 731 |
| 735 void GrDrawTarget::drawIndexedInstances(GrDrawState* ds, | 732 void GrDrawTarget::drawIndexedInstances(GrDrawState* ds, |
| 733 const GrGeometryProcessor* gp, |
| 736 GrPrimitiveType type, | 734 GrPrimitiveType type, |
| 737 int instanceCount, | 735 int instanceCount, |
| 738 int verticesPerInstance, | 736 int verticesPerInstance, |
| 739 int indicesPerInstance, | 737 int indicesPerInstance, |
| 740 const SkRect* devBounds) { | 738 const SkRect* devBounds) { |
| 741 SkASSERT(ds); | 739 SkASSERT(ds); |
| 742 | 740 |
| 743 if (!verticesPerInstance || !indicesPerInstance) { | 741 if (!verticesPerInstance || !indicesPerInstance) { |
| 744 return; | 742 return; |
| 745 } | 743 } |
| (...skipping 18 matching lines...) Expand all Loading... |
| 764 info.fIndicesPerInstance = indicesPerInstance; | 762 info.fIndicesPerInstance = indicesPerInstance; |
| 765 info.fVerticesPerInstance = verticesPerInstance; | 763 info.fVerticesPerInstance = verticesPerInstance; |
| 766 | 764 |
| 767 // Set the same bounds for all the draws. | 765 // Set the same bounds for all the draws. |
| 768 if (devBounds) { | 766 if (devBounds) { |
| 769 info.setDevBounds(*devBounds); | 767 info.setDevBounds(*devBounds); |
| 770 } | 768 } |
| 771 | 769 |
| 772 // TODO: We should continue with incorrect blending. | 770 // TODO: We should continue with incorrect blending. |
| 773 GrDeviceCoordTexture dstCopy; | 771 GrDeviceCoordTexture dstCopy; |
| 774 const GrGeometryProcessor* gp = ds->getGeometryProcessor(); | 772 if (!this->setupDstReadIfNecessary(ds, gp, &dstCopy,devBounds)) { |
| 775 if (!this->setupDstReadIfNecessary(ds, gp->getColor(), gp->getCoverage(), &d
stCopy,devBounds)) { | |
| 776 return; | 773 return; |
| 777 } | 774 } |
| 778 | 775 |
| 779 while (instanceCount) { | 776 while (instanceCount) { |
| 780 info.fInstanceCount = SkTMin(instanceCount, maxInstancesPerDraw); | 777 info.fInstanceCount = SkTMin(instanceCount, maxInstancesPerDraw); |
| 781 info.fVertexCount = info.fInstanceCount * verticesPerInstance; | 778 info.fVertexCount = info.fInstanceCount * verticesPerInstance; |
| 782 info.fIndexCount = info.fInstanceCount * indicesPerInstance; | 779 info.fIndexCount = info.fInstanceCount * indicesPerInstance; |
| 783 | 780 |
| 784 if (this->checkDraw(*ds, | 781 if (this->checkDraw(*ds, |
| 782 gp, |
| 785 type, | 783 type, |
| 786 info.fStartVertex, | 784 info.fStartVertex, |
| 787 info.fStartIndex, | 785 info.fStartIndex, |
| 788 info.fVertexCount, | 786 info.fVertexCount, |
| 789 info.fIndexCount)) { | 787 info.fIndexCount)) { |
| 790 this->setDrawBuffers(&info, gp->getVertexStride()); | 788 this->setDrawBuffers(&info, gp->getVertexStride()); |
| 791 this->onDraw(*ds, info, scissorState, dstCopy.texture() ? &dstCopy :
NULL); | 789 this->onDraw(*ds, gp, info, scissorState, dstCopy.texture() ? &dstCo
py : NULL); |
| 792 } | 790 } |
| 793 info.fStartVertex += info.fVertexCount; | 791 info.fStartVertex += info.fVertexCount; |
| 794 instanceCount -= info.fInstanceCount; | 792 instanceCount -= info.fInstanceCount; |
| 795 } | 793 } |
| 796 } | 794 } |
| 797 | 795 |
| 798 //////////////////////////////////////////////////////////////////////////////// | 796 //////////////////////////////////////////////////////////////////////////////// |
| 799 | 797 |
| 800 GrDrawTarget::AutoReleaseGeometry::AutoReleaseGeometry( | 798 GrDrawTarget::AutoReleaseGeometry::AutoReleaseGeometry( |
| 801 GrDrawTarget* target, | 799 GrDrawTarget* target, |
| (...skipping 415 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1217 GrDrawState::AutoRestoreStencil* ars, | 1215 GrDrawState::AutoRestoreStencil* ars, |
| 1218 GrDrawState* ds, | 1216 GrDrawState* ds, |
| 1219 GrClipMaskManager::ScissorState* scissorState) { | 1217 GrClipMaskManager::ScissorState* scissorState) { |
| 1220 return fClipMaskManager.setupClipping(ds, | 1218 return fClipMaskManager.setupClipping(ds, |
| 1221 are, | 1219 are, |
| 1222 ars, | 1220 ars, |
| 1223 scissorState, | 1221 scissorState, |
| 1224 this->getClip(), | 1222 this->getClip(), |
| 1225 devBounds); | 1223 devBounds); |
| 1226 } | 1224 } |
| OLD | NEW |