Statistics
| Revision:

root / branches / v1_9_0 / libGPE-GML / src / org / gvsig / gpe / gml / parser / v2 / geometries / GeometryMemberTypeBinding.java @ 53

History | View | Annotate | Download (3.77 KB)

1
package org.gvsig.gpe.gml.parser.v2.geometries;
2

    
3
import java.io.IOException;
4

    
5
import javax.xml.namespace.QName;
6

    
7
import org.gvsig.gpe.gml.parser.GPEDefaultGmlParser;
8
import org.gvsig.gpe.gml.utils.GMLTags;
9
import org.gvsig.gpe.xml.stream.EventType;
10
import org.gvsig.gpe.xml.stream.IXmlStreamReader;
11
import org.gvsig.gpe.xml.stream.XmlStreamException;
12
import org.gvsig.gpe.xml.utils.CompareUtils;
13

    
14
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana
15
 *
16
 * Copyright (C) 2004 IVER T.I. and Generalitat Valenciana.
17
 *
18
 * This program is free software; you can redistribute it and/or
19
 * modify it under the terms of the GNU General Public License
20
 * as published by the Free Software Foundation; either version 2
21
 * of the License, or (at your option) any later version.
22
 *
23
 * This program is distributed in the hope that it will be useful,
24
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
25
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
26
 * GNU General Public License for more details.
27
 *
28
 * You should have received a copy of the GNU General Public License
29
 * along with this program; if not, write to the Free Software
30
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,USA.
31
 *
32
 * For more information, contact:
33
 *
34
 *  Generalitat Valenciana
35
 *   Conselleria d'Infraestructures i Transport
36
 *   Av. Blasco Ib??ez, 50
37
 *   46010 VALENCIA
38
 *   SPAIN
39
 *
40
 *      +34 963862235
41
 *   gvsig@gva.es
42
 *      www.gvsig.gva.es
43
 *
44
 *    or
45
 *
46
 *   IVER T.I. S.A
47
 *   Salamanca 50
48
 *   46005 Valencia
49
 *   Spain
50
 *
51
 *   +34 963163400
52
 *   dac@iver.es
53
 */
54
/* CVS MESSAGES:
55
 *
56
 * $Id:GeometryMemberTypeBinding.java 371 2008-01-10 09:30:19Z jpiera $
57
 * $Log$
58
 * Revision 1.2  2007/05/14 09:31:06  jorpiell
59
 * Add the a new class to compare tags
60
 *
61
 * Revision 1.1  2007/05/07 12:58:42  jorpiell
62
 * Add some methods to manage the multigeometries
63
 *
64
 *
65
 */
66
/**
67
 * It parses a gml:geometryMemberType object. Example:
68
 * <p>
69
 * <pre>
70
 * <code>
71
 * &lt;geometryMember&gt;
72
 * &lt;Point gid="P6776"&gt;
73
 * &lt;coord&gt;&lt;X&gt;50.0&lt;/X&gt;&lt;Y&gt;50.0&lt;/Y&gt;&lt;/coord&gt;
74
 * &lt;/Point&gt;
75
 * &lt;/geometryMember&gt;
76
 * </code>
77
 * </pre>
78
 * </p> 
79
 * @author Jorge Piera LLodr? (jorge.piera@iver.es)
80
 */
81

    
82

    
83
public class GeometryMemberTypeBinding {
84
        
85
        /**
86
         * It parses the gml:GeometryMember tag
87
         * @param parser
88
         * The XML parser
89
         * @param handler
90
         * The GPE parser that contains the content handler and
91
         * the error handler
92
         * @return
93
         * A Geometry
94
         * @throws XmlStreamException
95
         * @throws IOException
96
         */
97
        public Object parse(IXmlStreamReader parser,GPEDefaultGmlParser handler) throws XmlStreamException, IOException {
98

    
99
        parser.require(EventType.START_ELEMENT, GMLTags.GML_GEOMETRYMEMBER);
100
        
101
                boolean endFeature = false;
102
                EventType currentTag;
103
                Object geometry = null;                
104
                
105
                QName tag = parser.getElementName();
106
                currentTag = parser.getEventType();
107

    
108
                while (!endFeature){
109
                        switch(currentTag.getCode()){
110
                        case EventType.START_ELEMENT_CODE:
111
                                        if (CompareUtils.compareWithNamespace(tag,GMLTags.GML_POINT)){
112
                                                geometry = handler.getProfile().getPointTypeBinding().
113
                                                parse(parser, handler);
114
                                        }else if (CompareUtils.compareWithNamespace(tag,GMLTags.GML_LINESTRING)){
115
                                                geometry = handler.getProfile().getLineStringTypeBinding().
116
                                                parse(parser, handler);
117
                                        }if (CompareUtils.compareWithNamespace(tag,GMLTags.GML_POLYGON)){
118
                                                geometry = handler.getProfile().getPolygonTypeBinding().
119
                                                parse(parser, handler);
120
                                        }
121
                                        break;
122
                                case EventType.END_ELEMENT_CODE:
123
                                        if (CompareUtils.compareWithNamespace(tag,GMLTags.GML_GEOMETRYMEMBER)){                                                
124
                                                endFeature = true;                                                
125
                                        }
126
                                        break;
127
                                }
128
                                if (!endFeature){                                        
129
                                        currentTag = parser.nextTag();
130
                                        tag = parser.getElementName();
131
                                }
132
                        }                        
133
                return geometry;        
134
        }
135
}