blob: 1c3f91da4f76b944792218d82248107882b37fca [file] [log] [blame]
Hal Canary6c8422c2020-01-10 15:22:09 -05001// Copyright 2020 Google LLC.
2// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file.
3#include "tools/fiddle/examples.h"
4REG_FIDDLE(SkPath_arcto_conic_parametric, 512, 512, false, 0) {
5SkPoint conic(SkPoint p0, SkPoint p1, SkPoint p2, float w, float t) {
6 float s = 1 - t;
7 return {((s * s * p0.x()) + (2 * s * t * w * p1.x()) + (t * t * p2.x())) /
8 ((s * s) + (w * 2 * s * t) + (t * t)),
9 ((s * s * p0.y()) + (2 * s * t * w * p1.y()) + (t * t * p2.y())) /
10 ((s * s) + (w * 2 * s * t) + (t * t))};
11}
12
13void draw(SkCanvas* canvas) {
14 canvas->clear(SkColorSetARGB(255, 255, 255, 255));
15
16 SkPaint paint;
17 paint.setAntiAlias(true);
18 paint.setStyle(SkPaint::kStroke_Style);
19 paint.setStrokeWidth(2.5);
20
21 SkPoint center = {256, 256};
22 float r = 192;
23 SkRect oval = {center.x() - r, center.y() - r, center.x() + r, center.y() + r};
24 canvas->drawOval(oval, paint);
25 float startAngle = 0;
26 float sweepAngle = 179;
27
28 SkPath arc;
29 arc.arcTo(oval, startAngle, sweepAngle, false);
30
31 paint.setStrokeWidth(5);
32 paint.setColor(SkColorSetARGB(255, 0, 0, 255));
33 canvas->drawPath(arc, paint);
34
35 SkPaint pointPaint;
36 pointPaint.setAntiAlias(true);
37 pointPaint.setStrokeWidth(8);
38 pointPaint.setStrokeCap(SkPaint::kRound_Cap);
39 pointPaint.setColor(SkColorSetARGB(255, 0, 255, 0));
40
41 float finalAngle = startAngle + sweepAngle;
42 float middleAngle = startAngle + 0.5f * sweepAngle;
43 float weight = cos(SkDegreesToRadians(sweepAngle) / 2);
44 SkPoint p0 = {r * SkScalarCos(SkDegreesToRadians(startAngle)),
45 r * SkScalarSin(SkDegreesToRadians(startAngle))};
46 float d = r / weight;
47 SkPoint p1 = {d * SkScalarCos(SkDegreesToRadians(middleAngle)),
48 d * SkScalarSin(SkDegreesToRadians(middleAngle))};
49 SkPoint p2 = {r * SkScalarCos(SkDegreesToRadians(finalAngle)),
50 r * SkScalarSin(SkDegreesToRadians(finalAngle))};
51 p0 += center;
52 p1 += center;
53 p2 += center;
54
55 const int N = 8;
56 for (int i = 0; i <= N; ++i) {
57 SkPoint p = conic(p0, p1, p2, weight, (float)i / N);
58 canvas->drawPoint(p.x(), p.y(), pointPaint);
59 }
60 pointPaint.setColor(SkColorSetARGB(255, 255, 0, 0));
61 canvas->drawPoint(p0.x(), p0.y(), pointPaint);
62 canvas->drawPoint(p1.x(), p1.y(), pointPaint);
63 canvas->drawPoint(p2.x(), p2.y(), pointPaint);
64
65 SkPath weightedQuadratic;
66 weightedQuadratic.moveTo(p0);
67 weightedQuadratic.conicTo(p1, p2, weight);
68 paint.setColor(SK_ColorCYAN);
69 paint.setStrokeWidth(1);
70 canvas->drawPath(weightedQuadratic, paint);
71}
72} // END FIDDLE