source: josm/trunk/src/com/kitfox/svg/pathcmd/CubicSmooth.java@ 5369

Last change on this file since 5369 was 4256, checked in by bastiK, 13 years ago

see #6560 - basic svg support, includes kitfox svgsalamander, r 98, patched

File size: 2.6 KB
Line 
1/*
2 * MoveTo.java
3 *
4 *
5 * The Salamander Project - 2D and 3D graphics libraries in Java
6 * Copyright (C) 2004 Mark McKay
7 *
8 * This library is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Lesser General Public
10 * License as published by the Free Software Foundation; either
11 * version 2.1 of the License, or (at your option) any later version.
12 *
13 * This library is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * Lesser General Public License for more details.
17 *
18 * You should have received a copy of the GNU Lesser General Public
19 * License along with this library; if not, write to the Free Software
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21 *
22 * Mark McKay can be contacted at mark@kitfox.com. Salamander and other
23 * projects can be found at http://www.kitfox.com
24 *
25 * Created on January 26, 2004, 8:40 PM
26 */
27
28package com.kitfox.svg.pathcmd;
29
30//import org.apache.batik.ext.awt.geom.ExtendedGeneralPath;
31import java.awt.geom.*;
32
33/**
34 * @author Mark McKay
35 * @author <a href="mailto:mark@kitfox.com">Mark McKay</a>
36 */
37public class CubicSmooth extends PathCommand {
38
39 public float x = 0f;
40 public float y = 0f;
41 public float k2x = 0f;
42 public float k2y = 0f;
43
44 /** Creates a new instance of MoveTo */
45 public CubicSmooth() {
46 }
47
48 public CubicSmooth(boolean isRelative, float k2x, float k2y, float x, float y) {
49 super(isRelative);
50 this.k2x = k2x;
51 this.k2y = k2y;
52 this.x = x;
53 this.y = y;
54 }
55
56// public void appendPath(ExtendedGeneralPath path, BuildHistory hist)
57 public void appendPath(GeneralPath path, BuildHistory hist)
58 {
59 float offx = isRelative ? hist.history[0].x : 0f;
60 float offy = isRelative ? hist.history[0].y : 0f;
61
62 float oldKx = hist.history.length >= 2 ? hist.history[1].x : hist.history[0].x;
63 float oldKy = hist.history.length >= 2 ? hist.history[1].y : hist.history[0].y;
64 float oldX = hist.history[0].x;
65 float oldY = hist.history[0].y;
66 //Calc knot as reflection of old knot
67 float k1x = oldX * 2f - oldKx;
68 float k1y = oldY * 2f - oldKy;
69
70 path.curveTo(k1x, k1y, k2x + offx, k2y + offy, x + offx, y + offy);
71 hist.setPointAndKnot(x + offx, y + offy, k2x + offx, k2y + offy);
72 }
73
74 public int getNumKnotsAdded()
75 {
76 return 6;
77 }
78}
Note: See TracBrowser for help on using the repository browser.