Add onPrePrepareDraws & createProgramInfo methods to GrDrawVerticesOp
This CL also incidentally adds: 1) a GrMeshDrawOp::Target 'outputView' virtual and switches GrOpFlushState over to overriding it. 2) a createProgramInfo helper to GrSimpleMeshDrawOpHelper Bug: skia:9455 Change-Id: Iecd712d3ac76038651bd2e0512134e310930d527 Reviewed-on: https://skia-review.googlesource.com/c/skia/+/274551 Reviewed-by: Greg Daniel <egdaniel@google.com> Commit-Queue: Robert Phillips <robertphillips@google.com>
This commit is contained in:
parent
37f84c05db
commit
d3606518fa
@ -106,7 +106,7 @@ protected:
|
||||
GrProgramInfo* createProgramInfo(GrOpFlushState* flushState) {
|
||||
return this->createProgramInfo(&flushState->caps(),
|
||||
flushState->allocator(),
|
||||
flushState->view(),
|
||||
flushState->outputView(),
|
||||
flushState->detachAppliedClip(),
|
||||
flushState->dstProxyView());
|
||||
}
|
||||
|
@ -178,7 +178,7 @@ private:
|
||||
GrProgramInfo* createProgramInfo(GrOpFlushState* flushState) const {
|
||||
return this->createProgramInfo(&flushState->caps(),
|
||||
flushState->allocator(),
|
||||
flushState->view(),
|
||||
flushState->outputView(),
|
||||
flushState->detachAppliedClip(),
|
||||
flushState->dstProxyView());
|
||||
}
|
||||
|
@ -186,7 +186,7 @@ private:
|
||||
GrProgramInfo* createProgramInfo(GrOpFlushState* flushState) const {
|
||||
return this->createProgramInfo(&flushState->caps(),
|
||||
flushState->allocator(),
|
||||
flushState->view(),
|
||||
flushState->outputView(),
|
||||
flushState->detachAppliedClip(),
|
||||
flushState->dstProxyView());
|
||||
}
|
||||
|
@ -262,7 +262,7 @@ private:
|
||||
GrProgramInfo* createProgramInfo(GrOpFlushState* flushState) const {
|
||||
return this->createProgramInfo(&flushState->caps(),
|
||||
flushState->allocator(),
|
||||
flushState->view(),
|
||||
flushState->outputView(),
|
||||
flushState->detachAppliedClip(),
|
||||
flushState->dstProxyView());
|
||||
}
|
||||
|
@ -333,7 +333,7 @@ private:
|
||||
}
|
||||
|
||||
GrProgramInfo programInfo(state->proxy()->numSamples(), state->proxy()->numStencilSamples(),
|
||||
state->proxy()->backendFormat(), state->view()->origin(),
|
||||
state->proxy()->backendFormat(), state->outputView()->origin(),
|
||||
&pipeline, shader.get(), &fixedDynamicState, nullptr, 0,
|
||||
GrPrimitiveType::kPatches, tessellationPatchVertexCount);
|
||||
|
||||
|
@ -46,7 +46,7 @@ void GrOpFlushState::executeDrawsAndUploadsForMeshDrawOp(
|
||||
GrProgramInfo programInfo(this->proxy()->numSamples(),
|
||||
this->proxy()->numStencilSamples(),
|
||||
this->proxy()->backendFormat(),
|
||||
this->view()->origin(),
|
||||
this->outputView()->origin(),
|
||||
pipeline,
|
||||
fCurrDraw->fGeometryProcessor,
|
||||
fCurrDraw->fFixedDynamicState,
|
||||
|
@ -71,7 +71,7 @@ public:
|
||||
GrSwizzle outputSwizzle() const { return fSurfaceView->swizzle(); }
|
||||
|
||||
GrOp* op() { return fOp; }
|
||||
const GrSurfaceProxyView* view() const { return fSurfaceView; }
|
||||
const GrSurfaceProxyView* outputView() const { return fSurfaceView; }
|
||||
GrRenderTargetProxy* proxy() const { return fRenderTargetProxy; }
|
||||
GrAppliedClip* appliedClip() { return fAppliedClip; }
|
||||
const GrAppliedClip* appliedClip() const { return fAppliedClip; }
|
||||
@ -132,7 +132,7 @@ public:
|
||||
int* actualIndexCount) final;
|
||||
void putBackIndices(int indexCount) final;
|
||||
void putBackVertices(int vertices, size_t vertexStride) final;
|
||||
const GrSurfaceProxyView* view() const { return this->drawOpArgs().view(); }
|
||||
const GrSurfaceProxyView* outputView() const final { return this->drawOpArgs().outputView(); }
|
||||
GrRenderTargetProxy* proxy() const final { return this->drawOpArgs().proxy(); }
|
||||
const GrAppliedClip* appliedClip() const final { return this->drawOpArgs().appliedClip(); }
|
||||
GrAppliedClip detachAppliedClip() final;
|
||||
|
@ -207,7 +207,7 @@ void GrCCCoverageProcessor::draw(
|
||||
GrProgramInfo programInfo(flushState->proxy()->numSamples(),
|
||||
flushState->proxy()->numStencilSamples(),
|
||||
flushState->proxy()->backendFormat(),
|
||||
flushState->view()->origin(),
|
||||
flushState->outputView()->origin(),
|
||||
&pipeline,
|
||||
this,
|
||||
nullptr,
|
||||
|
@ -144,7 +144,7 @@ void GrCCPathProcessor::drawPaths(GrOpFlushState* flushState, const GrPipeline&
|
||||
GrProgramInfo programInfo(flushState->proxy()->numSamples(),
|
||||
flushState->proxy()->numStencilSamples(),
|
||||
flushState->proxy()->backendFormat(),
|
||||
flushState->view()->origin(),
|
||||
flushState->outputView()->origin(),
|
||||
&pipeline,
|
||||
this,
|
||||
fixedDynamicState,
|
||||
|
@ -782,7 +782,7 @@ void GrCCStroker::flushBufferedMeshesAsStrokes(const GrPrimitiveProcessor& proce
|
||||
GrProgramInfo programInfo(flushState->proxy()->numSamples(),
|
||||
flushState->proxy()->numStencilSamples(),
|
||||
flushState->proxy()->backendFormat(),
|
||||
flushState->view()->origin(),
|
||||
flushState->outputView()->origin(),
|
||||
&pipeline,
|
||||
&processor,
|
||||
nullptr,
|
||||
|
@ -157,7 +157,7 @@ void GrStencilAtlasOp::onExecute(GrOpFlushState* flushState, const SkRect& chain
|
||||
GrProgramInfo programInfo(flushState->proxy()->numSamples(),
|
||||
flushState->proxy()->numStencilSamples(),
|
||||
flushState->proxy()->backendFormat(),
|
||||
flushState->view()->origin(),
|
||||
flushState->outputView()->origin(),
|
||||
&resolvePipeline,
|
||||
&primProc,
|
||||
&scissorRectState,
|
||||
|
@ -101,7 +101,7 @@ void GrDrawPathOp::onExecute(GrOpFlushState* flushState, const SkRect& chainBoun
|
||||
GrProgramInfo programInfo(proxy->numSamples(),
|
||||
proxy->numStencilSamples(),
|
||||
proxy->backendFormat(),
|
||||
flushState->view()->origin(),
|
||||
flushState->outputView()->origin(),
|
||||
pipeline,
|
||||
pathProc.get(),
|
||||
fixedDynamicState,
|
||||
|
@ -9,6 +9,7 @@
|
||||
#include "src/gpu/GrCaps.h"
|
||||
#include "src/gpu/GrDefaultGeoProcFactory.h"
|
||||
#include "src/gpu/GrOpFlushState.h"
|
||||
#include "src/gpu/GrProgramInfo.h"
|
||||
#include "src/gpu/SkGr.h"
|
||||
#include "src/gpu/ops/GrDrawVerticesOp.h"
|
||||
#include "src/gpu/ops/GrSimpleMeshDrawOpHelper.h"
|
||||
@ -47,29 +48,40 @@ private:
|
||||
kSkColor,
|
||||
};
|
||||
|
||||
GrProgramInfo* createProgramInfo(const GrCaps*,
|
||||
SkArenaAlloc*,
|
||||
const GrSurfaceProxyView* outputView,
|
||||
GrAppliedClip&&,
|
||||
const GrXferProcessor::DstProxyView&);
|
||||
GrProgramInfo* createProgramInfo(Target* target) {
|
||||
return this->createProgramInfo(&target->caps(),
|
||||
target->allocator(),
|
||||
target->outputView(),
|
||||
target->detachAppliedClip(),
|
||||
target->dstProxyView());
|
||||
}
|
||||
|
||||
void onPrePrepareDraws(GrRecordingContext*,
|
||||
const GrSurfaceProxyView* outputView,
|
||||
GrAppliedClip*,
|
||||
const GrXferProcessor::DstProxyView&) override;
|
||||
void onPrepareDraws(Target*) override;
|
||||
void onExecute(GrOpFlushState*, const SkRect& chainBounds) override;
|
||||
|
||||
void drawVolatile(Target*);
|
||||
void drawNonVolatile(Target*);
|
||||
void drawVolatile(Target*, const GrPrimitiveProcessor&);
|
||||
void drawNonVolatile(Target*, const GrPrimitiveProcessor&);
|
||||
|
||||
void fillBuffers(bool hasColorAttribute,
|
||||
bool hasLocalCoordsAttribute,
|
||||
size_t vertexStride,
|
||||
void fillBuffers(size_t vertexStride,
|
||||
void* verts,
|
||||
uint16_t* indices) const;
|
||||
|
||||
void drawVertices(Target*,
|
||||
const GrGeometryProcessor*,
|
||||
sk_sp<const GrBuffer> vertexBuffer,
|
||||
int firstVertex,
|
||||
sk_sp<const GrBuffer> indexBuffer,
|
||||
int firstIndex);
|
||||
void createMesh(Target*,
|
||||
sk_sp<const GrBuffer> vertexBuffer,
|
||||
int firstVertex,
|
||||
sk_sp<const GrBuffer> indexBuffer,
|
||||
int firstIndex);
|
||||
|
||||
GrGeometryProcessor* makeGP(SkArenaAlloc* arena,
|
||||
const GrShaderCaps* shaderCaps,
|
||||
bool* hasColorAttribute,
|
||||
bool* hasLocalCoordAttribute) const;
|
||||
GrGeometryProcessor* makeGP(SkArenaAlloc*, const GrShaderCaps*);
|
||||
|
||||
GrPrimitiveType primitiveType() const { return fPrimitiveType; }
|
||||
bool combinablePrimitive() const {
|
||||
@ -117,6 +129,11 @@ private:
|
||||
kRequiresPerVertexColors_Flag = 0x1,
|
||||
kAnyMeshHasExplicitLocalCoords_Flag = 0x2,
|
||||
kHasMultipleViewMatrices_Flag = 0x4,
|
||||
|
||||
// These following flags are set in makeGP
|
||||
kHasLocalCoordAttribute_Flag = 0x8,
|
||||
kHasColorAttribute_Flag = 0x10, // should always match kRequiresPerVertexColors
|
||||
kWasCharacterized_Flag = 0x20,
|
||||
};
|
||||
|
||||
Helper fHelper;
|
||||
@ -130,6 +147,9 @@ private:
|
||||
ColorArrayType fColorArrayType;
|
||||
sk_sp<GrColorSpaceXform> fColorSpaceXform;
|
||||
|
||||
GrMesh* fMesh = nullptr;
|
||||
GrProgramInfo* fProgramInfo = nullptr;
|
||||
|
||||
typedef GrMeshDrawOp INHERITED;
|
||||
};
|
||||
|
||||
@ -230,25 +250,20 @@ GrProcessorSet::Analysis DrawVerticesOp::finalize(
|
||||
return result;
|
||||
}
|
||||
|
||||
GrGeometryProcessor* DrawVerticesOp::makeGP(SkArenaAlloc* arena,
|
||||
const GrShaderCaps* shaderCaps,
|
||||
bool* hasColorAttribute,
|
||||
bool* hasLocalCoordAttribute) const {
|
||||
GrGeometryProcessor* DrawVerticesOp::makeGP(SkArenaAlloc* arena, const GrShaderCaps* shaderCaps) {
|
||||
using namespace GrDefaultGeoProcFactory;
|
||||
LocalCoords::Type localCoordsType;
|
||||
if (fHelper.usesLocalCoords()) {
|
||||
// If we have multiple view matrices we will transform the positions into device space. We
|
||||
// must then also provide untransformed positions as local coords.
|
||||
if (this->anyMeshHasExplicitLocalCoords() || this->hasMultipleViewMatrices()) {
|
||||
*hasLocalCoordAttribute = true;
|
||||
fFlags |= kHasLocalCoordAttribute_Flag;
|
||||
localCoordsType = LocalCoords::kHasExplicit_Type;
|
||||
} else {
|
||||
*hasLocalCoordAttribute = false;
|
||||
localCoordsType = LocalCoords::kUsePosition_Type;
|
||||
}
|
||||
} else {
|
||||
localCoordsType = LocalCoords::kUnused_Type;
|
||||
*hasLocalCoordAttribute = false;
|
||||
}
|
||||
|
||||
Color color(fMeshes[0].fColor);
|
||||
@ -259,13 +274,12 @@ GrGeometryProcessor* DrawVerticesOp::makeGP(SkArenaAlloc* arena,
|
||||
color.fType = Color::kUnpremulSkColorAttribute_Type;
|
||||
color.fColorSpaceXform = fColorSpaceXform;
|
||||
}
|
||||
*hasColorAttribute = true;
|
||||
} else {
|
||||
*hasColorAttribute = false;
|
||||
fFlags |= kHasColorAttribute_Flag;
|
||||
}
|
||||
|
||||
const SkMatrix& vm = this->hasMultipleViewMatrices() ? SkMatrix::I() : fMeshes[0].fViewMatrix;
|
||||
|
||||
fFlags |= kWasCharacterized_Flag;
|
||||
return GrDefaultGeoProcFactory::Make(arena,
|
||||
shaderCaps,
|
||||
color,
|
||||
@ -274,25 +288,52 @@ GrGeometryProcessor* DrawVerticesOp::makeGP(SkArenaAlloc* arena,
|
||||
vm);
|
||||
}
|
||||
|
||||
GrProgramInfo* DrawVerticesOp::createProgramInfo(
|
||||
const GrCaps* caps,
|
||||
SkArenaAlloc* arena,
|
||||
const GrSurfaceProxyView* outputView,
|
||||
GrAppliedClip&& appliedClip,
|
||||
const GrXferProcessor::DstProxyView& dstProxyView) {
|
||||
GrGeometryProcessor* gp = this->makeGP(arena, caps->shaderCaps());
|
||||
|
||||
return fHelper.createProgramInfo(caps, arena, outputView, std::move(appliedClip), dstProxyView,
|
||||
gp, this->primitiveType());
|
||||
}
|
||||
|
||||
void DrawVerticesOp::onPrePrepareDraws(GrRecordingContext* context,
|
||||
const GrSurfaceProxyView* outputView,
|
||||
GrAppliedClip* clip,
|
||||
const GrXferProcessor::DstProxyView& dstProxyView) {
|
||||
SkArenaAlloc* arena = context->priv().recordTimeAllocator();
|
||||
|
||||
// This is equivalent to a GrOpFlushState::detachAppliedClip
|
||||
GrAppliedClip appliedClip = clip ? std::move(*clip) : GrAppliedClip();
|
||||
|
||||
fProgramInfo = this->createProgramInfo(context->priv().caps(), arena, outputView,
|
||||
std::move(appliedClip), dstProxyView);
|
||||
|
||||
context->priv().recordProgramInfo(fProgramInfo);
|
||||
}
|
||||
|
||||
void DrawVerticesOp::onPrepareDraws(Target* target) {
|
||||
if (!fProgramInfo) {
|
||||
// Note: this could be moved to onExecute if draw*Volatile were made to compute
|
||||
// their own vertex stride and hasColorAttribute and hasLocalCoordsAttribute settings.
|
||||
fProgramInfo = this->createProgramInfo(target);
|
||||
}
|
||||
|
||||
bool hasMapBufferSupport = GrCaps::kNone_MapFlags != target->caps().mapBufferFlags();
|
||||
if (fMeshes[0].fVertices->isVolatile() || !hasMapBufferSupport) {
|
||||
this->drawVolatile(target);
|
||||
this->drawVolatile(target, fProgramInfo->primProc());
|
||||
} else {
|
||||
this->drawNonVolatile(target);
|
||||
this->drawNonVolatile(target, fProgramInfo->primProc());
|
||||
}
|
||||
}
|
||||
|
||||
void DrawVerticesOp::drawVolatile(Target* target) {
|
||||
bool hasColorAttribute;
|
||||
bool hasLocalCoordsAttribute;
|
||||
GrGeometryProcessor* gp = this->makeGP(target->allocator(),
|
||||
target->caps().shaderCaps(),
|
||||
&hasColorAttribute,
|
||||
&hasLocalCoordsAttribute);
|
||||
void DrawVerticesOp::drawVolatile(Target* target, const GrPrimitiveProcessor& gp) {
|
||||
|
||||
// Allocate buffers.
|
||||
size_t vertexStride = gp->vertexStride();
|
||||
size_t vertexStride = gp.vertexStride();
|
||||
sk_sp<const GrBuffer> vertexBuffer;
|
||||
int firstVertex = 0;
|
||||
void* verts = target->makeVertexSpace(vertexStride, fVertexCount, &vertexBuffer, &firstVertex);
|
||||
@ -312,27 +353,14 @@ void DrawVerticesOp::drawVolatile(Target* target) {
|
||||
}
|
||||
}
|
||||
|
||||
// Fill the buffers.
|
||||
this->fillBuffers(hasColorAttribute,
|
||||
hasLocalCoordsAttribute,
|
||||
vertexStride,
|
||||
verts,
|
||||
indices);
|
||||
this->fillBuffers(vertexStride, verts, indices);
|
||||
|
||||
// Draw the vertices.
|
||||
this->drawVertices(target, gp, std::move(vertexBuffer), firstVertex, indexBuffer, firstIndex);
|
||||
this->createMesh(target, std::move(vertexBuffer), firstVertex, indexBuffer, firstIndex);
|
||||
}
|
||||
|
||||
void DrawVerticesOp::drawNonVolatile(Target* target) {
|
||||
void DrawVerticesOp::drawNonVolatile(Target* target, const GrPrimitiveProcessor& gp) {
|
||||
static const GrUniqueKey::Domain kDomain = GrUniqueKey::GenerateDomain();
|
||||
|
||||
bool hasColorAttribute;
|
||||
bool hasLocalCoordsAttribute;
|
||||
GrGeometryProcessor* gp = this->makeGP(target->allocator(),
|
||||
target->caps().shaderCaps(),
|
||||
&hasColorAttribute,
|
||||
&hasLocalCoordsAttribute);
|
||||
|
||||
SkASSERT(fMeshes.count() == 1); // Non-volatile meshes should never combine.
|
||||
|
||||
// Get the resource provider.
|
||||
@ -355,12 +383,12 @@ void DrawVerticesOp::drawNonVolatile(Target* target) {
|
||||
|
||||
// Draw using the cached buffers if possible.
|
||||
if (vertexBuffer && (!this->isIndexed() || indexBuffer)) {
|
||||
this->drawVertices(target, gp, std::move(vertexBuffer), 0, std::move(indexBuffer), 0);
|
||||
this->createMesh(target, std::move(vertexBuffer), 0, std::move(indexBuffer), 0);
|
||||
return;
|
||||
}
|
||||
|
||||
// Allocate vertex buffer.
|
||||
size_t vertexStride = gp->vertexStride();
|
||||
size_t vertexStride = gp.vertexStride();
|
||||
vertexBuffer = rp->createBuffer(
|
||||
fVertexCount * vertexStride, GrGpuBufferType::kVertex, kStatic_GrAccessPattern);
|
||||
void* verts = vertexBuffer ? vertexBuffer->map() : nullptr;
|
||||
@ -381,14 +409,8 @@ void DrawVerticesOp::drawNonVolatile(Target* target) {
|
||||
}
|
||||
}
|
||||
|
||||
// Fill the buffers.
|
||||
this->fillBuffers(hasColorAttribute,
|
||||
hasLocalCoordsAttribute,
|
||||
vertexStride,
|
||||
verts,
|
||||
indices);
|
||||
this->fillBuffers(vertexStride, verts, indices);
|
||||
|
||||
// Unmap the buffers.
|
||||
vertexBuffer->unmap();
|
||||
if (indexBuffer) {
|
||||
indexBuffer->unmap();
|
||||
@ -399,15 +421,15 @@ void DrawVerticesOp::drawNonVolatile(Target* target) {
|
||||
rp->assignUniqueKeyToResource(indexKey, indexBuffer.get());
|
||||
|
||||
// Draw the vertices.
|
||||
this->drawVertices(target, gp, std::move(vertexBuffer), 0, std::move(indexBuffer), 0);
|
||||
this->createMesh(target, std::move(vertexBuffer), 0, std::move(indexBuffer), 0);
|
||||
}
|
||||
|
||||
void DrawVerticesOp::fillBuffers(bool hasColorAttribute,
|
||||
bool hasLocalCoordsAttribute,
|
||||
size_t vertexStride,
|
||||
void* verts,
|
||||
uint16_t* indices) const {
|
||||
void DrawVerticesOp::fillBuffers(size_t vertexStride, void* verts, uint16_t* indices) const {
|
||||
int instanceCount = fMeshes.count();
|
||||
bool hasColorAttribute = SkToBool(fFlags & kHasColorAttribute_Flag);
|
||||
bool hasLocalCoordsAttribute = SkToBool(fFlags & kHasLocalCoordAttribute_Flag);
|
||||
SkASSERT(fFlags & kWasCharacterized_Flag);
|
||||
SkASSERT(hasColorAttribute == this->requiresPerVertexColors());
|
||||
|
||||
// Copy data into the buffers.
|
||||
int vertexOffset = 0;
|
||||
@ -494,27 +516,26 @@ void DrawVerticesOp::fillBuffers(bool hasColorAttribute,
|
||||
}
|
||||
}
|
||||
|
||||
void DrawVerticesOp::drawVertices(Target* target,
|
||||
const GrGeometryProcessor* gp,
|
||||
sk_sp<const GrBuffer> vertexBuffer,
|
||||
int firstVertex,
|
||||
sk_sp<const GrBuffer> indexBuffer,
|
||||
int firstIndex) {
|
||||
GrMesh* mesh = target->allocMesh();
|
||||
void DrawVerticesOp::createMesh(Target* target,
|
||||
sk_sp<const GrBuffer> vertexBuffer,
|
||||
int firstVertex,
|
||||
sk_sp<const GrBuffer> indexBuffer,
|
||||
int firstIndex) {
|
||||
SkASSERT(!fMesh);
|
||||
|
||||
fMesh = target->allocMesh();
|
||||
if (this->isIndexed()) {
|
||||
mesh->setIndexed(std::move(indexBuffer), fIndexCount, firstIndex, 0, fVertexCount - 1,
|
||||
fMesh->setIndexed(std::move(indexBuffer), fIndexCount, firstIndex, 0, fVertexCount - 1,
|
||||
GrPrimitiveRestart::kNo);
|
||||
} else {
|
||||
mesh->setNonIndexedNonInstanced(fVertexCount);
|
||||
fMesh->setNonIndexedNonInstanced(fVertexCount);
|
||||
}
|
||||
mesh->setVertexData(std::move(vertexBuffer), firstVertex);
|
||||
target->recordDraw(gp, mesh, 1, this->primitiveType());
|
||||
fMesh->setVertexData(std::move(vertexBuffer), firstVertex);
|
||||
}
|
||||
|
||||
void DrawVerticesOp::onExecute(GrOpFlushState* flushState, const SkRect& chainBounds) {
|
||||
auto pipeline = fHelper.createPipeline(flushState);
|
||||
|
||||
flushState->executeDrawsAndUploadsForMeshDrawOp(this, chainBounds, pipeline);
|
||||
flushState->opsRenderPass()->bindPipeline(*fProgramInfo, chainBounds);
|
||||
flushState->opsRenderPass()->drawMeshes(*fProgramInfo, fMesh, 1);
|
||||
}
|
||||
|
||||
GrOp::CombineResult DrawVerticesOp::onCombineIfPossible(GrOp* t, GrRecordingContext::Arenas*,
|
||||
|
@ -102,7 +102,7 @@ private:
|
||||
GrProgramInfo* createProgramInfo(GrOpFlushState* flushState) {
|
||||
return this->createProgramInfo(&flushState->caps(),
|
||||
flushState->allocator(),
|
||||
flushState->view(),
|
||||
flushState->outputView(),
|
||||
flushState->detachAppliedClip(),
|
||||
flushState->dstProxyView());
|
||||
}
|
||||
|
@ -191,6 +191,7 @@ public:
|
||||
}
|
||||
|
||||
virtual GrRenderTargetProxy* proxy() const = 0;
|
||||
virtual const GrSurfaceProxyView* outputView() const = 0;
|
||||
|
||||
virtual const GrAppliedClip* appliedClip() const = 0;
|
||||
virtual GrAppliedClip detachAppliedClip() = 0;
|
||||
|
@ -136,7 +136,7 @@ const GrPipeline* GrSimpleMeshDrawOpHelper::CreatePipeline(
|
||||
const GrUserStencilSettings* stencilSettings) {
|
||||
return CreatePipeline(&flushState->caps(),
|
||||
flushState->allocator(),
|
||||
flushState->view(),
|
||||
flushState->outputView(),
|
||||
flushState->detachAppliedClip(),
|
||||
flushState->dstProxyView(),
|
||||
std::move(processorSet),
|
||||
@ -147,7 +147,7 @@ const GrPipeline* GrSimpleMeshDrawOpHelper::CreatePipeline(
|
||||
const GrPipeline* GrSimpleMeshDrawOpHelper::createPipeline(GrOpFlushState* flushState) {
|
||||
return CreatePipeline(&flushState->caps(),
|
||||
flushState->allocator(),
|
||||
flushState->view(),
|
||||
flushState->outputView(),
|
||||
flushState->detachAppliedClip(),
|
||||
flushState->dstProxyView(),
|
||||
this->detachProcessorSet(),
|
||||
@ -196,6 +196,25 @@ GrProgramInfo* GrSimpleMeshDrawOpHelper::CreateProgramInfo(
|
||||
return tmp;
|
||||
}
|
||||
|
||||
GrProgramInfo* GrSimpleMeshDrawOpHelper::createProgramInfo(
|
||||
const GrCaps* caps,
|
||||
SkArenaAlloc* arena,
|
||||
const GrSurfaceProxyView* outputView,
|
||||
GrAppliedClip&& appliedClip,
|
||||
const GrXferProcessor::DstProxyView& dstProxyView,
|
||||
GrGeometryProcessor* gp,
|
||||
GrPrimitiveType primType) {
|
||||
return CreateProgramInfo(caps,
|
||||
arena,
|
||||
outputView,
|
||||
std::move(appliedClip),
|
||||
dstProxyView,
|
||||
gp,
|
||||
this->detachProcessorSet(),
|
||||
primType,
|
||||
this->pipelineFlags());
|
||||
}
|
||||
|
||||
#ifdef SK_DEBUG
|
||||
static void dump_pipeline_flags(GrPipeline::InputFlags flags, SkString* result) {
|
||||
if (GrPipeline::InputFlags::kNone != flags) {
|
||||
|
@ -157,6 +157,14 @@ public:
|
||||
const GrUserStencilSettings*
|
||||
= &GrUserStencilSettings::kUnused);
|
||||
|
||||
GrProgramInfo* createProgramInfo(const GrCaps*,
|
||||
SkArenaAlloc*,
|
||||
const GrSurfaceProxyView* outputView,
|
||||
GrAppliedClip&&,
|
||||
const GrXferProcessor::DstProxyView&,
|
||||
GrGeometryProcessor*,
|
||||
GrPrimitiveType);
|
||||
|
||||
GrProcessorSet detachProcessorSet() {
|
||||
return fProcessors ? std::move(*fProcessors) : GrProcessorSet::MakeEmptySet();
|
||||
}
|
||||
|
@ -11,7 +11,7 @@ const GrPipeline* GrSimpleMeshDrawOpHelperWithStencil::createPipelineWithStencil
|
||||
GrOpFlushState* flushState) {
|
||||
return GrSimpleMeshDrawOpHelper::CreatePipeline(&flushState->caps(),
|
||||
flushState->allocator(),
|
||||
flushState->view(),
|
||||
flushState->outputView(),
|
||||
flushState->detachAppliedClip(),
|
||||
flushState->dstProxyView(),
|
||||
this->detachProcessorSet(),
|
||||
|
@ -180,8 +180,8 @@ void GrDrawAtlasPathOp::onExecute(GrOpFlushState* state, const SkRect& chainBoun
|
||||
SkASSERT(shader.instanceStride() == Instance::Stride(fUsesLocalCoords));
|
||||
|
||||
GrProgramInfo programInfo(state->proxy()->numSamples(), state->proxy()->numStencilSamples(),
|
||||
state->proxy()->backendFormat(), state->view()->origin(), &pipeline,
|
||||
&shader, &fixedDynamicState, nullptr, 0,
|
||||
state->proxy()->backendFormat(), state->outputView()->origin(),
|
||||
&pipeline, &shader, &fixedDynamicState, nullptr, 0,
|
||||
GrPrimitiveType::kTriangleStrip);
|
||||
|
||||
GrMesh mesh;
|
||||
|
@ -45,7 +45,7 @@ public:
|
||||
const GrPipeline::FixedDynamicState* fixedDynamicState, const GrMesh& mesh,
|
||||
const SkRect& bounds) {
|
||||
GrProgramInfo programInfo(state->proxy()->numSamples(), state->proxy()->numStencilSamples(),
|
||||
state->proxy()->backendFormat(), state->view()->origin(),
|
||||
state->proxy()->backendFormat(), state->outputView()->origin(),
|
||||
pipeline, this, fixedDynamicState, nullptr, 0,
|
||||
fPrimitiveType, fTessellationPatchVertexCount);
|
||||
state->opsRenderPass()->bindPipeline(programInfo, bounds);
|
||||
|
@ -441,7 +441,7 @@ void DrawMeshHelper::drawMesh(const GrMesh& mesh, GrPrimitiveType primitiveType)
|
||||
GrProgramInfo programInfo(fState->proxy()->numSamples(),
|
||||
fState->proxy()->numStencilSamples(),
|
||||
fState->proxy()->backendFormat(),
|
||||
fState->view()->origin(),
|
||||
fState->outputView()->origin(),
|
||||
pipeline,
|
||||
mtp,
|
||||
nullptr, nullptr, 0, primitiveType);
|
||||
|
@ -163,7 +163,7 @@ private:
|
||||
GrProgramInfo programInfo(flushState->proxy()->numSamples(),
|
||||
flushState->proxy()->numStencilSamples(),
|
||||
flushState->proxy()->backendFormat(),
|
||||
flushState->view()->origin(),
|
||||
flushState->outputView()->origin(),
|
||||
&pipeline,
|
||||
geomProc,
|
||||
nullptr,
|
||||
|
@ -110,7 +110,7 @@ private:
|
||||
GrProgramInfo* createProgramInfo(GrOpFlushState* flushState) {
|
||||
return this->createProgramInfo(&flushState->caps(),
|
||||
flushState->allocator(),
|
||||
flushState->view(),
|
||||
flushState->outputView(),
|
||||
flushState->detachAppliedClip(),
|
||||
flushState->dstProxyView());
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user