aboutsummaryrefslogtreecommitdiffhomepage
path: root/samplecode
diff options
context:
space:
mode:
authorGravatar Chris Dalton <csmartdalton@google.com>2018-02-07 13:02:58 -0700
committerGravatar Skia Commit-Bot <skia-commit-bot@chromium.org>2018-02-12 17:06:31 +0000
commit4138c972effe4eb0227fbb96571df290f3d1979b (patch)
treef506f42ba68294dac155f09c01f77ae8186e3150 /samplecode
parenta58bcf7ef8227708dad1501db59bd506e83e5341 (diff)
ccpr: Tessellate fans for very large and/or simple paths
This increases CPU work, but reduces overdraw on the GPU as compared to Redbook fanning. Bug: skia: Change-Id: I47239c964261e0014a94266a71223eab0597bfb8 Reviewed-on: https://skia-review.googlesource.com/105203 Reviewed-by: Brian Salomon <bsalomon@google.com> Commit-Queue: Chris Dalton <csmartdalton@google.com>
Diffstat (limited to 'samplecode')
-rw-r--r--samplecode/SampleCCPRGeometry.cpp39
1 files changed, 20 insertions, 19 deletions
diff --git a/samplecode/SampleCCPRGeometry.cpp b/samplecode/SampleCCPRGeometry.cpp
index 5a2da7f02b..a0c5d7be7a 100644
--- a/samplecode/SampleCCPRGeometry.cpp
+++ b/samplecode/SampleCCPRGeometry.cpp
@@ -26,8 +26,8 @@
#include "gl/GrGLGpu.cpp"
#include "ops/GrDrawOp.h"
-using TriangleInstance = GrCCCoverageProcessor::TriangleInstance;
-using CubicInstance = GrCCCoverageProcessor::CubicInstance;
+using TriPointInstance = GrCCCoverageProcessor::TriPointInstance;
+using QuadPointInstance = GrCCCoverageProcessor::QuadPointInstance;
using RenderPass = GrCCCoverageProcessor::RenderPass;
static constexpr float kDebugBloat = 40;
@@ -66,8 +66,8 @@ private:
SkPoint fPoints[4] = {
{100.05f, 100.05f}, {400.75f, 100.05f}, {400.75f, 300.95f}, {100.05f, 300.95f}};
- SkTArray<TriangleInstance> fTriangleInstances;
- SkTArray<CubicInstance> fCubicInstances;
+ SkTArray<TriPointInstance> fTriPointInstances;
+ SkTArray<QuadPointInstance> fQuadPointInstances;
typedef SampleView INHERITED;
};
@@ -190,8 +190,8 @@ void CCPRGeometryView::onDrawContent(SkCanvas* canvas) {
}
void CCPRGeometryView::updateGpuData() {
- fTriangleInstances.reset();
- fCubicInstances.reset();
+ fTriPointInstances.reset();
+ fQuadPointInstances.reset();
if (GrCCCoverageProcessor::RenderPassIsCubic(fRenderPass)) {
double t[2], s[2];
@@ -210,7 +210,7 @@ void CCPRGeometryView::updateGpuData() {
ptsIdx += 2;
continue;
case GrCCGeometry::Verb::kMonotonicCubicTo:
- fCubicInstances.push_back().set(&geometry.points()[ptsIdx], 0, 0);
+ fQuadPointInstances.push_back().set(&geometry.points()[ptsIdx], 0, 0);
ptsIdx += 3;
continue;
default:
@@ -234,11 +234,11 @@ void CCPRGeometryView::updateGpuData() {
continue;
}
SkASSERT(GrCCGeometry::Verb::kMonotonicQuadraticTo == verb);
- fTriangleInstances.push_back().set(&geometry.points()[ptsIdx], Sk2f(0, 0));
+ fTriPointInstances.push_back().set(&geometry.points()[ptsIdx], Sk2f(0, 0));
ptsIdx += 2;
}
} else {
- fTriangleInstances.push_back().set(fPoints[0], fPoints[1], fPoints[3], Sk2f(0, 0));
+ fTriPointInstances.push_back().set(fPoints[0], fPoints[1], fPoints[3], Sk2f(0, 0));
}
}
@@ -253,27 +253,28 @@ void CCPRGeometryView::Op::onExecute(GrOpFlushState* state) {
return;
}
- GrCCCoverageProcessor proc(rp, fView->fRenderPass, state->caps());
+ GrCCCoverageProcessor proc(rp, fView->fRenderPass,
+ GrCCCoverageProcessor::WindMethod::kCrossProduct);
SkDEBUGCODE(proc.enableDebugVisualizations(kDebugBloat));
SkSTArray<1, GrMesh> mesh;
if (GrCCCoverageProcessor::RenderPassIsCubic(fView->fRenderPass)) {
sk_sp<GrBuffer> instBuff(rp->createBuffer(
- fView->fCubicInstances.count() * sizeof(CubicInstance), kVertex_GrBufferType,
- kDynamic_GrAccessPattern,
+ fView->fQuadPointInstances.count() * sizeof(QuadPointInstance),
+ kVertex_GrBufferType, kDynamic_GrAccessPattern,
GrResourceProvider::kNoPendingIO_Flag | GrResourceProvider::kRequireGpuMemory_Flag,
- fView->fCubicInstances.begin()));
- if (!fView->fCubicInstances.empty() && instBuff) {
- proc.appendMesh(instBuff.get(), fView->fCubicInstances.count(), 0, &mesh);
+ fView->fQuadPointInstances.begin()));
+ if (!fView->fQuadPointInstances.empty() && instBuff) {
+ proc.appendMesh(instBuff.get(), fView->fQuadPointInstances.count(), 0, &mesh);
}
} else {
sk_sp<GrBuffer> instBuff(rp->createBuffer(
- fView->fTriangleInstances.count() * sizeof(TriangleInstance), kVertex_GrBufferType,
+ fView->fTriPointInstances.count() * sizeof(TriPointInstance), kVertex_GrBufferType,
kDynamic_GrAccessPattern,
GrResourceProvider::kNoPendingIO_Flag | GrResourceProvider::kRequireGpuMemory_Flag,
- fView->fTriangleInstances.begin()));
- if (!fView->fTriangleInstances.empty() && instBuff) {
- proc.appendMesh(instBuff.get(), fView->fTriangleInstances.count(), 0, &mesh);
+ fView->fTriPointInstances.begin()));
+ if (!fView->fTriPointInstances.empty() && instBuff) {
+ proc.appendMesh(instBuff.get(), fView->fTriPointInstances.count(), 0, &mesh);
}
}