Revision 856

View differences:

org.gvsig.gpe/library/tags/org.gvsig.gpe-2.1.75/org.gvsig.gpe.app/pom.xml
1
<?xml version="1.0" encoding="ISO-8859-1"?>
2

  
3
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
4
  <modelVersion>4.0.0</modelVersion>
5
  <artifactId>org.gvsig.gpe.app</artifactId>
6
  <description>Adds support for some vector formats (GML, KML)</description>
7
  <packaging>pom</packaging>
8
  
9
  
10
  <parent>
11
      <groupId>org.gvsig</groupId>
12
      <artifactId>org.gvsig.gpe</artifactId>
13
      <version>2.1.75</version>
14
  </parent>
15
    
16
  <modules>
17
    <module>org.gvsig.gpe.app.mainplugin</module>
18
  </modules>
19
</project>
org.gvsig.gpe/library/tags/org.gvsig.gpe-2.1.75/org.gvsig.gpe.app/org.gvsig.gpe.app.mainplugin/buildNumber.properties
1
#Sat Oct 06 11:56:04 CEST 2018
2
buildNumber=2177
org.gvsig.gpe/library/tags/org.gvsig.gpe-2.1.75/org.gvsig.gpe.app/org.gvsig.gpe.app.mainplugin/src/main/assembly/gvsig-plugin-package.xml
1
<!--
2

  
3
    gvSIG. Desktop Geographic Information System.
4

  
5
    Copyright (C) 2007-2013 gvSIG Association.
6

  
7
    This program is free software; you can redistribute it and/or
8
    modify it under the terms of the GNU General Public License
9
    as published by the Free Software Foundation; either version 3
10
    of the License, or (at your option) any later version.
11

  
12
    This program is distributed in the hope that it will be useful,
13
    but WITHOUT ANY WARRANTY; without even the implied warranty of
14
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15
    GNU General Public License for more details.
16

  
17
    You should have received a copy of the GNU General Public License
18
    along with this program; if not, write to the Free Software
19
    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
20
    MA  02110-1301, USA.
21

  
22
    For any additional information, do not hesitate to contact us
23
    at info AT gvsig.com, or visit our website www.gvsig.com.
24

  
25
-->
26
<assembly>
27
  <id>gvsig-plugin-package</id>
28
  <formats>
29
    <format>zip</format>
30
  </formats>
31
  <baseDirectory>${project.artifactId}</baseDirectory>
32
  <includeBaseDirectory>true</includeBaseDirectory>
33
  <files>
34
    <file>
35
      <source>target/${project.artifactId}-${project.version}.jar</source>
36
      <outputDirectory>lib</outputDirectory>
37
    </file>
38
    <file>
39
      <source>target/package.info</source>
40
    </file>
41
  </files>
42

  
43
  <fileSets>
44
    <fileSet>
45
      <directory>src/main/resources-plugin</directory>
46
      <outputDirectory>.</outputDirectory>
47
    </fileSet>
48
  </fileSets>
49

  
50
  <dependencySets>
51
    <dependencySet>
52
      <useProjectArtifact>false</useProjectArtifact>
53
      <useTransitiveDependencies>false</useTransitiveDependencies>
54
      <outputDirectory>lib</outputDirectory>
55
      <includes>
56
    	<include>org.gvsig:org.gvsig.gpe.lib*</include>
57
        <include>org.gvsig:org.gvsig.gpe.prov*</include>
58
        <include>org.gvsig:org.gvsig.xmlpull*</include>
59
        <include>org.gvsig:org.gvsig.gpe.exportto*</include>
60
        <include>org.gvsig:org.gvsig.xmlschema*</include>
61
        <include>stax:stax</include>
62
      </includes>
63
    </dependencySet>
64
  </dependencySets>
65

  
66
</assembly>
67

  
org.gvsig.gpe/library/tags/org.gvsig.gpe-2.1.75/org.gvsig.gpe.app/org.gvsig.gpe.app.mainplugin/src/main/java/org/gvsig/fmap/geom/operation/writegml2/MultiCurveWriteGml2Operation.java
1
/* gvSIG. Geographic Information System of the Valencian Government
2
 *
3
 * Copyright (C) 2007-2008 Infrastructures and Transports Department
4
 * of the Valencian Government (CIT)
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., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 */
22
package org.gvsig.fmap.geom.operation.writegml2;
23

  
24
import org.gvsig.fmap.geom.Geometry;
25
import org.gvsig.fmap.geom.aggregate.MultiCurve;
26
import org.gvsig.fmap.geom.operation.GeometryOperationContext;
27
import org.gvsig.fmap.geom.operation.GeometryOperationException;
28

  
29

  
30
/**
31
 * @author gvSIG Team
32
 * @version $Id$
33
 *
34
 */
35
public class MultiCurveWriteGml2Operation extends WriteGml2Operation{
36
	
37
	public Object invoke(Geometry geom, GeometryOperationContext ctx) throws GeometryOperationException {
38
	    initializeParams(ctx);
39
        MultiCurve multiCurve = (MultiCurve)geom;
40
        
41
        writerHandler.startMultiLineString(id, srs);
42
        for (int i=0 ; i<multiCurve.getPrimitivesNumber() ; i++){
43
            writerHandler.startLineString(null, new OrientablePrimitiveCoordinateSequence(multiCurve.getCurveAt(i)), srs);
44
            writerHandler.endLineString();
45
        }        
46
        writerHandler.endMultiLineString();
47
        
48
        return null;
49
	}
50
}
org.gvsig.gpe/library/tags/org.gvsig.gpe-2.1.75/org.gvsig.gpe.app/org.gvsig.gpe.app.mainplugin/src/main/java/org/gvsig/fmap/geom/operation/writegml2/PointCoordinatesSequence.java
1
/* gvSIG. Geographic Information System of the Valencian Government
2
 *
3
 * Copyright (C) 2007-2008 Infrastructures and Transports Department
4
 * of the Valencian Government (CIT)
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., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 */
22
package org.gvsig.fmap.geom.operation.writegml2;
23

  
24
import java.io.IOException;
25

  
26
import org.gvsig.fmap.geom.primitive.Point;
27
import org.gvsig.gpe.lib.api.parser.ICoordinateIterator;
28
import org.gvsig.gpe.lib.api.writer.ICoordinateSequence;
29

  
30

  
31
/**
32
 * @author gvSIG Team
33
 * @version $Id$
34
 *
35
 */
36
public class PointCoordinatesSequence implements ICoordinateSequence, ICoordinateIterator {
37
    private Point point = null; 
38
    private boolean hasNext = true;
39
    
40
    public PointCoordinatesSequence(Point point) {
41
        super();
42
        this.point = point;
43
    }
44

  
45
    public int getSize() {       
46
        return 1;
47
    }
48

  
49
    public ICoordinateIterator iterator() {
50
        return this;
51
    }
52

  
53
    public boolean hasNext() throws IOException {
54
        if (hasNext){
55
            hasNext = false;
56
            return true;
57
        }
58
        return false;
59
    }
60

  
61
    public int getDimension() {
62
        return point.getDimension();
63
    }
64

  
65
    public void next(double[] buffer) throws IOException {
66
        for (int i=0 ; i<point.getDimension() ; i++){  
67
            buffer[i] = point.getCoordinateAt(i);   
68
        }          
69
    }
70
}
org.gvsig.gpe/library/tags/org.gvsig.gpe-2.1.75/org.gvsig.gpe.app/org.gvsig.gpe.app.mainplugin/src/main/java/org/gvsig/fmap/geom/operation/writegml2/WriteGml2Operation.java
1
/* gvSIG. Geographic Information System of the Valencian Government
2
 *
3
 * Copyright (C) 2007-2008 Infrastructures and Transports Department
4
 * of the Valencian Government (CIT)
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., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 */
22
package org.gvsig.fmap.geom.operation.writegml2;
23

  
24
import org.gvsig.fmap.geom.GeometryLocator;
25
import org.gvsig.fmap.geom.GeometryManager;
26
import org.gvsig.fmap.geom.operation.GeometryOperation;
27
import org.gvsig.fmap.geom.operation.GeometryOperationContext;
28
import org.gvsig.gpe.lib.api.writer.IGPEWriterHandler;
29

  
30

  
31
/**
32
 * @author gvSIG Team
33
 * @version $Id$
34
 *
35
 */
36
public abstract class WriteGml2Operation extends GeometryOperation {
37
    public static final String NAME = "writeGml2";
38
	protected static GeometryManager geomManager = GeometryLocator.getGeometryManager();
39
    public static final int CODE = geomManager.getGeometryOperationCode(NAME);	
40
	
41
    protected String id = null;
42
    protected IGPEWriterHandler writerHandler;
43
    protected String srs = null;
44
    
45
	public int getOperationIndex() {
46
		return CODE;
47
	}	
48
	
49
	protected void initializeParams(GeometryOperationContext geometryOperationContext){
50
	    writerHandler = (IGPEWriterHandler)geometryOperationContext.getAttribute(WriteGml2OperationContext.ATTRIBUTE_GPEWRITERHANDLER);
51
	    id = (String)geometryOperationContext.getAttribute(WriteGml2OperationContext.ATTRIBUTE_ID);
52
	    srs = (String)geometryOperationContext.getAttribute(WriteGml2OperationContext.ATTRIBUTE_SRS);
53
	}
54

  
55
}
org.gvsig.gpe/library/tags/org.gvsig.gpe-2.1.75/org.gvsig.gpe.app/org.gvsig.gpe.app.mainplugin/src/main/java/org/gvsig/fmap/geom/operation/writegml2/OrientablePrimitiveCoordinateSequence.java
1
/* gvSIG. Geographic Information System of the Valencian Government
2
 *
3
 * Copyright (C) 2007-2008 Infrastructures and Transports Department
4
 * of the Valencian Government (CIT)
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., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 */
22
package org.gvsig.fmap.geom.operation.writegml2;
23

  
24
import java.awt.geom.PathIterator;
25
import java.io.IOException;
26

  
27
import org.gvsig.fmap.geom.primitive.GeneralPathX;
28
import org.gvsig.fmap.geom.primitive.OrientablePrimitive;
29
import org.gvsig.gpe.lib.api.parser.ICoordinateIterator;
30
import org.gvsig.gpe.lib.api.writer.ICoordinateSequence;
31

  
32

  
33
/**
34
 * @author gvSIG Team
35
 * @version $Id$
36
 *
37
 */
38
public class OrientablePrimitiveCoordinateSequence  implements ICoordinateSequence, ICoordinateIterator {
39
    private OrientablePrimitive orientablePrimitive; 
40
    private GeneralPathX generalPathX;
41
    private PathIterator pathIterator;  
42
        
43
    public OrientablePrimitiveCoordinateSequence(
44
        OrientablePrimitive orientablePrimitive) {
45
        super();
46
        this.orientablePrimitive = orientablePrimitive;
47
        this.generalPathX = orientablePrimitive.getGeneralPath();
48
        this.pathIterator = generalPathX.getPathIterator(null);
49
    }
50

  
51
    public boolean hasNext() throws IOException {
52
       return !pathIterator.isDone();
53
    }
54

  
55
    public int getDimension() {
56
        return orientablePrimitive.getDimension();
57
    }
58

  
59
    public void next(double[] buffer) throws IOException {        
60
        pathIterator.currentSegment(buffer);  
61
        pathIterator.next();   
62
    }
63

  
64
    public int getSize() {       
65
        return orientablePrimitive.getNumVertices();
66
    }
67

  
68
    public ICoordinateIterator iterator() {       
69
        return this;
70
    }
71

  
72
}
org.gvsig.gpe/library/tags/org.gvsig.gpe-2.1.75/org.gvsig.gpe.app/org.gvsig.gpe.app.mainplugin/src/main/java/org/gvsig/fmap/geom/operation/writegml2/MultiSurfaceWriteGml2Operation.java
1
/* gvSIG. Geographic Information System of the Valencian Government
2
 *
3
 * Copyright (C) 2007-2008 Infrastructures and Transports Department
4
 * of the Valencian Government (CIT)
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., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 */
22
package org.gvsig.fmap.geom.operation.writegml2;
23

  
24
import org.gvsig.fmap.geom.Geometry;
25
import org.gvsig.fmap.geom.aggregate.MultiSurface;
26
import org.gvsig.fmap.geom.operation.GeometryOperationContext;
27
import org.gvsig.fmap.geom.operation.GeometryOperationException;
28

  
29

  
30
/**
31
 * @author gvSIG Team
32
 * @version $Id$
33
 *
34
 */
35
public class MultiSurfaceWriteGml2Operation extends WriteGml2Operation{
36
	
37
	public Object invoke(Geometry geom, GeometryOperationContext ctx) throws GeometryOperationException {
38
	    initializeParams(ctx);
39
        MultiSurface multiSurface = (MultiSurface)geom;
40
        
41
        writerHandler.startMultiPolygon(id, srs);
42
        for (int i=0 ; i<multiSurface.getPrimitivesNumber() ; i++){
43
            writerHandler.startPolygon(null, new OrientablePrimitiveCoordinateSequence(multiSurface.getSurfaceAt(i)), srs);
44
            writerHandler.endPolygon();
45
        }        
46
        writerHandler.endMultiPolygon();
47
        
48
        return null;
49
	}
50
}
org.gvsig.gpe/library/tags/org.gvsig.gpe-2.1.75/org.gvsig.gpe.app/org.gvsig.gpe.app.mainplugin/src/main/java/org/gvsig/fmap/geom/operation/writegml2/CurveWriteGml2Operation.java
1
/* gvSIG. Geographic Information System of the Valencian Government
2
 *
3
 * Copyright (C) 2007-2008 Infrastructures and Transports Department
4
 * of the Valencian Government (CIT)
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., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 */
22
package org.gvsig.fmap.geom.operation.writegml2;
23

  
24
import org.gvsig.fmap.geom.Geometry;
25
import org.gvsig.fmap.geom.operation.GeometryOperationContext;
26
import org.gvsig.fmap.geom.operation.GeometryOperationException;
27
import org.gvsig.fmap.geom.primitive.Curve;
28

  
29

  
30
/**
31
 * @author gvSIG Team
32
 * @version $Id$
33
 *
34
 */
35
public class CurveWriteGml2Operation extends WriteGml2Operation{
36
	
37
	public Object invoke(Geometry geom, GeometryOperationContext ctx) throws GeometryOperationException {
38
	    initializeParams(ctx);
39
        Curve curve = (Curve)geom;
40
        
41
        writerHandler.startLineString(id, new OrientablePrimitiveCoordinateSequence(curve), srs);
42
        writerHandler.endLineString();
43
        
44
        return null;
45
	}
46
}
org.gvsig.gpe/library/tags/org.gvsig.gpe-2.1.75/org.gvsig.gpe.app/org.gvsig.gpe.app.mainplugin/src/main/java/org/gvsig/fmap/geom/operation/writegml2/MultiPointWriteGml2Operation.java
1
/* gvSIG. Geographic Information System of the Valencian Government
2
 *
3
 * Copyright (C) 2007-2008 Infrastructures and Transports Department
4
 * of the Valencian Government (CIT)
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., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 */
22
package org.gvsig.fmap.geom.operation.writegml2;
23

  
24
import org.gvsig.fmap.geom.Geometry;
25
import org.gvsig.fmap.geom.aggregate.MultiPoint;
26
import org.gvsig.fmap.geom.operation.GeometryOperationContext;
27
import org.gvsig.fmap.geom.operation.GeometryOperationException;
28

  
29

  
30
/**
31
 * @author gvSIG Team
32
 * @version $Id$
33
 *
34
 */
35
public class MultiPointWriteGml2Operation extends WriteGml2Operation{
36
	
37
	public Object invoke(Geometry geom, GeometryOperationContext ctx) throws GeometryOperationException {
38
	    initializeParams(ctx);
39
        MultiPoint multiPoint = (MultiPoint)geom;
40
        
41
        writerHandler.startMultiPoint(id, srs);
42
        for (int i=0 ; i<multiPoint.getPrimitivesNumber() ; i++){
43
            writerHandler.startPoint(null, new PointCoordinatesSequence(multiPoint.getPointAt(i)), srs);
44
            writerHandler.endPoint();
45
        }        
46
        writerHandler.endMultiPoint();
47
        
48
        return null;
49
	}
50
}
org.gvsig.gpe/library/tags/org.gvsig.gpe-2.1.75/org.gvsig.gpe.app/org.gvsig.gpe.app.mainplugin/src/main/java/org/gvsig/fmap/geom/operation/writegml2/WriteGml2OperationContext.java
1
/* gvSIG. Geographic Information System of the Valencian Government
2
 *
3
 * Copyright (C) 2007-2008 Infrastructures and Transports Department
4
 * of the Valencian Government (CIT)
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., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 */
22
package org.gvsig.fmap.geom.operation.writegml2;
23

  
24
import org.gvsig.fmap.geom.operation.GeometryOperationContext;
25
import org.gvsig.gpe.lib.api.writer.IGPEWriterHandler;
26

  
27

  
28
/**
29
 * @author gvSIG Team
30
 * @version $Id$
31
 *
32
 */
33
public class WriteGml2OperationContext extends GeometryOperationContext {
34
	public static final String ATTRIBUTE_GPEWRITERHANDLER = "writerHandler";
35
	public static final String ATTRIBUTE_SRS = "srs";
36
    public static final String ATTRIBUTE_ID = "id";
37
    
38
    /**
39
     * @return the srs
40
     */
41
    public String getSrs() {
42
        return (String) super.getAttribute(ATTRIBUTE_SRS);
43
    }
44
    
45
    /**
46
     * @param srs the srs to set
47
     */
48
    public void setSrs(String srs) {
49
        this.setAttribute(ATTRIBUTE_SRS, srs);
50
    }   
51
    
52
    /**
53
     * @return the Id
54
     */
55
    public String getId() {
56
        return (String) super.getAttribute(ATTRIBUTE_ID);
57
    }
58
    
59
    /**
60
     * @param id the id to set
61
     */
62
    public void setId(String id) {
63
        this.setAttribute(ATTRIBUTE_ID, id);
64
    }   
65
    
66
    /**
67
     * @return the writerHandler
68
     */
69
    public IGPEWriterHandler getWriterHandler() {
70
        return (IGPEWriterHandler) super.getAttribute(ATTRIBUTE_GPEWRITERHANDLER);
71
    }
72
    
73
    /**
74
     * @param writerHandler the writerHandler to set
75
     */
76
    public void setWriterHandler(IGPEWriterHandler writerHandler) {
77
        this.setAttribute(ATTRIBUTE_GPEWRITERHANDLER, writerHandler);
78
    } 	
79
}
80

  
org.gvsig.gpe/library/tags/org.gvsig.gpe-2.1.75/org.gvsig.gpe.app/org.gvsig.gpe.app.mainplugin/src/main/java/org/gvsig/fmap/geom/operation/writegml2/SurfaceWriteGml2Operation.java
1
/* gvSIG. Geographic Information System of the Valencian Government
2
 *
3
 * Copyright (C) 2007-2008 Infrastructures and Transports Department
4
 * of the Valencian Government (CIT)
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., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 */
22
package org.gvsig.fmap.geom.operation.writegml2;
23

  
24
import org.gvsig.fmap.geom.Geometry;
25
import org.gvsig.fmap.geom.operation.GeometryOperationContext;
26
import org.gvsig.fmap.geom.operation.GeometryOperationException;
27
import org.gvsig.fmap.geom.primitive.Surface;
28

  
29

  
30
/**
31
 * @author gvSIG Team
32
 * @version $Id$
33
 *
34
 */
35
public class SurfaceWriteGml2Operation extends WriteGml2Operation{
36
	
37
	public Object invoke(Geometry geom, GeometryOperationContext ctx) throws GeometryOperationException {
38
	    initializeParams(ctx);
39
        Surface surface = (Surface)geom;
40
        
41
        writerHandler.startPolygon(id, new OrientablePrimitiveCoordinateSequence(surface), srs);
42
        writerHandler.endPolygon();
43
        
44
        return null;
45
	}
46
}
org.gvsig.gpe/library/tags/org.gvsig.gpe-2.1.75/org.gvsig.gpe.app/org.gvsig.gpe.app.mainplugin/src/main/java/org/gvsig/fmap/geom/operation/writegml2/PointWriteGml2Operation.java
1
/* gvSIG. Geographic Information System of the Valencian Government
2
 *
3
 * Copyright (C) 2007-2008 Infrastructures and Transports Department
4
 * of the Valencian Government (CIT)
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., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 */
22
package org.gvsig.fmap.geom.operation.writegml2;
23

  
24
import org.gvsig.fmap.geom.Geometry;
25
import org.gvsig.fmap.geom.operation.GeometryOperationContext;
26
import org.gvsig.fmap.geom.operation.GeometryOperationException;
27
import org.gvsig.fmap.geom.primitive.Point;
28

  
29

  
30
/**
31
 * @author gvSIG Team
32
 * @version $Id$
33
 *
34
 */
35
public class PointWriteGml2Operation extends WriteGml2Operation{
36
	
37
	public Object invoke(Geometry geom, GeometryOperationContext ctx) throws GeometryOperationException {
38
	    initializeParams(ctx);
39
		Point point = (Point)geom;
40
				
41
		writerHandler.startPoint(id, new PointCoordinatesSequence(point), srs);
42
		writerHandler.endPoint();
43
		
44
		return null;
45
	}
46
}
org.gvsig.gpe/library/tags/org.gvsig.gpe-2.1.75/org.gvsig.gpe.app/org.gvsig.gpe.app.mainplugin/src/main/java/org/gvsig/fmap/dal/store/gpe/GPEStoreParameters.java
1
/* gvSIG. Geographic Information System of the Valencian Government
2
 *
3
 * Copyright (C) 2007-2008 Infrastructures and Transports Department
4
 * of the Valencian Government (CIT)
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., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 */
22

  
23
/*
24
 * AUTHORS (In addition to CIT):
25
 * 2009 {Iver T.I.}   {Task}
26
 */
27

  
28
package org.gvsig.fmap.dal.store.gpe;
29

  
30
import java.io.File;
31
import org.apache.commons.lang3.BooleanUtils;
32

  
33
import org.cresques.cts.IProjection;
34
import org.gvsig.fmap.crs.CRSFactory;
35
import org.gvsig.fmap.dal.DataStore;
36
import org.gvsig.fmap.dal.DataStoreParameters;
37
import org.gvsig.fmap.dal.FileHelper;
38
import org.gvsig.fmap.dal.feature.EditableFeatureType;
39
import org.gvsig.fmap.dal.feature.FeatureType;
40
import org.gvsig.fmap.dal.feature.NewFeatureStoreParameters;
41
import org.gvsig.fmap.dal.feature.OpenFeatureStoreParameters;
42
import org.gvsig.fmap.dal.serverexplorer.filesystem.FilesystemStoreParameters;
43
import org.gvsig.fmap.dal.spi.AbstractDataParameters;
44
import org.gvsig.fmap.dal.spi.DataStoreProviderServices;
45
import org.gvsig.fmap.geom.primitive.Envelope;
46
import org.gvsig.gpe.lib.api.GPELocator;
47
import org.gvsig.gpe.lib.api.GPEManager;
48
import org.gvsig.gpe.lib.api.exceptions.ParserCreationException;
49
import org.gvsig.tools.ToolsLocator;
50
import org.gvsig.tools.dataTypes.CoercionException;
51
import org.gvsig.tools.dataTypes.DataTypesManager;
52
import org.gvsig.tools.dataTypes.impl.DefaultDataTypesManager;
53
import org.gvsig.tools.dynobject.DelegatedDynObject;
54
import org.gvsig.tools.dynobject.DynStruct;
55
import org.gvsig.tools.dynobject.exception.DynFieldNotFoundException;
56
import org.gvsig.tools.locator.LocatorException;
57
import org.slf4j.Logger;
58
import org.slf4j.LoggerFactory;
59

  
60
/**
61
 * @author <a href="mailto:jpiera@gvsig.org">Jorge Piera</a>
62
 */
63
public class GPEStoreParameters extends AbstractDataParameters implements
64
OpenFeatureStoreParameters, FilesystemStoreParameters,
65
NewFeatureStoreParameters {
66

  
67
    public static final String PARAMETERS_DEFINITION_NAME = "GPEStoreParameters";
68

  
69
    private static final String FILE_PARAMETER_NAME = "File";
70
    private static final String CRS_PARAMETER_NAME = "CRS";
71
    private static final String ENVELOPE_PARAMETER_NAME = "Envelope";
72
    private static final String FEATURETYPE_PARAMETER_NAME = "FeatureType";
73

  
74
    private DelegatedDynObject parameters;
75

  
76
    private static Logger logger = LoggerFactory.getLogger(GPEStoreParameters.class);
77

  
78
    public GPEStoreParameters() {
79
        this(PARAMETERS_DEFINITION_NAME);
80
    }
81

  
82
    protected GPEStoreParameters(String parametersDefinitionName) {
83
        this(parametersDefinitionName, GPEStoreProvider.NAME);
84
    }
85

  
86
    public GPEStoreParameters(String parametersDefinitionName, String name) {
87
        super();
88
        this.parameters = (DelegatedDynObject) FileHelper.newParameters(parametersDefinitionName);
89
        this.setDynValue(DataStoreProviderServices.PROVIDER_PARAMTER_NAME, name);
90
    }
91

  
92
    protected static void registerParametersDefinition(){
93
        DynStruct dynStruct = FileHelper.registerParametersDefinition(
94
            GPEStoreParameters.PARAMETERS_DEFINITION_NAME,
95
            GPEStoreParameters.class, "GPEParameters.xml");
96

  
97
        dynStruct.addDynFieldObject(ENVELOPE_PARAMETER_NAME).
98
        setClassOfValue(Envelope.class).setMandatory(false);
99

  
100
        dynStruct.addDynFieldObject(FEATURETYPE_PARAMETER_NAME).
101
        setClassOfValue(FeatureType.class).setMandatory(false);
102
    }
103

  
104
    protected DelegatedDynObject getDelegatedDynObject() {
105
        return parameters;
106
    }
107

  
108
    public String getDataStoreName() {
109
        return GPEStoreProvider.NAME;
110
    }
111

  
112
    public String getDescription() {
113
        return GPEStoreProvider.DESCRIPTION;
114
    }
115

  
116
    public boolean isValid() {
117
        return (this.getFile() != null);
118
    }
119

  
120
    public File getFile() {
121
        return (File) this.getDynValue(FILE_PARAMETER_NAME);
122
    }
123

  
124
    public void setFile(File file) {
125
        this.setDynValue(FILE_PARAMETER_NAME, file);
126
    }
127

  
128
    public String getFileName() {
129
        return this.getFile().getAbsolutePath();
130
    }
131

  
132
    public void setFileName(String fileName) {
133
        this.setDynValue(FILE_PARAMETER_NAME, fileName);
134
    }
135

  
136
    public IProjection getCRS() {
137
        return (IProjection) this.getDynValue(CRS_PARAMETER_NAME);
138
    }
139

  
140
    public void setCRS(IProjection srs) {
141
        this.setDynValue(CRS_PARAMETER_NAME, srs);
142
    }
143

  
144
    public void setCRS(String srs) {
145
        this.setDynValue(CRS_PARAMETER_NAME, srs);
146
    }
147

  
148
    public Envelope getEnvelope() {
149
        return (Envelope) this.getDynValue(ENVELOPE_PARAMETER_NAME);
150
    }
151

  
152
    public void setEnvelope(Envelope envelope) {
153
        this.setDynValue(ENVELOPE_PARAMETER_NAME, envelope);
154
    }
155

  
156
    public void setDynValue(String name, Object val) {
157
    	super.setDynValue(name, val);
158
    }
159

  
160
    public boolean getUseAxisOrderYX()  {
161
        boolean x = BooleanUtils.isTrue((Boolean) this.getDynValue("useAxisOrderYX"));
162
        return x;
163
    }
164

  
165
	public EditableFeatureType getDefaultFeatureType() {
166
		return (EditableFeatureType) this.getDynValue(FEATURETYPE_PARAMETER_NAME);
167
	}
168

  
169
	public void setDefaultFeatureType(FeatureType featureType) {
170
		this.setDynValue(FEATURETYPE_PARAMETER_NAME, featureType);
171
	}
172

  
173
    public Object getDynValue(String name) throws DynFieldNotFoundException {
174
        if (DataStore.METADATA_CRS.equalsIgnoreCase(name)) {
175
            try {
176
                GPEManager gpeManager=GPELocator.getGPEManager();
177
                String crs=gpeManager.getDefaultProjection(getFile());
178
                DataTypesManager dataTypesManager=ToolsLocator.getDataTypesManager();
179
                IProjection projection=(IProjection) dataTypesManager.coerce(org.cresques.DataTypes.CRS, crs);
180
                if (projection!=null){
181
                    setCRS(projection);
182
                }
183
            } catch (LocatorException  | ParserCreationException | CoercionException e) {
184
                logger.warn("Couldn't get default projection",e);
185
            }
186
        }
187
        return super.getDynValue(name);
188
    }
189
}
org.gvsig.gpe/library/tags/org.gvsig.gpe-2.1.75/org.gvsig.gpe.app/org.gvsig.gpe.app.mainplugin/src/main/java/org/gvsig/fmap/dal/store/gpe/handlers/FmapErrorHandler.java
1
package org.gvsig.fmap.dal.store.gpe.handlers;
2

  
3
import org.gvsig.gpe.lib.impl.parser.GPEErrorHandler;
4

  
5
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana
6
 *
7
 * Copyright (C) 2004 IVER T.I. and Generalitat Valenciana.
8
 *
9
 * This program is free software; you can redistribute it and/or
10
 * modify it under the terms of the GNU General Public License
11
 * as published by the Free Software Foundation; either version 2
12
 * of the License, or (at your option) any later version.
13
 *
14
 * This program is distributed in the hope that it will be useful,
15
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
 * GNU General Public License for more details.
18
 *
19
 * You should have received a copy of the GNU General Public License
20
 * along with this program; if not, write to the Free Software
21
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,USA.
22
 *
23
 * For more information, contact:
24
 *
25
 *  Generalitat Valenciana
26
 *   Conselleria d'Infraestructures i Transport
27
 *   Av. Blasco Ib??ez, 50
28
 *   46010 VALENCIA
29
 *   SPAIN
30
 *
31
 *      +34 963862235
32
 *   gvsig@gva.es
33
 *      www.gvsig.gva.es
34
 *
35
 *    or
36
 *
37
 *   IVER T.I. S.A
38
 *   Salamanca 50
39
 *   46005 Valencia
40
 *   Spain
41
 *
42
 *   +34 963163400
43
 *   dac@iver.es
44
 */
45
/* CVS MESSAGES:
46
 *
47
 * $Id$
48
 * $Log$
49
 *
50
 */
51
/**
52
 * @author Jorge Piera LLodr? (jorge.piera@iver.es)
53
 */
54
public class FmapErrorHandler extends GPEErrorHandler{
55

  
56
}
org.gvsig.gpe/library/tags/org.gvsig.gpe-2.1.75/org.gvsig.gpe.app/org.gvsig.gpe.app.mainplugin/src/main/java/org/gvsig/fmap/dal/store/gpe/handlers/FmapContentHandler.java
1
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana
2
 *
3
 * Copyright (C) 2004 IVER T.I. and Generalitat Valenciana.
4
 *
5
 * This program is free software; you can redistribute it and/or
6
 * modify it under the terms of the GNU General Public License
7
 * as published by the Free Software Foundation; either version 2
8
 * of the License, or (at your option) any later version.
9
 *
10
 * This program is distributed in the hope that it will be useful,
11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 * GNU General Public License for more details.
14
 *
15
 * You should have received a copy of the GNU General Public License
16
 * along with this program; if not, write to the Free Software
17
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,USA.
18
 */
19

  
20
package org.gvsig.fmap.dal.store.gpe.handlers;
21

  
22
import java.io.File;
23
import java.io.IOException;
24
import java.util.ArrayList;
25
import java.util.HashMap;
26
import java.util.Iterator;
27
import java.util.List;
28
import java.util.Map;
29

  
30
import org.cresques.cts.IProjection;
31
import org.gvsig.fmap.dal.DataTypes;
32
import org.gvsig.fmap.dal.feature.EditableFeatureAttributeDescriptor;
33
import org.gvsig.fmap.dal.feature.EditableFeatureType;
34
import org.gvsig.fmap.dal.feature.Feature;
35
import org.gvsig.fmap.dal.feature.FeatureType;
36
import org.gvsig.fmap.dal.feature.spi.DefaultFeatureProvider;
37
import org.gvsig.fmap.dal.feature.spi.FeatureProvider;
38
import org.gvsig.fmap.dal.feature.spi.FeatureStoreProviderServices;
39
import org.gvsig.fmap.dal.store.gpe.GPEStoreProvider;
40
import org.gvsig.fmap.dal.store.gpe.model.GPEElement;
41
import org.gvsig.fmap.dal.store.gpe.model.GPEFeature;
42
import org.gvsig.fmap.geom.Geometry;
43
import org.gvsig.fmap.geom.Geometry.SUBTYPES;
44
import org.gvsig.fmap.geom.Geometry.TYPES;
45
import org.gvsig.fmap.geom.GeometryLocator;
46
import org.gvsig.fmap.geom.GeometryManager;
47
import org.gvsig.fmap.geom.aggregate.MultiCurve;
48
import org.gvsig.fmap.geom.aggregate.MultiLine;
49
import org.gvsig.fmap.geom.aggregate.MultiPoint;
50
import org.gvsig.fmap.geom.aggregate.MultiPolygon;
51
import org.gvsig.fmap.geom.exception.CreateEnvelopeException;
52
import org.gvsig.fmap.geom.exception.CreateGeometryException;
53
import org.gvsig.fmap.geom.primitive.Curve;
54
import org.gvsig.fmap.geom.primitive.Envelope;
55
import org.gvsig.fmap.geom.primitive.Line;
56
import org.gvsig.fmap.geom.primitive.Point;
57
import org.gvsig.fmap.geom.primitive.Polygon;
58
import org.gvsig.fmap.geom.primitive.Ring;
59
import org.gvsig.gpe.lib.api.parser.IAttributesIterator;
60
import org.gvsig.gpe.lib.api.parser.ICoordinateIterator;
61
import org.gvsig.gpe.lib.api.parser.IGPEErrorHandler;
62
import org.gvsig.gpe.lib.impl.parser.GPEContentHandler;
63
import org.jfree.util.Log;
64
import org.slf4j.Logger;
65
import org.slf4j.LoggerFactory;
66

  
67

  
68

  
69
public class FmapContentHandler extends GPEContentHandler {
70
    private static final Logger LOG = LoggerFactory.getLogger(FmapContentHandler.class);
71

  
72
    private HashMap featureSet = null;
73
    private EditableFeatureType featureType = null;
74
    private FeatureStoreProviderServices store = null;
75
    private GPEStoreProvider storeProvider = null;
76
    private GeometryManager geomManager = GeometryLocator.getGeometryManager();
77
    private int featureId = 0;
78
    private Envelope envelope = null;
79
    private File file = null;
80
    private IProjection srs = null;
81
    private int geometryType = 0;
82
    private boolean useAxisOrderYX = false;
83

  
84
    public FmapContentHandler(IGPEErrorHandler errorHandler, FeatureStoreProviderServices store,
85
        GPEStoreProvider storeProvider, File file, IProjection srs, int geometryType) {
86
        super();
87
        setErrorHandler(errorHandler);
88
        this.store = store;
89
        this.storeProvider = storeProvider;
90
        this.file = file;
91
        this.srs = srs;
92
        this.geometryType = geometryType;
93
    }
94

  
95
    public FmapContentHandler(IGPEErrorHandler errorHandler, FeatureStoreProviderServices store,
96
        GPEStoreProvider storeProvider, File file, IProjection srs, int geometryType,
97
        boolean useAxisOrderYX) {
98
        this(errorHandler, store, storeProvider, file, srs, geometryType);
99
        this.useAxisOrderYX = useAxisOrderYX;
100
    }
101

  
102
    public int getFeaturesCount(){
103
        return featureSet.size();
104
    }
105

  
106
    public Feature getFeatureAt(int index){
107
        return (Feature)featureSet.get(new Integer(index));
108
    }
109

  
110
    public EditableFeatureType getFeatureType(){
111
        return featureType;
112
    }
113

  
114

  
115
    /**
116
     * @return the featureSet
117
     */
118
    public HashMap getFeatureSet() {
119
        return featureSet;
120
    }
121

  
122
    /*
123
     * (non-Javadoc)
124
     * @see org.gvsig.gpe.parser.GPEContentHandler#startLayer(java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String, org.gvsig.gpe.parser.IAttributesIterator, java.lang.Object, java.lang.Object)
125
     */
126
    public Object startLayer(String id, String namespace, String name,
127
        String description, String srs, IAttributesIterator iterator, Object parentLayer, Object box) {
128
        if (featureSet == null){
129
            featureSet = new HashMap();
130
        }
131
        if (envelope == null){
132
            try {
133
                envelope = geomManager.createEnvelope(SUBTYPES.GEOM2D);
134
            } catch (CreateEnvelopeException e) {
135
                Log.error("Error creating the envelope", e);
136
            }
137
        }
138
        return featureSet;
139
    }
140

  
141
    /*
142
     * (non-Javadoc)
143
     * @see org.gvsig.gpe.IGPEContentHandler#endLayer(java.lang.Object)
144
     */
145
    public void endLayer(Object layer) {
146
        if (featureType == null){
147
            createFeatureType(null);
148
        }
149
        storeProvider.setEnvelope(envelope);
150
    }
151

  
152
    /*
153
     * (non-Javadoc)
154
     * @see org.gvsig.gpe.parser.GPEContentHandler#startPoint(java.lang.String, org.gvsig.gpe.parser.ICoordinateIterator, java.lang.String)
155
     */
156
    public Object startPoint(String id, ICoordinateIterator coords, String srs) {
157
        return createPoint(coords);
158
    }
159

  
160
    private Point createPoint(ICoordinateIterator coords){
161
        double[] buffer = new double[coords.getDimension()];
162
        try {
163
            coords.hasNext();
164
            coords.next(buffer);
165
            Point point = null;
166
            if (buffer.length == 2){
167
                point = (Point) geomManager.create(TYPES.POINT, SUBTYPES.GEOM2D);
168
                if( useAxisOrderYX ) {
169
                    point.setX(buffer[1]);
170
                    point.setY(buffer[0]);
171
                } else {
172
                    point.setX(buffer[0]);
173
                    point.setY(buffer[1]);
174
                }
175
            }else if (buffer.length == 3){
176
                point = (Point) geomManager.create(TYPES.POINT, SUBTYPES.GEOM3D);
177
                if( useAxisOrderYX ) {
178
                    point.setX(buffer[1]);
179
                    point.setY(buffer[0]);
180
                } else {
181
                    point.setX(buffer[0]);
182
                    point.setY(buffer[1]);
183
                }
184
                point.setCoordinateAt(2, buffer[2]);
185
            }
186
            return point;
187
        } catch (IOException e) {
188
            getErrorHandler().addError(e);
189
        } catch (CreateGeometryException e) {
190
            getErrorHandler().addError(e);
191
        }
192
        return null;
193
    }
194

  
195
    private Point createPoint(double[] buffer){
196
        try {
197
            Point point = null;
198
            if (buffer.length == 2){
199
                point = (Point) geomManager.create(TYPES.POINT, SUBTYPES.GEOM2D);
200
                if( useAxisOrderYX ) {
201
                    point.setX(buffer[1]);
202
                    point.setY(buffer[0]);
203
                } else {
204
                    point.setX(buffer[0]);
205
                    point.setY(buffer[1]);
206
                }
207
            }else if (buffer.length == 3){
208
                point = (Point) geomManager.create(TYPES.POINT, SUBTYPES.GEOM3D);
209
                if( useAxisOrderYX ) {
210
                    point.setX(buffer[1]);
211
                    point.setY(buffer[0]);
212
                } else {
213
                    point.setX(buffer[0]);
214
                    point.setY(buffer[1]);
215
                }
216
                point.setCoordinateAt(2, buffer[2]);
217
            }
218
            return point;
219
        }catch (CreateGeometryException e) {
220
            getErrorHandler().addError(e);
221
        }
222
        return null;
223
    }
224

  
225

  
226
    /* (non-Javadoc)
227
     * @see org.gvsig.gpe.parser.GPEContentHandler#startLineString(java.lang.String, org.gvsig.gpe.parser.ICoordinateIterator, java.lang.String)
228
     */
229
    public Object startLineString(String id, ICoordinateIterator coords,
230
        String srs) {
231
        return createCurve(coords);
232
    }
233

  
234
    private Line createCurve(ICoordinateIterator coords){
235
//        GeneralPathX gp = createGeneralPathX(coords);
236
        try {
237
            Line curve = null;
238
            if (coords == null || coords.getDimension() == 2){
239
                curve = (Line) geomManager.create(TYPES.LINE, SUBTYPES.GEOM2D);
240
            }else if (coords.getDimension() == 3){
241
                curve = (Line) geomManager.create(TYPES.LINE, SUBTYPES.GEOM3D);
242
            }
243
            while (coords.hasNext()){
244
                Point point=createPoint(coords);
245
                curve.addVertex(point);
246
            }
247
//            curve.setGeneralPath(gp);
248
            return curve;
249
        } catch (CreateGeometryException e) {
250
            getErrorHandler().addError(e);
251
        } catch (IOException e) {
252
            getErrorHandler().addError(e);
253
        }
254
        return null;
255
    }
256

  
257
//    private GeneralPathX createGeneralPathX(ICoordinateIterator coords){
258
//        GeneralPathX gp = new GeneralPathX();
259
//        if (coords == null){
260
//            return gp;
261
//        }
262
//        double[] buffer = new double[coords.getDimension()];
263
//        try {
264
//            if (coords.hasNext()){
265
//                coords.next(buffer);
266
//                if( this.useAxisOrderYX ) {
267
//                    gp.moveTo(buffer[1], buffer[0]);
268
//                } else {
269
//                    gp.moveTo(buffer[0], buffer[1]);
270
//                }
271
//            }
272
//            while(coords.hasNext()){
273
//                coords.next(buffer);
274
//                if( this.useAxisOrderYX ) {
275
//                    gp.lineTo(buffer[1], buffer[0]);
276
//                } else {
277
//                    gp.lineTo(buffer[0], buffer[1]);
278
//                }
279
//            }
280
//        } catch (IOException e) {
281
//            getErrorHandler().addError(e);
282
//        }
283
//        return gp;
284
//    }
285

  
286
    /* (non-Javadoc)
287
     * @see org.gvsig.gpe.parser.GPEContentHandler#startPolygon(java.lang.String, org.gvsig.gpe.parser.ICoordinateIterator, java.lang.String)
288
     */
289

  
290
    public Object startPolygon(String id, ICoordinateIterator coords, String srs) {
291
        return createPolygon(coords);
292
    }
293

  
294
    private Polygon createPolygon(ICoordinateIterator coords){
295
//        GeneralPathX gp = createGeneralPathX(coords);
296
        try {
297
            Polygon polygon = null;
298
            if (coords.getDimension() == 2){
299
                polygon = (Polygon) geomManager.create(TYPES.POLYGON, SUBTYPES.GEOM2D);
300
            }else if (coords.getDimension() == 3){
301
                polygon = (Polygon) geomManager.create(TYPES.POLYGON, SUBTYPES.GEOM3D);
302
            }
303
            //surface.setGeneralPath(gp);
304
            while (coords.hasNext()){
305
                Point point=createPoint(coords);
306
                polygon.addVertex(point);
307
            }
308
            if (!polygon.getVertex(0).equals(polygon.getVertex(polygon.getNumVertices()-1))){
309
                polygon.addVertex(polygon.getVertex(0));
310
            }
311

  
312
            return polygon;
313
        } catch (CreateGeometryException e) {
314
            getErrorHandler().addError(e);
315
        } catch (IOException e) {
316
            getErrorHandler().addError(e);
317
        }
318
        return null;
319
    }
320

  
321

  
322
    /* (non-Javadoc)
323
     * @see org.gvsig.gpe.parser.GPEContentHandler#startInnerPolygon(java.lang.String, org.gvsig.gpe.parser.ICoordinateIterator, java.lang.String)
324
     */
325
    public Object startInnerPolygon(String id, ICoordinateIterator coords,
326
        String srs) {
327
        return createPolygon(coords);
328
    }
329

  
330
    /*
331
     * (non-Javadoc)
332
     * @see org.gvsig.gpe.IGPEContentHandler#addGeometryToFeature(java.lang.Object, java.lang.Object)
333
     */
334
    public void addGeometryToFeature(Object geometry, Object feature) {
335

  
336
        /*
337
         * Two geometries (possibly of different type) in the same feature
338
         * Instead of overwriting we will preserve the first that arrives.
339
         * Alternative: aggregate, but then gvSIG would have issues to
340
         * draw? or export?
341
         */
342
        GPEFeature gpe_feat = (GPEFeature) feature;
343
        Geometry geom = gpe_feat.getGeometry();
344
        if (geom == null ||
345
            geom.getGeometryType().getType() == Geometry.TYPES.NULL) {
346

  
347
            gpe_feat.setGeometry((Geometry)geometry);
348
        }
349
    }
350

  
351
    /*
352
     * (non-Javadoc)
353
     * @see org.gvsig.gpe.IGPEContentHandler#addBboxToLayer(java.lang.Object, java.lang.Object)
354
     */
355
    public void addBboxToLayer(Object bbox, Object layer) {
356
        //		if (layer != null){
357
        //		GPEBBox gpeBBox = (GPEBBox)bbox;
358
        //		if (gpeBBox.getSrs() != null){
359
        //		IProjection projection = null;
360
        //		try{
361
        //		CRSFactory.getCRS(gpeBBox.getSrs());
362
        //		}catch(Exception e){
363
        //		//If the CRS factory has an error.
364
        //		}
365
        //		if ((projection != null) && (!(projection.equals(((FLayer)layer).getProjection())))){
366
        //		//TODO reproyectar la bbox y asignarsela a la capa
367
        //		}
368
        //		}
369
        //		((IGPEDriver)layer).setExtent(gpeBBox.getBbox2D());
370
        //		}
371
    }
372

  
373
    /*
374
     * (non-Javadoc)
375
     * @see org.gvsig.gpe.IGPEContentHandler#addElementToFeature(java.lang.Object, java.lang.Object)
376
     */
377
    public void addElementToFeature(Object element, Object feature) {
378
        GPEElement gpeElement = (GPEElement)element;
379
        ((GPEFeature)feature).addElement(gpeElement);
380
    }
381

  
382
    /*
383
     * (non-Javadoc)
384
     * @see org.gvsig.gpe.IGPEContentHandler#addFeatureToLayer(java.lang.Object, java.lang.Object)
385
     */
386
    public void addFeatureToLayer(Object feature, Object layer) {
387
        GPEFeature gpefeature = (GPEFeature)feature;
388
        Envelope currentEnvelope = gpefeature.getEnvelope();
389
        if (featureType == null){
390
            createFeatureType(gpefeature);
391

  
392
            //Initialize the envelope
393
            try {
394
                envelope = geomManager.createEnvelope(SUBTYPES.GEOM2D);
395
            } catch (CreateEnvelopeException e) {
396
                getErrorHandler().addError(e);
397
            }
398
            //Calculates the envelope
399
            envelope = currentEnvelope;
400
        }else{
401
            //Calculates the envelope
402
            if (currentEnvelope != null){
403
                envelope.add(currentEnvelope);
404
            }
405
        }
406
        //If it is null is a multilayer: not supported yet
407
        if (layer != null){
408
            FeatureProvider data = new DefaultFeatureProvider(featureType.getNotEditableCopy(), storeProvider.createNewOID());
409
            Map elements = gpefeature.getelements();
410
            Iterator keys = elements.keySet().iterator();
411
            String gid = gpefeature.getId();
412
            data.setOID(gid);
413
            while (keys.hasNext()){
414
                String elementName = (String)keys.next();
415
                if (featureType.getIndex(elementName) != -1) {
416
                    /*
417
                     * If attribute exists, set its value
418
                     * (if a field description was not properly parsed in the
419
                     * feature type description (previous http request) then
420
                     * perhaps it's not available in featureType)
421
                     */
422
                    data.set(elementName, ((GPEElement)elements.get(elementName)).getValue());
423
                }
424
            }
425
            data.setDefaultGeometry(gpefeature.getGeometry());
426
            data.set(featureType.getDefaultGeometryAttributeIndex(), gpefeature.getGeometry());
427
            ((HashMap)layer).put(gid, data);
428
        }
429
    }
430

  
431
    private void createFeatureType(GPEFeature gpefeature){
432
        featureType = store.createFeatureType();
433

  
434
        //Adding the Geometry field
435
        EditableFeatureAttributeDescriptor attributeDescriptor = featureType.add("the_geom", DataTypes.GEOMETRY).setGeometryType(geometryType);
436
        attributeDescriptor.setGeometrySubType(SUBTYPES.GEOM2D);
437
        attributeDescriptor.setSRS(srs);
438
        featureType.setDefaultGeometryAttributeName("the_geom");
439

  
440
        //Adding the ID
441
        EditableFeatureAttributeDescriptor ed = featureType.add("gid", DataTypes.LONG);
442
        ed.setSize(10);
443

  
444
        featureType.setHasOID(true);
445

  
446
        if (gpefeature != null){
447
            Map elements = gpefeature.getelements();
448
            Iterator keys = elements.keySet().iterator();
449
            while (keys.hasNext()){
450
                String elementName = (String)keys.next();
451
                if (!elementName.equals("the_geom") && !elementName.equals("gid")){
452
                    ed = featureType.add(elementName, DataTypes.STRING);
453
                    ed.setSize(80);
454
                }
455
            }
456
        }
457

  
458
        FeatureType defaultType = featureType.getNotEditableCopy();
459
        List types = new ArrayList(1);
460
        types.add(defaultType);
461
        this.store.setFeatureTypes(types, defaultType);
462
    }
463

  
464
    /*
465
     * (non-Javadoc)
466
     * @see org.gvsig.gpe.IGPEContentHandler#addInnerPolygonToPolygon(java.lang.Object, java.lang.Object)
467
     */
468
    public void addInnerPolygonToPolygon(Object innerPolygon, Object Polygon) {
469
        //((Geometry)Polygon).addGeometry((GPEGeometry)innerPolygon);
470
    }
471

  
472
    /*
473
     * (non-Javadoc)
474
     * @see org.gvsig.gpe.IGPEContentHandler#addNameToFeature(java.lang.String, java.lang.Object)
475
     */
476
    public void addNameToFeature(String name, Object feature) {
477

  
478
    }
479

  
480
    /*
481
     * (non-Javadoc)
482
     * @see org.gvsig.gpe.IGPEContentHandler#addParentElementToElement(java.lang.Object, java.lang.Object)
483
     */
484
    public void addParentElementToElement(Object parent, Object element) {
485

  
486
    }
487

  
488
    /*
489
     * (non-Javadoc)
490
     * @see org.gvsig.gpe.IGPEContentHandler#addSrsToLayer(java.lang.String, java.lang.Object)
491
     */
492
    public void addSrsToLayer(String srs, Object Layer) {
493
        //		this.srs = srs;
494
    }
495

  
496

  
497
    /* (non-Javadoc)
498
     * @see org.gvsig.gpe.parser.GPEContentHandler#startBbox(java.lang.String, org.gvsig.gpe.parser.ICoordinateIterator, java.lang.String)
499
     */
500
    public Object startBbox(String id, ICoordinateIterator coords, String srs) {
501
        Envelope envelope = null;
502
        try {
503
            if (coords.getDimension() == 2){
504
                envelope = geomManager.createEnvelope(SUBTYPES.GEOM2D);
505
            }else if (coords.getDimension() == 3){
506
                envelope = geomManager.createEnvelope(SUBTYPES.GEOM3D);
507
            }
508
            double[] buffer = new double[coords.getDimension()];
509

  
510
            if (coords.hasNext()){
511
                coords.next(buffer);
512
                envelope.setLowerCorner(createPoint(buffer));
513
            }
514
            if (coords.hasNext()){
515
                coords.next(buffer);
516
                envelope.setUpperCorner(createPoint(buffer));
517
            }
518
        } catch (IOException e) {
519
            getErrorHandler().addError(e);
520
        } catch (CreateEnvelopeException e) {
521
            getErrorHandler().addError(e);
522
        }
523
        return envelope;
... This diff was truncated because it exceeds the maximum size that can be displayed.

Also available in: Unified diff