OLD | NEW |
1 | 1 |
2 /* | 2 /* |
3 * Copyright 2013 Google Inc. | 3 * Copyright 2013 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 // This test only works with the GPU backend. | 9 // This test only works with the GPU backend. |
10 | 10 |
11 #include "gm.h" | 11 #include "gm.h" |
12 | 12 |
13 #if SK_SUPPORT_GPU | 13 #if SK_SUPPORT_GPU |
14 | 14 |
15 #include "GrContext.h" | 15 #include "GrContext.h" |
16 #include "GrPathUtils.h" | 16 #include "GrPathUtils.h" |
17 #include "GrTest.h" | 17 #include "GrTest.h" |
18 #include "SkColorPriv.h" | 18 #include "SkColorPriv.h" |
19 #include "SkDevice.h" | 19 #include "SkDevice.h" |
20 #include "SkGeometry.h" | 20 #include "SkGeometry.h" |
21 | 21 |
22 #include "effects/GrBezierEffect.h" | 22 #include "effects/GrBezierEffect.h" |
23 | 23 |
24 // Position & KLM line eq values. These are the vertex attributes for Bezier cur
ves. The last value | 24 // Position & KLM line eq values. These are the vertex attributes for Bezier cur
ves. The last value |
25 // of the Vec4f is ignored. | 25 // of the Vec4f is ignored. |
26 namespace { | 26 namespace { |
27 extern const GrVertexAttrib kAttribs[] = { | 27 extern const GrVertexAttrib kAttribs[] = { |
28 {kVec2f_GrVertexAttribType, 0, kPosition_GrVertexAttribBinding}, | 28 {kVec2f_GrVertexAttribType, 0, kPosition_GrVertexAttribBinding}, |
29 {kVec4f_GrVertexAttribType, sizeof(SkPoint), kEffect_GrVertexAttribBinding} | 29 {kVec4f_GrVertexAttribType, sizeof(SkPoint), kGeometryProcessor_GrVertexAttr
ibBinding} |
30 }; | 30 }; |
31 } | 31 } |
32 | 32 |
33 static inline SkScalar eval_line(const SkPoint& p, const SkScalar lineEq[3], SkS
calar sign) { | 33 static inline SkScalar eval_line(const SkPoint& p, const SkScalar lineEq[3], SkS
calar sign) { |
34 return sign * (lineEq[0] * p.fX + lineEq[1] * p.fY + lineEq[2]); | 34 return sign * (lineEq[0] * p.fX + lineEq[1] * p.fY + lineEq[2]); |
35 } | 35 } |
36 | 36 |
37 namespace skiagm { | 37 namespace skiagm { |
38 /** | 38 /** |
39 * This GM directly exercises effects that draw Bezier curves in the GPU backend
. | 39 * This GM directly exercises effects that draw Bezier curves in the GPU backend
. |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
85 int row = 0; | 85 int row = 0; |
86 int col = 0; | 86 int col = 0; |
87 | 87 |
88 for (int i = 0; i < kNumCubics; ++i) { | 88 for (int i = 0; i < kNumCubics; ++i) { |
89 SkPoint baseControlPts[] = { | 89 SkPoint baseControlPts[] = { |
90 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)}, | 90 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)}, |
91 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)}, | 91 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)}, |
92 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)}, | 92 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)}, |
93 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)} | 93 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)} |
94 }; | 94 }; |
95 for(int edgeType = 0; edgeType < kGrEffectEdgeTypeCnt; ++edgeType) { | 95 for(int edgeType = 0; edgeType < kGrProcessorEdgeTypeCnt; ++edgeType
) { |
96 SkAutoTUnref<GrEffect> effect; | 96 SkAutoTUnref<GrGeometryProcessor> gp; |
97 { // scope to contain GrTestTarget | 97 { // scope to contain GrTestTarget |
98 GrTestTarget tt; | 98 GrTestTarget tt; |
99 context->getTestTarget(&tt); | 99 context->getTestTarget(&tt); |
100 if (NULL == tt.target()) { | 100 if (NULL == tt.target()) { |
101 continue; | 101 continue; |
102 } | 102 } |
103 GrEffectEdgeType et = (GrEffectEdgeType)edgeType; | 103 GrProcessorEdgeType et = (GrProcessorEdgeType)edgeType; |
104 effect.reset(GrCubicEffect::Create(et, *tt.target()->caps())
); | 104 gp.reset(GrCubicEffect::Create(et, *tt.target()->caps())); |
105 if (!effect) { | 105 if (!gp) { |
106 continue; | 106 continue; |
107 } | 107 } |
108 } | 108 } |
109 | 109 |
110 SkScalar x = SkScalarMul(col, w); | 110 SkScalar x = SkScalarMul(col, w); |
111 SkScalar y = SkScalarMul(row, h); | 111 SkScalar y = SkScalarMul(row, h); |
112 SkPoint controlPts[] = { | 112 SkPoint controlPts[] = { |
113 {x + baseControlPts[0].fX, y + baseControlPts[0].fY}, | 113 {x + baseControlPts[0].fX, y + baseControlPts[0].fY}, |
114 {x + baseControlPts[1].fX, y + baseControlPts[1].fY}, | 114 {x + baseControlPts[1].fX, y + baseControlPts[1].fY}, |
115 {x + baseControlPts[2].fX, y + baseControlPts[2].fY}, | 115 {x + baseControlPts[2].fX, y + baseControlPts[2].fY}, |
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
163 verts[v].fKLM[1] = eval_line(verts[v].fPosition, klmEqs
+ 3, klmSigns[c]); | 163 verts[v].fKLM[1] = eval_line(verts[v].fPosition, klmEqs
+ 3, klmSigns[c]); |
164 verts[v].fKLM[2] = eval_line(verts[v].fPosition, klmEqs
+ 6, 1.f); | 164 verts[v].fKLM[2] = eval_line(verts[v].fPosition, klmEqs
+ 6, 1.f); |
165 } | 165 } |
166 | 166 |
167 GrTestTarget tt; | 167 GrTestTarget tt; |
168 context->getTestTarget(&tt); | 168 context->getTestTarget(&tt); |
169 SkASSERT(tt.target()); | 169 SkASSERT(tt.target()); |
170 GrDrawState* drawState = tt.target()->drawState(); | 170 GrDrawState* drawState = tt.target()->drawState(); |
171 drawState->setVertexAttribs<kAttribs>(2, sizeof(Vertex)); | 171 drawState->setVertexAttribs<kAttribs>(2, sizeof(Vertex)); |
172 | 172 |
173 drawState->setGeometryProcessor(effect); | 173 drawState->setGeometryProcessor(gp); |
174 drawState->setRenderTarget(rt); | 174 drawState->setRenderTarget(rt); |
175 drawState->setColor(0xff000000); | 175 drawState->setColor(0xff000000); |
176 | 176 |
177 tt.target()->setVertexSourceToArray(verts, 4); | 177 tt.target()->setVertexSourceToArray(verts, 4); |
178 tt.target()->setIndexSourceToBuffer(context->getQuadIndexBuf
fer()); | 178 tt.target()->setIndexSourceToBuffer(context->getQuadIndexBuf
fer()); |
179 tt.target()->drawIndexed(kTriangleFan_GrPrimitiveType, 0, 0,
4, 6); | 179 tt.target()->drawIndexed(kTriangleFan_GrPrimitiveType, 0, 0,
4, 6); |
180 } | 180 } |
181 ++col; | 181 ++col; |
182 if (numCols == col) { | 182 if (numCols == col) { |
183 col = 0; | 183 col = 0; |
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
243 int row = 0; | 243 int row = 0; |
244 int col = 0; | 244 int col = 0; |
245 | 245 |
246 for (int i = 0; i < kNumConics; ++i) { | 246 for (int i = 0; i < kNumConics; ++i) { |
247 SkPoint baseControlPts[] = { | 247 SkPoint baseControlPts[] = { |
248 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)}, | 248 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)}, |
249 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)}, | 249 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)}, |
250 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)} | 250 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)} |
251 }; | 251 }; |
252 SkScalar weight = rand.nextRangeF(0.f, 2.f); | 252 SkScalar weight = rand.nextRangeF(0.f, 2.f); |
253 for(int edgeType = 0; edgeType < kGrEffectEdgeTypeCnt; ++edgeType) { | 253 for(int edgeType = 0; edgeType < kGrProcessorEdgeTypeCnt; ++edgeType
) { |
254 SkAutoTUnref<GrEffect> effect; | 254 SkAutoTUnref<GrGeometryProcessor> gp; |
255 { // scope to contain GrTestTarget | 255 { // scope to contain GrTestTarget |
256 GrTestTarget tt; | 256 GrTestTarget tt; |
257 context->getTestTarget(&tt); | 257 context->getTestTarget(&tt); |
258 if (NULL == tt.target()) { | 258 if (NULL == tt.target()) { |
259 continue; | 259 continue; |
260 } | 260 } |
261 GrEffectEdgeType et = (GrEffectEdgeType)edgeType; | 261 GrProcessorEdgeType et = (GrProcessorEdgeType)edgeType; |
262 effect.reset(GrConicEffect::Create(et, *tt.target()->caps())
); | 262 gp.reset(GrConicEffect::Create(et, *tt.target()->caps())); |
263 if (!effect) { | 263 if (!gp) { |
264 continue; | 264 continue; |
265 } | 265 } |
266 } | 266 } |
267 | 267 |
268 SkScalar x = SkScalarMul(col, w); | 268 SkScalar x = SkScalarMul(col, w); |
269 SkScalar y = SkScalarMul(row, h); | 269 SkScalar y = SkScalarMul(row, h); |
270 SkPoint controlPts[] = { | 270 SkPoint controlPts[] = { |
271 {x + baseControlPts[0].fX, y + baseControlPts[0].fY}, | 271 {x + baseControlPts[0].fX, y + baseControlPts[0].fY}, |
272 {x + baseControlPts[1].fX, y + baseControlPts[1].fY}, | 272 {x + baseControlPts[1].fX, y + baseControlPts[1].fY}, |
273 {x + baseControlPts[2].fX, y + baseControlPts[2].fY} | 273 {x + baseControlPts[2].fX, y + baseControlPts[2].fY} |
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
318 verts[v].fKLM[1] = eval_line(verts[v].fPosition, klmEqs
+ 3, 1.f); | 318 verts[v].fKLM[1] = eval_line(verts[v].fPosition, klmEqs
+ 3, 1.f); |
319 verts[v].fKLM[2] = eval_line(verts[v].fPosition, klmEqs
+ 6, 1.f); | 319 verts[v].fKLM[2] = eval_line(verts[v].fPosition, klmEqs
+ 6, 1.f); |
320 } | 320 } |
321 | 321 |
322 GrTestTarget tt; | 322 GrTestTarget tt; |
323 context->getTestTarget(&tt); | 323 context->getTestTarget(&tt); |
324 SkASSERT(tt.target()); | 324 SkASSERT(tt.target()); |
325 GrDrawState* drawState = tt.target()->drawState(); | 325 GrDrawState* drawState = tt.target()->drawState(); |
326 drawState->setVertexAttribs<kAttribs>(2, sizeof(Vertex)); | 326 drawState->setVertexAttribs<kAttribs>(2, sizeof(Vertex)); |
327 | 327 |
328 drawState->setGeometryProcessor(effect); | 328 drawState->setGeometryProcessor(gp); |
329 drawState->setRenderTarget(rt); | 329 drawState->setRenderTarget(rt); |
330 drawState->setColor(0xff000000); | 330 drawState->setColor(0xff000000); |
331 | 331 |
332 tt.target()->setVertexSourceToArray(verts, 4); | 332 tt.target()->setVertexSourceToArray(verts, 4); |
333 tt.target()->setIndexSourceToBuffer(context->getQuadIndexBuf
fer()); | 333 tt.target()->setIndexSourceToBuffer(context->getQuadIndexBuf
fer()); |
334 tt.target()->drawIndexed(kTriangleFan_GrPrimitiveType, 0, 0,
4, 6); | 334 tt.target()->drawIndexed(kTriangleFan_GrPrimitiveType, 0, 0,
4, 6); |
335 } | 335 } |
336 ++col; | 336 ++col; |
337 if (numCols == col) { | 337 if (numCols == col) { |
338 col = 0; | 338 col = 0; |
(...skipping 93 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
432 SkScalar h = SkIntToScalar(rt->height()) / numRows; | 432 SkScalar h = SkIntToScalar(rt->height()) / numRows; |
433 int row = 0; | 433 int row = 0; |
434 int col = 0; | 434 int col = 0; |
435 | 435 |
436 for (int i = 0; i < kNumQuads; ++i) { | 436 for (int i = 0; i < kNumQuads; ++i) { |
437 SkPoint baseControlPts[] = { | 437 SkPoint baseControlPts[] = { |
438 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)}, | 438 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)}, |
439 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)}, | 439 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)}, |
440 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)} | 440 {rand.nextRangeF(0.f, w), rand.nextRangeF(0.f, h)} |
441 }; | 441 }; |
442 for(int edgeType = 0; edgeType < kGrEffectEdgeTypeCnt; ++edgeType) { | 442 for(int edgeType = 0; edgeType < kGrProcessorEdgeTypeCnt; ++edgeType
) { |
443 SkAutoTUnref<GrEffect> effect; | 443 SkAutoTUnref<GrGeometryProcessor> gp; |
444 { // scope to contain GrTestTarget | 444 { // scope to contain GrTestTarget |
445 GrTestTarget tt; | 445 GrTestTarget tt; |
446 context->getTestTarget(&tt); | 446 context->getTestTarget(&tt); |
447 if (NULL == tt.target()) { | 447 if (NULL == tt.target()) { |
448 continue; | 448 continue; |
449 } | 449 } |
450 GrEffectEdgeType et = (GrEffectEdgeType)edgeType; | 450 GrProcessorEdgeType et = (GrProcessorEdgeType)edgeType; |
451 effect.reset(GrQuadEffect::Create(et, *tt.target()->caps()))
; | 451 gp.reset(GrQuadEffect::Create(et, *tt.target()->caps())); |
452 if (!effect) { | 452 if (!gp) { |
453 continue; | 453 continue; |
454 } | 454 } |
455 } | 455 } |
456 | 456 |
457 SkScalar x = SkScalarMul(col, w); | 457 SkScalar x = SkScalarMul(col, w); |
458 SkScalar y = SkScalarMul(row, h); | 458 SkScalar y = SkScalarMul(row, h); |
459 SkPoint controlPts[] = { | 459 SkPoint controlPts[] = { |
460 {x + baseControlPts[0].fX, y + baseControlPts[0].fY}, | 460 {x + baseControlPts[0].fX, y + baseControlPts[0].fY}, |
461 {x + baseControlPts[1].fX, y + baseControlPts[1].fY}, | 461 {x + baseControlPts[1].fX, y + baseControlPts[1].fY}, |
462 {x + baseControlPts[2].fX, y + baseControlPts[2].fY} | 462 {x + baseControlPts[2].fX, y + baseControlPts[2].fY} |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
502 | 502 |
503 GrPathUtils::QuadUVMatrix DevToUV(pts); | 503 GrPathUtils::QuadUVMatrix DevToUV(pts); |
504 DevToUV.apply<4, sizeof(Vertex), sizeof(SkPoint)>(verts); | 504 DevToUV.apply<4, sizeof(Vertex), sizeof(SkPoint)>(verts); |
505 | 505 |
506 GrTestTarget tt; | 506 GrTestTarget tt; |
507 context->getTestTarget(&tt); | 507 context->getTestTarget(&tt); |
508 SkASSERT(tt.target()); | 508 SkASSERT(tt.target()); |
509 GrDrawState* drawState = tt.target()->drawState(); | 509 GrDrawState* drawState = tt.target()->drawState(); |
510 drawState->setVertexAttribs<kAttribs>(2, sizeof(Vertex)); | 510 drawState->setVertexAttribs<kAttribs>(2, sizeof(Vertex)); |
511 | 511 |
512 drawState->setGeometryProcessor(effect); | 512 drawState->setGeometryProcessor(gp); |
513 drawState->setRenderTarget(rt); | 513 drawState->setRenderTarget(rt); |
514 drawState->setColor(0xff000000); | 514 drawState->setColor(0xff000000); |
515 | 515 |
516 tt.target()->setVertexSourceToArray(verts, 4); | 516 tt.target()->setVertexSourceToArray(verts, 4); |
517 tt.target()->setIndexSourceToBuffer(context->getQuadIndexBuf
fer()); | 517 tt.target()->setIndexSourceToBuffer(context->getQuadIndexBuf
fer()); |
518 tt.target()->drawIndexed(kTriangles_GrPrimitiveType, 0, 0, 4
, 6); | 518 tt.target()->drawIndexed(kTriangles_GrPrimitiveType, 0, 0, 4
, 6); |
519 } | 519 } |
520 ++col; | 520 ++col; |
521 if (numCols == col) { | 521 if (numCols == col) { |
522 col = 0; | 522 col = 0; |
523 ++row; | 523 ++row; |
524 } | 524 } |
525 } | 525 } |
526 } | 526 } |
527 } | 527 } |
528 | 528 |
529 private: | 529 private: |
530 typedef GM INHERITED; | 530 typedef GM INHERITED; |
531 }; | 531 }; |
532 | 532 |
533 DEF_GM( return SkNEW(BezierCubicEffects); ) | 533 DEF_GM( return SkNEW(BezierCubicEffects); ) |
534 DEF_GM( return SkNEW(BezierConicEffects); ) | 534 DEF_GM( return SkNEW(BezierConicEffects); ) |
535 DEF_GM( return SkNEW(BezierQuadEffects); ) | 535 DEF_GM( return SkNEW(BezierQuadEffects); ) |
536 | 536 |
537 } | 537 } |
538 | 538 |
539 #endif | 539 #endif |
OLD | NEW |