Statistics
| Revision:

gvsig-gazetteer / org.gvsig.gazetteer / trunk / org.gvsig.gazetteer / org.gvsig.gazetteer.lib / src / main / java / org / gvsig / gazetteer / idec / parsers / IdecFeatureParser.java @ 103

History | View | Annotate | Download (3.52 KB)

1

    
2
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana
3
*
4
* Copyright (C) 2004 IVER T.I. and Generalitat Valenciana.
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
*  Generalitat Valenciana
23
*   Conselleria d'Infraestructures i Transport
24
*   Av. Blasco Ib??ez, 50
25
*   46010 VALENCIA
26
*   SPAIN
27
*
28
*      +34 963862235
29
*   gvsig@gva.es
30
*      www.gvsig.gva.es
31
*
32
*    or
33
*
34
*   IVER T.I. S.A
35
*   Salamanca 50
36
*   46005 Valencia
37
*   Spain
38
*
39
*   +34 963163400
40
*   dac@iver.es
41
*/
42
package org.gvsig.gazetteer.idec.parsers;
43
import java.awt.geom.Point2D;
44

    
45
import org.gvsig.catalog.metadataxml.XMLNode;
46
import org.gvsig.catalog.metadataxml.XMLTree;
47
import org.gvsig.fmap.geom.GeometryLocator;
48
import org.gvsig.fmap.geom.GeometryManager;
49
import org.gvsig.fmap.geom.Geometry.SUBTYPES;
50
import org.gvsig.fmap.geom.exception.CreateGeometryException;
51
import org.gvsig.fmap.geom.primitive.Point;
52
import org.gvsig.gazetteer.adl.parsers.AdlFeatureParser;
53
import org.gvsig.gazetteer.querys.Feature;
54
import org.slf4j.Logger;
55
import org.slf4j.LoggerFactory;
56

    
57

    
58
/**
59
 *
60
 *
61
 *
62
 * @author Jorge Piera Llodra (piera_jor@gva.es)
63
 */
64
public class IdecFeatureParser {
65
    private static final Logger logger =
66
        LoggerFactory.getLogger(IdecFeatureParser.class);
67
/**
68
 * @return
69
 * @param node
70
 */
71
    public static Feature[] parse(XMLNode node) {
72
        GeometryManager geomManager = GeometryLocator.getGeometryManager();
73

    
74
        XMLNode[] nodeFeatures = XMLTree.searchMultipleNode(node,"SOAP-ENV:Body->ns1:getCoordenadesUTMResponse->return->item");
75
        Feature[] features = new Feature[nodeFeatures.length];
76

    
77
        //New Version
78
        if (features.length == 0){
79
                nodeFeatures = XMLTree.searchMultipleNode(node,"soapenv:Body->multiRef");
80
                features = new Feature[nodeFeatures.length];
81
        }
82

    
83
        for (int i=0 ; i<nodeFeatures.length ; i++){
84
            String id = XMLTree.searchNodeValue(nodeFeatures[i],"NOM");
85
            String name = id;
86
            String description = id;
87
            Point point = null;
88
            double x = Double.parseDouble(XMLTree.searchNodeValue(nodeFeatures[i],"X"));
89
            double y = Double.parseDouble(XMLTree.searchNodeValue(nodeFeatures[i],"Y"));
90
            try {
91
                point = geomManager.createPoint(x, y, SUBTYPES.GEOM2D);
92
            } catch (CreateGeometryException | NumberFormatException e) {
93
                StringBuilder builder = new StringBuilder();
94
                builder.append("Can't create point: (");
95
                builder.append(x);
96
                builder.append(",");
97
                builder.append(y);
98
                builder.append(")");
99
                logger.warn(builder.toString());
100
            }
101
            features[i] = new Feature(id,name,description,point);
102
        }
103

    
104

    
105
    return features;
106
    }
107
 }