Statistics
| Revision:

svn-gvsig-desktop / trunk / libraries / libGPE-KML / src / org / gvsig / gpe / kml / reader / bindings / geometries / CoordinatesTypeBinding.java @ 11573

History | View | Annotate | Download (4.19 KB)

1
package org.gvsig.gpe.kml.reader.bindings.geometries;
2

    
3
import java.io.IOException;
4

    
5
import org.gvsig.gpe.kml.GPEKmlParser;
6
import org.gvsig.gpe.kml.KmlTags;
7
import org.gvsig.gpe.kml.exceptions.KmlBodyParseException;
8
import org.kxml2.io.KXmlParser;
9
import org.xmlpull.v1.XmlPullParser;
10
import org.xmlpull.v1.XmlPullParserException;
11

    
12
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana
13
 *
14
 * Copyright (C) 2004 IVER T.I. and Generalitat Valenciana.
15
 *
16
 * This program is free software; you can redistribute it and/or
17
 * modify it under the terms of the GNU General Public License
18
 * as published by the Free Software Foundation; either version 2
19
 * of the License, or (at your option) any later version.
20
 *
21
 * This program is distributed in the hope that it will be useful,
22
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
23
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
24
 * GNU General Public License for more details.
25
 *
26
 * You should have received a copy of the GNU General Public License
27
 * along with this program; if not, write to the Free Software
28
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,USA.
29
 *
30
 * For more information, contact:
31
 *
32
 *  Generalitat Valenciana
33
 *   Conselleria d'Infraestructures i Transport
34
 *   Av. Blasco Ib??ez, 50
35
 *   46010 VALENCIA
36
 *   SPAIN
37
 *
38
 *      +34 963862235
39
 *   gvsig@gva.es
40
 *      www.gvsig.gva.es
41
 *
42
 *    or
43
 *
44
 *   IVER T.I. S.A
45
 *   Salamanca 50
46
 *   46005 Valencia
47
 *   Spain
48
 *
49
 *   +34 963163400
50
 *   dac@iver.es
51
 */
52
/* CVS MESSAGES:
53
 *
54
 * $Id: CoordinatesTypeBinding.java 11573 2007-05-11 07:06:29Z jorpiell $
55
 * $Log$
56
 * Revision 1.1  2007-05-11 07:06:29  jorpiell
57
 * Refactoring of some package names
58
 *
59
 * Revision 1.4  2007/05/09 08:36:24  jorpiell
60
 * Add the bbox to the layer
61
 *
62
 * Revision 1.3  2007/05/08 08:22:37  jorpiell
63
 * Add comments to create javadocs
64
 *
65
 * Revision 1.2  2007/04/14 16:08:07  jorpiell
66
 * Kml writing support added
67
 *
68
 * Revision 1.1  2007/04/13 13:16:21  jorpiell
69
 * Add KML reading support
70
 *
71
 * Revision 1.1  2007/03/07 08:19:10  jorpiell
72
 * Pasadas las clases de KML de libGPE-GML a libGPE-KML
73
 *
74
 * Revision 1.1  2007/02/28 11:48:31  csanchez
75
 * *** empty log message ***
76
 *
77
 * Revision 1.1  2007/02/20 10:53:20  jorpiell
78
 * A?adidos los proyectos de kml y gml antiguos
79
 *
80
 * Revision 1.1  2007/02/12 13:49:18  jorpiell
81
 * A?adido el driver de KML
82
 *
83
 *
84
 */
85
/**
86
 * This class parses a coordinates tag. Example:
87
 * <p>
88
 * <pre>
89
 * <code>
90
 * &lt;coordinates&gt;60.0,60.0 60.0,90.0 90.0,90.0&lt;/coordinates&gt;
91
 * </code>
92
 * </pre>
93
 * </p> 
94
 * @author Jorge Piera LLodr? (jorge.piera@iver.es)
95
 * @see http://code.google.com/apis/kml/documentation/kml_tags_21.html#coordinates
96
 */
97
public class CoordinatesTypeBinding {
98

    
99
        /**
100
         * It parses the coordinates tag
101
         * @param parser
102
         * The XML parser
103
         * @param handler
104
         * The GPE parser that contains the content handler and
105
         * the error handler
106
         * @return
107
         * It retuns a matrix of doubles with 3 columns (x,y,z) and
108
         * one row for each coordinate.
109
         * @throws IOException 
110
         * @throws XmlPullParserException 
111
         */
112
        public static double[][] parse(XmlPullParser parser,GPEKmlParser handler) throws XmlPullParserException, IOException  {
113
                boolean endFeature = false;
114
                int currentTag;
115

    
116
                double[][] aCoordinates = null;
117

    
118

    
119
                String tag = parser.getName();
120
                currentTag = parser.getEventType();
121

    
122
                while (!endFeature){
123
                        switch(currentTag){
124
                        case KXmlParser.START_TAG:
125
                                if (tag.compareTo(KmlTags.COORDINATES) == 0){
126
                                        parser.next();
127
                                        String[] coordinates = parser.getText().split(KmlTags.TUPLES_SEPARATOR);
128
                                        aCoordinates = new double[3][coordinates.length];
129
                                        for (int i=0 ; i<coordinates.length ; i++){                                        
130
                                                String[] coordinate = coordinates[i].trim().split(KmlTags.COORDINATES_SEPARATOR);
131
                                                aCoordinates[0][i] = DoubleBinding.parse(coordinate[0]);
132
                                                aCoordinates[1][i] = DoubleBinding.parse(coordinate[1]);
133
                                                aCoordinates[2][i] = DoubleBinding.parse(coordinate[2]);
134
                                        }                                        
135
                                }
136
                                break;
137
                        case KXmlParser.END_TAG:
138
                                if (tag.compareTo(KmlTags.COORDINATES) == 0){                                                
139
                                        endFeature = true;
140
                                }
141
                                break;
142
                        case KXmlParser.TEXT:                                        
143

    
144
                                break;
145
                        }
146
                        if (!endFeature){                                        
147
                                currentTag = parser.next();
148
                                tag = parser.getName();
149
                        }
150
                }                        
151

    
152
                return aCoordinates;        
153
        }
154

    
155
}