1 | /*
|
---|
2 | * SVG Salamander
|
---|
3 | * Copyright (c) 2004, Mark McKay
|
---|
4 | * All rights reserved.
|
---|
5 | *
|
---|
6 | * Redistribution and use in source and binary forms, with or
|
---|
7 | * without modification, are permitted provided that the following
|
---|
8 | * conditions are met:
|
---|
9 | *
|
---|
10 | * - Redistributions of source code must retain the above
|
---|
11 | * copyright notice, this list of conditions and the following
|
---|
12 | * disclaimer.
|
---|
13 | * - Redistributions in binary form must reproduce the above
|
---|
14 | * copyright notice, this list of conditions and the following
|
---|
15 | * disclaimer in the documentation and/or other materials
|
---|
16 | * provided with the distribution.
|
---|
17 | *
|
---|
18 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
---|
19 | * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
---|
20 | * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
---|
21 | * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
---|
22 | * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
|
---|
23 | * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
---|
24 | * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
---|
25 | * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
---|
26 | * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
---|
27 | * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
---|
28 | * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
|
---|
29 | * OF THE POSSIBILITY OF SUCH DAMAGE.
|
---|
30 | *
|
---|
31 | * Mark McKay can be contacted at mark@kitfox.com. Salamander and other
|
---|
32 | * projects can be found at http://www.kitfox.com
|
---|
33 | *
|
---|
34 | * Created on January 26, 2004, 8:40 PM
|
---|
35 | */
|
---|
36 |
|
---|
37 | package com.kitfox.svg.pathcmd;
|
---|
38 |
|
---|
39 | //import org.apache.batik.ext.awt.geom.ExtendedGeneralPath;
|
---|
40 | import java.awt.geom.*;
|
---|
41 |
|
---|
42 | /**
|
---|
43 | * @author Mark McKay
|
---|
44 | * @author <a href="mailto:mark@kitfox.com">Mark McKay</a>
|
---|
45 | */
|
---|
46 | public class CubicSmooth extends PathCommand {
|
---|
47 |
|
---|
48 | public float x = 0f;
|
---|
49 | public float y = 0f;
|
---|
50 | public float k2x = 0f;
|
---|
51 | public float k2y = 0f;
|
---|
52 |
|
---|
53 | /** Creates a new instance of MoveTo */
|
---|
54 | public CubicSmooth() {
|
---|
55 | }
|
---|
56 |
|
---|
57 | public CubicSmooth(boolean isRelative, float k2x, float k2y, float x, float y) {
|
---|
58 | super(isRelative);
|
---|
59 | this.k2x = k2x;
|
---|
60 | this.k2y = k2y;
|
---|
61 | this.x = x;
|
---|
62 | this.y = y;
|
---|
63 | }
|
---|
64 |
|
---|
65 | // public void appendPath(ExtendedGeneralPath path, BuildHistory hist)
|
---|
66 | public void appendPath(GeneralPath path, BuildHistory hist)
|
---|
67 | {
|
---|
68 | float offx = isRelative ? hist.lastPoint.x : 0f;
|
---|
69 | float offy = isRelative ? hist.lastPoint.y : 0f;
|
---|
70 |
|
---|
71 | float oldKx = hist.lastKnot.x;
|
---|
72 | float oldKy = hist.lastKnot.y;
|
---|
73 | float oldX = hist.lastPoint.x;
|
---|
74 | float oldY = hist.lastPoint.y;
|
---|
75 | //Calc knot as reflection of old knot
|
---|
76 | float k1x = oldX * 2f - oldKx;
|
---|
77 | float k1y = oldY * 2f - oldKy;
|
---|
78 |
|
---|
79 | path.curveTo(k1x, k1y, k2x + offx, k2y + offy, x + offx, y + offy);
|
---|
80 | hist.setLastPoint(x + offx, y + offy);
|
---|
81 | hist.setLastKnot(k2x + offx, k2y + offy);
|
---|
82 | }
|
---|
83 |
|
---|
84 | public int getNumKnotsAdded()
|
---|
85 | {
|
---|
86 | return 6;
|
---|
87 | }
|
---|
88 |
|
---|
89 | public String toString()
|
---|
90 | {
|
---|
91 | return "S " + k2x + " " + k2y
|
---|
92 | + " " + x + " " + y;
|
---|
93 | }
|
---|
94 | }
|
---|