Statistics
| Revision:

root / branches / CqCMSDvp / libraries / libCq CMS for java.old / src / org / cresques / px / gml / InsPoint.java @ 2750

History | View | Annotate | Download (7.4 KB)

1
/*
2
 * Cresques Mapping Suite. Graphic Library for constructing mapping applications.
3
 *
4
 * Copyright (C) 2004-5.
5
 *
6
 * This program is free software; you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License
8
 * as published by the Free Software Foundation; either version 2
9
 * of the License, or (at your option) any later version.
10
 *
11
 * This program is distributed in the hope that it will be useful,
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 * GNU General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with this program; if not, write to the Free Software
18
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,USA.
19
 *
20
 * For more information, contact:
21
 *
22
 * cresques@gmail.com
23
 */
24
package org.cresques.px.gml;
25

    
26
import org.cresques.cts.ICoordTrans;
27
import org.cresques.cts.IProjection;
28

    
29
import org.cresques.geo.Point3D;
30
import org.cresques.geo.ViewPortData;
31

    
32
import java.awt.Color;
33
import java.awt.Graphics2D;
34
import java.awt.geom.Line2D;
35
import java.awt.geom.Point2D;
36

    
37
import java.util.Vector;
38

    
39
/**
40
 * Punto de inserci?n. Se trata de un Point al que se le han a?adido los atributos
41
 * necesarios para hacer referencia a un conjunto de objetos gr?ficos o bloque.
42
 * @author jmorell
43
 */
44
public class InsPoint extends Geometry {
45
    public static int pointNr = 0;
46
    public String text = null;
47
    String blockName;
48
    Point3D scaleFactor;
49
    double rotAngle;
50
    private FeatureCollection block = new FeatureCollection(proj);
51
    Vector blkList;
52
    boolean blockFound = false;
53
    private Color fColor = null; //new Color(255,222,165,64);
54
    private Color color = new Color(255, 0, 0); //Color(255,214,132,255);
55
    
56
    /**
57
     * Constructor de la clase.
58
     */
59
    public InsPoint() {
60
        super();
61
    }
62
    
63
    /**
64
     * Permite a?adir un punto.
65
     * @param pt, Punto.
66
     */
67
    public void add(Point2D pt) {
68
        pointNr++;
69
        super.add(pt);
70
    }
71
    
72
    /**
73
     * Devuelve el ?ngulo de rotaci?n que se aplica al bloque.
74
     * @return double. ?ngulo de rotaci?n.
75
     */
76
    public double getRotAngle() {
77
        return rotAngle;
78
    }
79
    
80
    /**
81
     * Devuelve el factor de escala que se aplica al bloque.
82
     * @return Point3D. Contiene el factor de escala en X, en Y y en Z.
83
     */
84
    public Point3D getScaleFactor() {
85
        return scaleFactor;
86
    }
87
    
88
    /**
89
     * Devuelve la lista de bloques.
90
     * @return Vector, la lista de bloques.
91
     */
92
    public Vector getBlkList() {
93
        return blkList;
94
    }
95
    
96
    /**
97
     * Informa sobre si el bloque ya ha sido encontrado.
98
     * @return boolean, true si el bloque ya ha sido encontrado.
99
     */
100
    public boolean getBlockFound() {
101
        return blockFound;
102
    }
103
    
104
    /**
105
     * Establece el bloque al que hace referencia este punto de inserci?n.
106
     * @param block, bloque.
107
     */
108
    public void setBlock(FeatureCollection block) {
109
        this.block = block;
110
    }
111
    
112
    /**
113
     * Establece si el bloque ya ha sido encontrado.
114
     * @param found, true si el bloque ya ha sido encontrado.
115
     */
116
    public void setBlockFound(boolean found) {
117
        blockFound = found;
118
    }
119
    
120
    /**
121
     * Establece la lista de bloques.
122
     * @param blkList, Vector con la lista de bloques.
123
     */
124
    public void setBlkList(Vector blkList) {
125
        this.blkList = blkList;
126
    }
127
    
128
    /**
129
     * Devuelve el bloque al que hace referencia el punto de inserci?n.
130
     * @return FeatureCollection, el bloque.
131
     */
132
    public FeatureCollection getBlock() {
133
        return block;
134
    }
135
    
136
    /**
137
     * Establece el nombre del bloque.
138
     * @param blockName, nombre del bloque.
139
     */
140
    public void setBlockName(String blockName) {
141
        this.blockName = blockName;
142
    }
143
    
144
    /**
145
     * Devuelve el nombre del bloque al que hace referencia el punto de inserci?n.
146
     * @return String, nombre del bloque.
147
     */
148
    public String getBlockName() {
149
        return blockName;
150
    }
151
    
152
    /**
153
     * Establece el factor de escala para el bloque.
154
     * @param scaleFactor, factor de escala en X, en Y y en Z.
155
     */
156
    public void setScaleFactor(Point3D scaleFactor) {
157
        this.scaleFactor = scaleFactor;
158
    }
159
    
160
    /**
161
     * Establece el ?ngulo de rotaci?n para el bloque.
162
     * @param rotAngle, ?ngulo de rotaci?n.
163
     */
164
    public void setRotAngle(double rotAngle) {
165
        this.rotAngle = rotAngle;
166
    }
167
    
168
    /**
169
     * M?todo para cargar el bloque al que hace referencia el punto de inserci?n, en el
170
     * propio punto InsPoint.
171
     * @param blockName, nombre del bloque que estamos buscando.
172
     * @return boolean, true si hemos encontrado el bloque que buscabamos y ha sido
173
     * cargado.
174
     */
175
    public boolean encuentraBloque(String blockName) {
176
        int i = 0;
177

    
178
        while ((i < blkList.size()) && (blockFound == false)) {
179
            //System.out.println("encuentraBloque: ((DxfBlock)blkList.get(i)).getBlkName() = " + ((FeatureCollection)blkList.get(i)).getProp("blockName"));
180
            //System.out.println("encuentraBloque: blockName = " + blockName);
181
            if (((FeatureCollection) blkList.get(i)).getProp("blockName")
182
                     .equals(blockName)) {
183
                //System.out.println("encuentraBloque: Bloque " + i + " encontrado.");
184
                block = (FeatureCollection) blkList.get(i);
185
                blockFound = true;
186
            } else {
187
                //System.out.println("encuentraBloque: Bloque " + blockName + " no encontrado");
188
                blockFound = false;
189
            }
190

    
191
            i++;
192
        }
193

    
194
        return blockFound;
195
    }
196
    
197
    /**
198
     * Devuelve el color del punto de inserci?n.
199
     * @return Color
200
     */
201
    public Color c() {
202
        return color;
203
    }
204
    
205
    /**
206
     * Establece el color del punto de inserci?n.
207
     * @param color
208
     * @return Color
209
     */
210
    public Color c(Color color) {
211
        this.color = color;
212

    
213
        return color;
214
    }
215
    
216
    /**
217
     * Devuelve el color del relleno.
218
     * @return Color
219
     */
220
    public Color fillColor() {
221
        return fColor;
222
    }
223
    
224
    /**
225
     * Establece el color de relleno.
226
     * @param c, color.
227
     * @return Color
228
     */
229
    public Color fillColor(Color c) {
230
        fColor = c;
231

    
232
        return fColor;
233
    }
234
    
235
    /**
236
     * Devuelve la proyecci?n cartogr?fica en la que se encuentra el InsPoint.
237
     * @return IProjection, proyecci?n cartogr?fica.
238
     */
239
    public IProjection getProjection() {
240
        return proj;
241
    }
242
    
243
    /**
244
     * Establece la proyecci?n cartogr?fica en la que se encuentra el InsPoint.
245
     * @param p, proyecci?n cartogr?fica.
246
     */
247
    public void setProjection(IProjection p) {
248
        proj = p;
249
    }
250
    
251
    /**
252
     * Permite cambiar la proyecci?n cartogr?fica del InsPoint a trav?s de unas
253
     * coordenadas de transformaci?n.
254
     * @param rp, coordenadas de transformaci?n.
255
     */
256
    public void reProject(ICoordTrans rp) {
257
        // TODO metodo reProject pendiente de implementar
258
    }
259
    
260
    /**
261
     * Permite dibujar el InsPoint.
262
     */
263
    public void draw(Graphics2D g, ViewPortData vp) {
264
        g.setColor(c());
265

    
266
        Point2D pt = new Point2D.Double(0D, 0D);
267
        vp.mat.transform((Point2D) data.get(0), pt);
268
        g.draw(new Line2D.Double(pt, pt));
269

    
270
        if (text != null) {
271
            g.drawString(text, (int) pt.getX(), (int) pt.getY());
272
        }
273
    }
274
}