About working with GeometryEnvironment
GeometryEnvironment provides a way of creating geometries from different inputs and setting or getting global variables for controlling the behavior of geometry methods. It also provides Java and .NET friendly versions of methods originally defined on other geometry objects (see the IGeometryBridge and IGeometryBridge2 interfaces).
The GeometryEnvironment object is a singleton object (see Interacting with singleton objects), so calling new several times does not create a new object each time. Instead, it returns a reference to the existing GeometryEnvironment object.
Using GeometryEnvironment and SpatialReferenceEnvironment
The following code example uses the IGeometryBridge2 interface on the GeometryEnvironment singleton object to define a polyline from an array of WKSPoint structures. It also uses the SpatialReferenceEnvironment singleton object to create a predefined projected coordinate system. Some of the concepts discussed in the previous introduction are used here.
[C#]
public IPolyline TestGeometryEnvironment()
{
ISpatialReferenceFactory spatialReferenceFactory = new
SpatialReferenceEnvironmentClass();
//Create a projected coordinate system and define its domain, resolution, and x,y tolerance.
ISpatialReferenceResolution spatialReferenceResolution =
spatialReferenceFactory.CreateProjectedCoordinateSystem((int)
esriSRProjCSType.esriSRProjCS_NAD1983UTM_11N)as ISpatialReferenceResolution;
spatialReferenceResolution.ConstructFromHorizon();
ISpatialReferenceTolerance spatialReferenceTolerance =
spatialReferenceResolution as ISpatialReferenceTolerance;
spatialReferenceTolerance.SetDefaultXYTolerance();
ISpatialReference spatialReference = spatialReferenceResolution as
ISpatialReference;
//Create an array of WKSPoint structures starting in the middle of the x,y domain of the
//projected coordinate system.
double xMin;
double xMax;
double yMin;
double yMax;
spatialReference.GetDomain(out xMin, out xMax, out yMin, out yMax);
double xFactor = (xMin + xMax) * 0.5;
double yFactor = (yMin + yMax) * 0.5;
WKSPoint[] wksPoints = new WKSPoint[10];
for (int i = 0; i < wksPoints.Length; i++)
{
wksPoints[i].X = xFactor + i;
wksPoints[i].Y = yFactor + i;
}
IPointCollection4 pointCollection = new PolylineClass();
IGeometryBridge2 geometryBridge = new GeometryEnvironmentClass();
geometryBridge.AddWKSPoints(pointCollection, ref wksPoints);
IPolyline polyline = pointCollection as IPolyline;
polyline.SpatialReference = spatialReference;
return polyline;
}
[VB.NET]
Public Function TestGeometryEnvironment() As IPolyline
Dim spatialReferenceFactory As ISpatialReferenceFactory = New SpatialReferenceEnvironmentClass()
'Create a projected coordinate system and define its domain, resolution, and x,y tolerance.
Dim spatialReferenceResolution As ISpatialReferenceResolution = spatialReferenceFactory.CreateProjectedCoordinateSystem(esriSRProjCSType.esriSRProjCS_NAD1983UTM_11N)
spatialReferenceResolution.ConstructFromHorizon()
Dim spatialReferenceTolerance As ISpatialReferenceTolerance = CType(spatialReferenceResolution, ISpatialReferenceTolerance)
spatialReferenceTolerance.SetDefaultXYTolerance()
Dim spatialReference As ISpatialReference = CType(spatialReferenceResolution, ISpatialReference)
'Create an array of WKSPoint structures starting in the middle of the x,y domain of the
'projected coordinate system.
Dim xMin As Double
Dim xMax As Double
Dim yMin As Double
Dim yMax As Double
spatialReference.GetDomain(xMin, xMax, yMin, yMax)
Dim xFactor As Double = (xMin + xMax) * 0.5
Dim yFactor As Double = (yMin + yMax) * 0.5
Dim wksPoints(9) As WKSPoint
For i As Integer = 0 To wksPoints.Length - 1 Step 1
wksPoints(i).X = xFactor + i
wksPoints(i).Y = yFactor + i
Next i
Dim pointCollection As IPointCollection4 = New PolylineClass()
Dim geometryBridge As IGeometryBridge2 = New GeometryEnvironmentClass()
geometryBridge.AddWKSPoints(pointCollection, wksPoints)
Dim polyline As IPolyline = CType(pointCollection, IPolyline)
polyline.SpatialReference = spatialReference
Return polyline
End Function
To use the code in this topic, reference the following assemblies in your Visual Studio project. In the code files, you will need using (C#) or Imports (VB .NET) directives for the corresponding namespaces (given in parenthesis below if different from the assembly name):
Development licensing | Deployment licensing |
---|---|
ArcGIS for Desktop Basic | ArcGIS for Desktop Basic |
ArcGIS for Desktop Standard | ArcGIS for Desktop Standard |
ArcGIS for Desktop Advanced | ArcGIS for Desktop Advanced |
Engine Developer Kit | Engine |