Package org.geotools.shapefile
Class Shapefile
- java.lang.Object
-
- org.geotools.shapefile.Shapefile
-
- All Implemented Interfaces:
TaskMonitorSupport
public class Shapefile extends Object implements TaskMonitorSupport
This class represents an ESRI Shape file.You construct it with a file name, and later you can read the file's properties, i.e. Sizes, Types, and the data itself.
Copyright 1998 by James Macgill.
Version 1.0beta1.1 (added construct with inputstream) 1.0beta1.2 (made Shape type constants public 18/Aug/98) This class supports the Shape file as set out in :-
"ESRI(r) Shapefile - A Technical Description"
'An ESRI White Paper . May 1997'This code is coverd by the LGPL. Mail the Author
-
-
Field Summary
Fields Modifier and Type Field Description static int
ARC
static int
ARCM
static int
ARCZ
static int
MULTIPATCH
static int
MULTIPOINT
static int
MULTIPOINTM
static int
MULTIPOINTZ
static int
NULL
static int
POINT
static int
POINTM
static int
POINTZ
static int
POLYGON
static int
POLYGONM
static int
POLYGONZ
static int
UNDEFINED
-
Constructor Summary
Constructors Constructor Description Shapefile(InputStream is)
Shapefile(URL url)
Creates and initialises a shapefile from a url
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description void
close()
int
getErrorNumber()
Get the number of errors found after a read.static ShapeHandler
getShapeHandler(int type)
static ShapeHandler
getShapeHandler(org.locationtech.jts.geom.Geometry geom, int ShapeFileDimension)
static int
getShapeType(org.locationtech.jts.geom.Geometry geom, int ShapeFileDimension)
Returns the Shape Type corresponding to geometry geom of dimension ShapeFileDimension.static String
getShapeTypeDescription(int index)
Returns a string describing the shape type.TaskMonitor
getTaskMonitor()
org.locationtech.jts.geom.GeometryCollection
read(org.locationtech.jts.geom.GeometryFactory geometryFactory)
Initialises a shapefile from disk.org.locationtech.jts.geom.GeometryCollection
readFromIndex(org.locationtech.jts.geom.GeometryFactory geometryFactory, InputStream is)
The purpose of this new reader [mmichaud 2015-04-11] is to read a shapefile using the shx index file.void
setTaskMonitor(TaskMonitor taskMonitor)
void
write(org.locationtech.jts.geom.GeometryCollection geometries, int ShapeFileDimension)
Saves a shapefile to an output stream.void
writeIndex(org.locationtech.jts.geom.GeometryCollection geometries, EndianDataOutputStream file, int ShapeFileDimension)
Saves a shapefile index (shx) to an output stream.
-
-
-
Field Detail
-
NULL
public static final int NULL
- See Also:
- Constant Field Values
-
POINT
public static final int POINT
- See Also:
- Constant Field Values
-
POINTZ
public static final int POINTZ
- See Also:
- Constant Field Values
-
POINTM
public static final int POINTM
- See Also:
- Constant Field Values
-
ARC
public static final int ARC
- See Also:
- Constant Field Values
-
ARCM
public static final int ARCM
- See Also:
- Constant Field Values
-
ARCZ
public static final int ARCZ
- See Also:
- Constant Field Values
-
POLYGON
public static final int POLYGON
- See Also:
- Constant Field Values
-
POLYGONM
public static final int POLYGONM
- See Also:
- Constant Field Values
-
POLYGONZ
public static final int POLYGONZ
- See Also:
- Constant Field Values
-
MULTIPOINT
public static final int MULTIPOINT
- See Also:
- Constant Field Values
-
MULTIPOINTM
public static final int MULTIPOINTM
- See Also:
- Constant Field Values
-
MULTIPOINTZ
public static final int MULTIPOINTZ
- See Also:
- Constant Field Values
-
MULTIPATCH
public static final int MULTIPATCH
- See Also:
- Constant Field Values
-
UNDEFINED
public static final int UNDEFINED
- See Also:
- Constant Field Values
-
-
Constructor Detail
-
Shapefile
public Shapefile(URL url)
Creates and initialises a shapefile from a url- Parameters:
url
- The url of the shapefile
-
Shapefile
public Shapefile(InputStream is)
-
-
Method Detail
-
close
public void close()
-
read
public org.locationtech.jts.geom.GeometryCollection read(org.locationtech.jts.geom.GeometryFactory geometryFactory) throws Exception
Initialises a shapefile from disk. Use Shapefile(String) if you don't want to use LEDataInputStream directly (recommended)- Parameters:
geometryFactory
- the geometry factory to use to read the shapes- Throws:
Exception
-
getErrorNumber
public int getErrorNumber()
Get the number of errors found after a read.
-
write
public void write(org.locationtech.jts.geom.GeometryCollection geometries, int ShapeFileDimension) throws Exception
Saves a shapefile to an output stream.- Parameters:
geometries
- geometry collection to writeShapeFileDimension
- shapefile dimension (2=x,y ; 3=x,y,m ; 4=x,y,z,m)- Throws:
Exception
-
writeIndex
public void writeIndex(org.locationtech.jts.geom.GeometryCollection geometries, EndianDataOutputStream file, int ShapeFileDimension) throws Exception
Saves a shapefile index (shx) to an output stream.- Parameters:
geometries
- geometry collection to writefile
- file to write toShapeFileDimension
- shapefile dimension (2=x,y ; 3=x,y,m ; 4=x,y,z,m)- Throws:
Exception
-
getShapeTypeDescription
public static String getShapeTypeDescription(int index)
Returns a string describing the shape type.- Parameters:
index
- An int coresponding to the shape type to be described- Returns:
- A string describing the shape type
-
getShapeHandler
public static ShapeHandler getShapeHandler(org.locationtech.jts.geom.Geometry geom, int ShapeFileDimension) throws Exception
- Throws:
Exception
-
getShapeHandler
public static ShapeHandler getShapeHandler(int type) throws Exception
- Throws:
Exception
-
getShapeType
public static int getShapeType(org.locationtech.jts.geom.Geometry geom, int ShapeFileDimension) throws ShapefileException
Returns the Shape Type corresponding to geometry geom of dimension ShapeFileDimension.- Parameters:
geom
- the geomShapeFileDimension
- the dimension of the geom (2=x,y ; 3=x,y,m ; 4=x,y,z,m)- Returns:
- A int representing the Shape Type
- Throws:
ShapefileException
-
readFromIndex
public org.locationtech.jts.geom.GeometryCollection readFromIndex(org.locationtech.jts.geom.GeometryFactory geometryFactory, InputStream is) throws Exception
The purpose of this new reader [mmichaud 2015-04-11] is to read a shapefile using the shx index file. While the legacy reader #read(GeometryFactory geometryFactory) read the shapefile sequentially and don't need the shx index file, this new parser read the shx file and access the shp file with a RandomAccessReader. Because the shapefile may come from a compressed input stream, the method first write the shapefile in a temporary file.- Parameters:
geometryFactory
- geometry factory to use to build geometriesis
- shx input stream- Returns:
- a GeometryCollection containing all the shapes.
- Throws:
Exception
-
setTaskMonitor
public void setTaskMonitor(TaskMonitor taskMonitor)
- Specified by:
setTaskMonitor
in interfaceTaskMonitorSupport
-
getTaskMonitor
public TaskMonitor getTaskMonitor()
- Specified by:
getTaskMonitor
in interfaceTaskMonitorSupport
-
-