Class NtsGeometryServices
- Namespace
- NetTopologySuite
- Assembly
- NetTopologySuite.dll
A geometry service provider class
public class NtsGeometryServices- Inheritance
- 
      
      NtsGeometryServices
- Inherited Members
Remarks
When overriding this class, you need to provide a public constructor with the following arguments:
- A factory to create coordinate sequences
- PrecisionModelA precision model
- intspatial reference id (srid)
- GeometryOverlayA class that bundles an overlay operation function set
- CoordinateEqualityComparerA class that performs checks Coordinates for equality.
Constructors
NtsGeometryServices()
Creates an instance of this class, using the CoordinateArraySequenceFactory
as default and a Floating precision model.
No DefaultSRID is specified.
The Legacy function set for overlay operations is being used.
public NtsGeometryServices()NtsGeometryServices(CoordinateSequenceFactory)
Creates an instance of this class, using a Floating precision model as default.
No DefaultSRID is specified.
The default coordinate sequence factory is defined by coordinateSequenceFactory.
The Legacy function set for overlay operations is being used.
public NtsGeometryServices(CoordinateSequenceFactory coordinateSequenceFactory)Parameters
- coordinateSequenceFactoryCoordinateSequenceFactory
NtsGeometryServices(CoordinateSequenceFactory, PrecisionModel, int)
Creates an instance of this class, using the provided CoordinateSequenceFactory,
PrecisionModel and spatial reference Id (srid).
public NtsGeometryServices(CoordinateSequenceFactory coordinateSequenceFactory, PrecisionModel precisionModel, int srid)Parameters
- coordinateSequenceFactoryCoordinateSequenceFactory
- The coordinate sequence factory to use. 
- precisionModelPrecisionModel
- The precision model. 
- sridint
- The default spatial reference ID 
NtsGeometryServices(CoordinateSequenceFactory, PrecisionModel, int, GeometryOverlay, CoordinateEqualityComparer)
Creates an instance of this class, using the provided CoordinateSequenceFactory,
PrecisionModel, a spatial reference Id (srid) and
a GeometryOverlay.
public NtsGeometryServices(CoordinateSequenceFactory coordinateSequenceFactory, PrecisionModel precisionModel, int srid, GeometryOverlay geometryOverlay, CoordinateEqualityComparer coordinateEqualityComparer)Parameters
- coordinateSequenceFactoryCoordinateSequenceFactory
- The coordinate sequence factory to use. 
- precisionModelPrecisionModel
- The precision model. 
- sridint
- The default spatial reference ID 
- geometryOverlayGeometryOverlay
- The geometry overlay function set to use. 
- coordinateEqualityComparerCoordinateEqualityComparer
- The equality comparer for coordinates 
NtsGeometryServices(GeometryOverlay)
Creates an instance of this class, using the CoordinateArraySequenceFactory as default and a Floating precision model. No DefaultSRID is specified
public NtsGeometryServices(GeometryOverlay geometryOverlay)Parameters
- geometryOverlayGeometryOverlay
- The function set to perform overlay operations 
NtsGeometryServices(PrecisionModel)
Creates an instance of this class, using the CoordinateArraySequenceFactory as default.
No DefaultSRID is specified.
The default precision model is defined by precisionModel.
The Legacy function set for overlay operations is being used.
public NtsGeometryServices(PrecisionModel precisionModel)Parameters
- precisionModelPrecisionModel
NtsGeometryServices(PrecisionModel, int)
Creates an instance of this class, using the CoordinateArraySequenceFactory as default.
A value of srid is assigned to DefaultSRID.
The default precision model is defined by precisionModel.
The Legacy function set for overlay operations is being used.
public NtsGeometryServices(PrecisionModel precisionModel, int srid)Parameters
- precisionModelPrecisionModel
- sridint
Properties
CoordinateEqualityComparer
Gets an object that is used to test 2 coordinates for equality.
public CoordinateEqualityComparer CoordinateEqualityComparer { get; }Property Value
- CoordinateEqualityComparer
- A coordinate equality tester object 
DefaultCoordinateSequenceFactory
Gets or sets the coordiate sequence factory to use
public CoordinateSequenceFactory DefaultCoordinateSequenceFactory { get; }Property Value
DefaultPrecisionModel
Gets or sets the default precision model
public PrecisionModel DefaultPrecisionModel { get; }Property Value
DefaultSRID
Gets the default spatial reference id
public int DefaultSRID { get; }Property Value
GeometryOverlay
Gets or sets a value indicating the operations to use for geometry overlay.
public GeometryOverlay GeometryOverlay { get; }Property Value
- GeometryOverlay
- A set of geometry overlay functions. 
Instance
Gets or sets the default instance of NtsGeometryServices.
public static NtsGeometryServices Instance { get; set; }Property Value
Exceptions
- ArgumentNullException
- Thrown when trying to set the value to null. 
Methods
CreateGeometryFactory()
Creates or retrieves a geometry factory using DefaultSRID, DefaultPrecisionModel and DefaultCoordinateSequenceFactory.
public GeometryFactory CreateGeometryFactory()Returns
- GeometryFactory
- A geometry factory 
CreateGeometryFactory(CoordinateSequenceFactory)
Creates or retrieves a geometry factory using DefaultSRID, DefaultPrecisionModel and
coordinateSequenceFactory.
public GeometryFactory CreateGeometryFactory(CoordinateSequenceFactory coordinateSequenceFactory)Parameters
- coordinateSequenceFactoryCoordinateSequenceFactory
Returns
- GeometryFactory
- A geometry factory 
CreateGeometryFactory(PrecisionModel)
Creates or retrieves a geometry factory using DefaultSRID, precisionModel and
DefaultCoordinateSequenceFactory.
public GeometryFactory CreateGeometryFactory(PrecisionModel precisionModel)Parameters
- precisionModelPrecisionModel
- The precision model to use. 
Returns
- GeometryFactory
- A geometry factory 
CreateGeometryFactory(PrecisionModel, int)
Creates or retrieves a geometry factory using srid, precisionModel and
DefaultCoordinateSequenceFactory.
public GeometryFactory CreateGeometryFactory(PrecisionModel precisionModel, int srid)Parameters
- precisionModelPrecisionModel
- The precision model to use. 
- sridint
- The spatial reference id. 
Returns
- GeometryFactory
- A geometry factory 
CreateGeometryFactory(PrecisionModel, int, CoordinateSequenceFactory)
Creates or retrieves a geometry factory using srid, precisionModel and
coordinateSequenceFactory.
public GeometryFactory CreateGeometryFactory(PrecisionModel precisionModel, int srid, CoordinateSequenceFactory coordinateSequenceFactory)Parameters
- precisionModelPrecisionModel
- The precision model to use. 
- sridint
- The spatial reference id. 
- coordinateSequenceFactoryCoordinateSequenceFactory
Returns
- GeometryFactory
- A geometry factory 
CreateGeometryFactory(int)
Creates or retrieves a geometry factory using srid, DefaultPrecisionModel and
DefaultCoordinateSequenceFactory.
public GeometryFactory CreateGeometryFactory(int srid)Parameters
- sridint
Returns
- GeometryFactory
- A geometry factory 
CreateGeometryFactoryCore(PrecisionModel, int, CoordinateSequenceFactory)
Creates a GeometryFactory based on the given parameters.
protected virtual GeometryFactory CreateGeometryFactoryCore(PrecisionModel precisionModel, int srid, CoordinateSequenceFactory coordinateSequenceFactory)Parameters
- precisionModelPrecisionModel
- The value for PrecisionModel. 
- sridint
- The value for SRID. 
- coordinateSequenceFactoryCoordinateSequenceFactory
- The value for CoordinateSequenceFactory. 
Returns
- GeometryFactory
- A GeometryFactory that has the given values. 
Remarks
This method is expected to be safe to call from any number of threads at once.
Implementations must make sure to use a constructor which is properly assigning GeometryOverlay to the factory.
Although the result for a given set of parameters is cached, there is no guarantee that, once this method is called with some set of parameters, it will never be called again with an exactly equal set of parameters. When this does happen, an arbitrary result is chosen as the winner (not necessarily the first one to start or finish), and all other results are discarded.
CreatePrecisionModel(PrecisionModel)
Creates a precision model based on given precision model.
[Obsolete("Will be removed in a future version")]
public PrecisionModel CreatePrecisionModel(PrecisionModel precisionModel)Parameters
- precisionModelPrecisionModel
Returns
- PrecisionModel
- The precision model 
CreatePrecisionModel(PrecisionModels)
Creates a precision model based on given precision model type
[Obsolete("Will be removed in a future version")]
public PrecisionModel CreatePrecisionModel(PrecisionModels modelType)Parameters
- modelTypePrecisionModels
Returns
- PrecisionModel
- The precision model type 
CreatePrecisionModel(double)
Creates a precision model based on the given scale factor.
[Obsolete("Will be removed in a future version")]
public PrecisionModel CreatePrecisionModel(double scale)Parameters
- scaledouble
- The scale factor 
Returns
- PrecisionModel
- The precision model.