Initial commit of newLISP.
[newlisp.git] / guiserver / java / FilledPolygonShape.java
blobf158aecd5bf5ab67b91343b4e17cd86434ed6267
1 //
2 // FilledPolygonShape.java
3 // guiserver
4 //
5 // Created by Lutz Mueller on 7/2/07.
6 //
7 //
8 // Copyright (C) 2007 Lutz Mueller
9 //
10 // This program is free software: you can redistribute it and/or modify
11 // it under the terms of the GNU General Public License as published by
12 // the Free Software Foundation, either version 3 of the License, or
13 // (at your option) any later version.
15 // This program is distributed in the hope that it will be useful,
16 // but WITHOUT ANY WARRANTY; without even the implied warranty of
17 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 // GNU General Public License for more details.
20 // You should have received a copy of the GNU General Public License
21 // along with this program. If not, see <http://www.gnu.org/licenses/>.
25 import java.lang.*;
26 import java.awt.*;
27 import java.awt.color.*;
28 import java.awt.geom.*;
29 import java.util.*;
31 @SuppressWarnings("unchecked")
32 public class FilledPolygonShape extends Shape {
34 int pointXd[];
35 int pointYd[];
37 int N;
39 public FilledPolygonShape(StringTokenizer tokens)
41 tag = tokens.nextToken();
42 N = Integer.parseInt(tokens.nextToken());
44 pointXd = new int [N];
45 pointYd = new int [N];
47 X = Integer.parseInt(tokens.nextToken());
48 Y = Integer.parseInt(tokens.nextToken());
50 pointXd[0] = pointYd[0] = 0;
52 for(int i = 1; i < N; i++)
54 pointXd[i] = Integer.parseInt(tokens.nextToken()) - X;
55 pointYd[i] = Integer.parseInt(tokens.nextToken()) - Y;
58 if(tokens.hasMoreTokens())
59 paintColor = Shape.getColorParameter(tokens);
61 stroke = CanvasWidget.currentCanvas.currentStroke;
63 CanvasWidget.currentCanvas.drawobjects.add(this);
66 public void drawShape(Graphics2D g2)
68 g2.setStroke(stroke);
69 g2.setPaint(paintColor);
72 int pX[] = new int [N];
73 int pY[] = new int [N];
75 for(int i = 0; i < N; i++)
77 pX[i] = pointXd[i] + X;
78 pY[i] = pointYd[i] + Y;
81 g2.fillPolygon(pX, pY, N);
83 Polygon polygon = new Polygon();
85 for(int i = 0; i < N; i++)
86 polygon.addPoint(pointXd[i] + X, pointYd[i] + Y);
88 g2.fill(polygon);
91 public boolean hasPoint(int x, int y)
93 Polygon polygon = new Polygon();
95 for(int i = 0; i < N; i++)
96 polygon.addPoint(pointXd[i] + X, pointYd[i] + Y);
98 return(polygon.contains(x, y));
103 // eof //