Line | |
---|
1 | using System;
|
---|
2 |
|
---|
3 | using SharpVectors.Polynomials;
|
---|
4 |
|
---|
5 | namespace SharpVectors.Dom.Svg
|
---|
6 | {
|
---|
7 | public abstract class SvgPathSegCurvetoQuadratic : SvgPathSegCurveto
|
---|
8 | {
|
---|
9 | protected SvgPathSegCurvetoQuadratic(SvgPathSegType type) : base(type)
|
---|
10 | {
|
---|
11 | }
|
---|
12 |
|
---|
13 | public abstract override SvgPointF AbsXY{get;}
|
---|
14 | public abstract override SvgPointF CubicX1Y1{get;}
|
---|
15 | public abstract override SvgPointF CubicX2Y2{get;}
|
---|
16 |
|
---|
17 | public abstract SvgPointF QuadraticX1Y1{get;}
|
---|
18 |
|
---|
19 | protected override SqrtPolynomial getArcLengthPolynomial()
|
---|
20 | {
|
---|
21 | double c2x, c2y, c1x, c1y;
|
---|
22 | SvgPointF p1 = PreviousSeg.AbsXY;
|
---|
23 | SvgPointF p2 = QuadraticX1Y1;
|
---|
24 | SvgPointF p3 = AbsXY;
|
---|
25 |
|
---|
26 | c2x = p1.X - 2.0 * p2.X + p3.X;
|
---|
27 | c2y = p1.Y - 2.0 * p2.Y + p3.Y;
|
---|
28 |
|
---|
29 | c1x = -2.0*p1.X + 2.0*p2.X;
|
---|
30 | c1y = -2.0*p1.Y + 2.0*p2.Y;
|
---|
31 |
|
---|
32 | // build polynomial
|
---|
33 | // dx = dx/dt
|
---|
34 | // dy = dy/dt
|
---|
35 | // sqrt poly = sqrt( (dx*dx) + (dy*dy) )
|
---|
36 | return new SqrtPolynomial(
|
---|
37 | c1x*c1x + c1y*c1y, 4.0*(c1x*c2x + c1y*c2y), 4.0*(c2x*c2x + c2y*c2y));
|
---|
38 | }
|
---|
39 | }
|
---|
40 | }
|
---|
Note: See
TracBrowser
for help on using the repository browser.