Table of Contents

Class EllipseShape

Namespace
ThinkGeo.Core
Assembly
ThinkGeo.Core.dll

This class represents an ellipse that is defined with a center point, a height and a width.

[TypeConverter(typeof(BaseShapeTypeConverter))]
public class EllipseShape : AreaBaseShape
Inheritance
EllipseShape
Inherited Members

Remarks

None

Constructors

EllipseShape()

This constructor creates the EllipseShape.

public EllipseShape()

Remarks

None

EllipseShape(byte[])

This constructor creates the EllipseShape.

public EllipseShape(byte[] wellKnownBinary)

Parameters

wellKnownBinary byte[]

This parameter is the well-known binary used to create the shape.

Remarks

None

Exceptions

ArgumentException

Passing invalid well-known binary in the bytes parameter will throw an ArgumentException.

ArgumentNullException

Passing a null as the bytes parameter will throw an ArgumentNullException.

EllipseShape(string)

This constructor creates the EllipseShape.

public EllipseShape(string wellKnownText)

Parameters

wellKnownText string

This parameter is the well-known text used to create the shape.

Remarks

None

Exceptions

ArgumentException

Passing invalid well-known text in the wellKnownText parameter will throw an ArgumentException.

ArgumentNullException

Passing a null as the wellKnownText parameter will throw an ArgumentNullException.

EllipseShape(Feature, double)

This constructor creates the EllipseShape.

public EllipseShape(Feature centerPointFeature, double radius)

Parameters

centerPointFeature Feature

This parameter is the center PointFeature for the EllipseShape.

radius double

This parameter allows you to set the radius of the EllipseShape.

Remarks

Using this overload will create a circle.

Exceptions

ArgumentNullException

If you pass a null as the center, we will throw an ArgumentNullException.

ArgumentOutOfRangeException

Passing an invalid radius which is not greater than 0 will throw an ArgumentOutOfRangeException.

EllipseShape(Feature, double, double)

This constructor creates the EllipseShape.

public EllipseShape(Feature centerPointFeature, double horizontalRadius, double verticalRadius)

Parameters

centerPointFeature Feature

This parameter is the center PointFeature for the EllipseShape.

horizontalRadius double

This parameter allows you to set the horizontal radius of the EllipseShape in the unit of the shape.

verticalRadius double

This parameter allows you to set the vertical radius of the EllipseShape in the unit of the shape.

Remarks

None

Exceptions

ArgumentNullException

If you pass a null as the center, we will throw an ArgumentNullException.

ArgumentOutOfRangeException

Passing an invalid horizonalRadius which is not greater than 0 will throw an ArgumentOutOfRangeException.

ArgumentOutOfRangeException

Passing an invalid verticalRadius which is not greater than 0 will throw an ArgumentOutOfRangeException.

EllipseShape(Feature, double, double, GeographyUnit, DistanceUnit)

This constructor creates the EllipseShape.

public EllipseShape(Feature centerPointFeature, double horizontalRadius, double verticalRadius, GeographyUnit shapeUnit, DistanceUnit unitOfRadius)

Parameters

centerPointFeature Feature

This parameter is the center Point Feature for the EllipseShape.

horizontalRadius double

This parameter allows you to set the horizontal radius of the EllipseShape in the unit specified by the unitOfRadius parameter.

verticalRadius double

This parameter allows you to set the vertical radius of the EllipseShape in the unit specified by the unitOfRadius parameter.

shapeUnit GeographyUnit

This is the GeographyUnit of the shape you are performing the operation on.

unitOfRadius DistanceUnit

This is the DistanceUnit you would like to use for the radius value. For example, if you select miles as your unitOfRadius, then it will use miles.

Remarks

None

Exceptions

ArgumentNullException

If you pass a null as the center, we will throw an ArgumentNullException.

ArgumentOutOfRangeException

Passing an invalid horizonalRadius which is not greater than 0 will throw an ArgumentOutOfRangeException.

ArgumentOutOfRangeException

Passing an invalid verticalRadius which is not greater than 0 will throw an ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a shapeUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a unitOfRadius that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

EllipseShape(Feature, double, GeographyUnit, DistanceUnit)

This constructor creates the EllipseShape.

public EllipseShape(Feature centerPointFeature, double radius, GeographyUnit shapeUnit, DistanceUnit unitOfRadius)

Parameters

centerPointFeature Feature

This parameter is the center Point Feature for the EllipseShape.

radius double

This parameter allows you to set the radius of the EllipseShape in the unit specified by the unitOfRadius parameter.

shapeUnit GeographyUnit

This is the GeographyUnit of the shape you are performing the operation on.

unitOfRadius DistanceUnit

This is the DistanceUnit you would like to use for the radius value. For example, if you select miles as your unitOfRadius, then it will use miles.

Remarks

This overload will create a circle.

Exceptions

ArgumentNullException

If you pass a null as the center, we will throw an ArgumentNullException.

ArgumentOutOfRangeException

Passing an invalid radius which is not greater than 0 will throw an ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a shapeUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a unitOfRadius that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

EllipseShape(PointShape, double)

This constructor creates the EllipseShape.

public EllipseShape(PointShape center, double radius)

Parameters

center PointShape

This parameter is the center PointShape for the EllipseShape.

radius double

This parameter allows you to set the radius of the EllipseShape.

Remarks

Using this overload will create a circle.

Exceptions

ArgumentNullException

If you pass a null as the center, we will throw an ArgumentNullException.

ArgumentOutOfRangeException

Passing an invalid radius which is not greater than 0 will throw an ArgumentOutOfRangeException.

EllipseShape(PointShape, double, double)

This constructor creates the EllipseShape.

public EllipseShape(PointShape center, double horizontalRadius, double verticalRadius)

Parameters

center PointShape

This parameter is the center PointShape for the EllipseShape.

horizontalRadius double

This parameter allows you to set the horizontal radius of the EllipseShape in the unit of the shape.

verticalRadius double

This parameter allows you to set the vertical radius of the EllipseShape in the unit of the shape.

Remarks

None

Exceptions

ArgumentNullException

If you pass a null as the center, we will throw an ArgumentNullException.

ArgumentOutOfRangeException

Passing an invalid horizonalRadius which is not greater than 0 will throw an ArgumentOutOfRangeException.

ArgumentOutOfRangeException

Passing an invalid verticalRadius which is not greater than 0 will throw an ArgumentOutOfRangeException.

EllipseShape(PointShape, double, double, GeographyUnit, DistanceUnit)

This constructor creates the EllipseShape.

public EllipseShape(PointShape center, double horizontalRadius, double verticalRadius, GeographyUnit shapeUnit, DistanceUnit unitOfRadius)

Parameters

center PointShape

This parameter is the center PointShape for the EllipseShape.

horizontalRadius double

This parameter allows you to set the horizontal radius of the EllipseShape in the unit specified by the unitOfRadius parameter.

verticalRadius double

This parameter allows you to set the vertical radius of the EllipseShape in the unit specified by the unitOfRadius parameter.

shapeUnit GeographyUnit

This is the GeographyUnit of the shape you are performing the operation on.

unitOfRadius DistanceUnit

This is the DistanceUnit you would like to use for the radius value. For example, if you select miles as your unitOfRadius, then it will use miles.

Remarks

None

Exceptions

ArgumentNullException

If you pass a null as the center, we will throw an ArgumentNullException.

ArgumentOutOfRangeException

Passing an invalid horizonalRadius which is not greater than 0 will throw an ArgumentOutOfRangeException.

ArgumentOutOfRangeException

Passing an invalid verticalRadius which is not greater than 0 will throw an ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a shapeUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a unitOfRadius that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

EllipseShape(PointShape, double, GeographyUnit, DistanceUnit)

This constructor creates the EllipseShape.

public EllipseShape(PointShape center, double radius, GeographyUnit shapeUnit, DistanceUnit unitOfRadius)

Parameters

center PointShape

This parameter is the center PointShape for the EllipseShape.

radius double

This parameter allows you to set the radius of the EllipseShape in the unit specified by the unitOfRadius parameter.

shapeUnit GeographyUnit

This is the GeographyUnit of the shape you are performing the operation on.

unitOfRadius DistanceUnit

This is the DistanceUnit you would like to use for the radius value. For example, if you select miles as your unitOfRadius, then it will use miles.

Remarks

This overload will create a circle.

Exceptions

ArgumentNullException

If you pass a null as the center, we will throw an ArgumentNullException.

ArgumentOutOfRangeException

Passing an invalid radius which is not greater than 0 will throw an ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a shapeUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a unitOfRadius that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

Properties

Center

This property allows you to get or set the center PointShape of the EllipseShape.

public PointShape Center { get; set; }

Property Value

PointShape

This property allows you to get or set the center PointShape of the EllipseShape.

Remarks

None

Height

This property returns the height of the EllipseShape in the unit of the shape.

public double Height { get; }

Property Value

double

This property returns the height of the EllipseShape in the unit of the shape.

Remarks

None

Width

This property returns the width of the EllipseShape in the unit of the shape.

public double Width { get; }

Property Value

double

This property returns the width of the EllipseShape in the unit of the shape.

Remarks

None

Methods

CloneDeepCore()

This method returns a complete copy of the shape without any references in common.

protected override BaseShape CloneDeepCore()

Returns

BaseShape

This method returns a complete copy of the shape without any references in common.

Remarks

When you override this method, you need to ensure that there are no references in common between the original and copy.

ContainsCore(BaseShape)

This method returns whether the targetShape lies within the interior of the current shape.

protected override bool ContainsCore(BaseShape targetShape)

Parameters

targetShape BaseShape

The shape you wish to compare the current one to.

Returns

bool

This method returns whether the targetShape lies within the interior of the current shape.

Remarks

<br />
<br />

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

InvalidOperationException

In the event you attempt to call this method on a shape which has no points, it will throw an InvalidOperationException.

ArgumentException

If you pass in a targetShape which is invalid, we will throw an ArgumentException.

ArgumentNullException

If you pass a null as the targetShape, we will throw an ArgumentNullException.

GetAreaCore(GeographyUnit, AreaUnit)

This method returns the area of the shape, which is defined as the size of the region enclosed by the figure.

protected override double GetAreaCore(GeographyUnit shapeUnit, AreaUnit returningUnit)

Parameters

shapeUnit GeographyUnit

This is the GeographyUnit of the shape you are performing the operation on.

returningUnit AreaUnit

This is the AreaUnit you would like to use for the return value. For example, if you select square miles as your returningUnit, then the distance will be returned in square miles.

Returns

double

The return unit is based on the AreaUnit you specify in the returningUnit parameter, regardless of the shape's GeographyUnit.

Remarks

You would use this method to find the area inside of a shape.

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

ArgumentOutOfRangeException

If you pass in a shapeUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a returningUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

InvalidOperationException

In the event you attempt to call this method on a shape which has no points, it will throw an InvalidOperationException.

GetBoundingBoxCore()

This method calculates the smallest RectangleShape that encompasses the entire geometry.

protected override RectangleShape GetBoundingBoxCore()

Returns

RectangleShape

The RectangleShape returned is the smallest RectangleShape that can encompass the entire geometry.

Remarks

The GetBoundingBox method calculates the smallest RectangleShape that can encompass the entire geometry by examining each point in the geometry.


Depending on the number of PointShapes and complexity of the geometry, this operation can take a significant amount of time (the larger the objects, the more time the operation will take).


If the shape is a PointShape, then the bounding box's upper left and lower right points will be equal. This will create a RectangleShape with no area.

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

InvalidOperationException

In the event you attempt to get the bounding box from a shape which has no points, it will throw an InvalidOperationException.

GetClosestPointToCore(BaseShape, GeographyUnit)

This method returns the point of the current shape that is closest to the target shape.

protected override PointShape GetClosestPointToCore(BaseShape targetShape, GeographyUnit shapeUnit)

Parameters

targetShape BaseShape

The shape you are trying to find the closest point to.

shapeUnit GeographyUnit

This is the GeographicUnit of the shape you are performing the operation on.

Returns

PointShape

A PointShape representing the point of the current shape that is closest to the targetShape.

Remarks

This method returns point of the current shape that is closest to the target shape. It is often the case that the point returned is not a point of the object itself. An example would be a line with two points that are far apart from each other. If you set the targetShape to be a point midway between the points but a short distance away, the method would return a point that is on the line, but not one of the two points that make up the line.

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

ArgumentException

If you pass in a targetShape which does not have any points, we will throw an ArgumentException.

ArgumentNullException

If you pass a null as the targetShape, we will throw an ArgumentNullException.

InvalidOperationException

In the event you attempt to call this method on a shape which has no points, it will throw an InvalidOperationException.

ArgumentOutOfRangeException

If you pass in a shapeUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

GetCrossingCore(BaseShape)

This method returns the crossing points of the current shape and the passed-in target shape.

protected override MultipointShape GetCrossingCore(BaseShape targetShape)

Parameters

targetShape BaseShape

The target shape you wish to get crossing with.

Returns

MultipointShape

This method returns the crossing points of the current shape and the passed-in target shape.

Remarks

As this is a concrete public method that wraps a Core method, we reserve the right to add events and other logic to pre- or post-process data returned by the Core version of the method. In this way, we leave our framework open on our end, but also allow you the developer to extend our logic to suit your needs. If you have questions about this, please contact our support team as we would be happy to work with you on extending our framework.

Exceptions

InvalidOperationException

In the event you attempt to call this method on a shape which has no points, it will throw an InvalidOperationException.

ArgumentNullException

If you pass a null as the targetShape, we will throw an ArgumentNullException.

GetDistanceToCore(BaseShape, GeographyUnit, DistanceUnit)

This method computes the distance between the current shape and the targetShape.

protected override double GetDistanceToCore(BaseShape targetShape, GeographyUnit shapeUnit, DistanceUnit distanceUnit)

Parameters

targetShape BaseShape

The shape you are trying to find the distance to.

shapeUnit GeographyUnit

This is the GeographicUnit of the shape you are performing the operation on.

distanceUnit DistanceUnit

This is the DistanceUnit you would like to use as the return value. For example, if you select miles as your distanceUnit, then the distance will be returned in miles.

Returns

double

The return type is the distance between this shape and the targetShape in the GeographyUnit of the shape.

Remarks

In this method, we compute the closest distance between two shapes. The returned unit will be in the unit of distance specified in the distanceUnit parameter.

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

ArgumentException

If you pass in a targetShape which does not have any points, we will throw an ArgumentException.

ArgumentNullException

If you pass a null as the targetShape, we will throw an ArgumentNullException.

InvalidOperationException

In the event you attempt to call this method on a shape which has no points, it will throw an InvalidOperationException.

ArgumentOutOfRangeException

If you pass in a shapeUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a distanceUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

GetHeightByUnit(GeographyUnit, DistanceUnit)

This method returns the height of the EllipseShape in the unit specified in the returningUnit parameter.

public double GetHeightByUnit(GeographyUnit shapeUnit, DistanceUnit returningUnit)

Parameters

shapeUnit GeographyUnit

This parameter is the unit of the current shape.

returningUnit DistanceUnit

This is the unit you would like to use for the return value. For example, if you select miles as your returningUnit, then the distance will be returned in miles.

Returns

double

This method returns the height of the EllipseShape in the unit specified in the returningUnit parameter.

Remarks

None

Exceptions

InvalidOperationException

In the event you attempt to call this method on a shape which has no points, it will throw an InvalidOperationException.

ArgumentOutOfRangeException

If you pass in a shapeUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a returningUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

GetPerimeterCore(GeographyUnit, DistanceUnit)

This method returns the perimeter of the shape, which is defined as the sum of the lengths of all its sides.

protected override double GetPerimeterCore(GeographyUnit shapeUnit, DistanceUnit returningUnit)

Parameters

shapeUnit GeographyUnit

This is the GeographyUnit of the shape you are performing the operation on.

returningUnit DistanceUnit

This is the DistanceUnit you would like to use for the return value. For example, if you select miles as your returningUnit, then the distance will be returned in miles.

Returns

double

The return unit is based on the LengthUnit you specify in the returningUnit parameter, regardless of the shape's GeographyUnit.

Remarks

You would use this method to find the distance around the area shape.



Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

ArgumentOutOfRangeException

If you pass in a shapeUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a returningUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

InvalidOperationException

In the event you attempt to call this method on a shape which has no points, it will throw an InvalidOperationException.

GetTangents(EllipseShape)

This method returns the tangent points of the current ellipse in relation to the target ellipse you specify.

public Collection<PointShape> GetTangents(EllipseShape targetEllipse)

Parameters

targetEllipse EllipseShape

This parameter represents the other ellipse you wish to find the tangent points to.

Returns

Collection<PointShape>

This method returns the tangent points of the current ellipse in relation to the target ellipse you specify.

Remarks

This operation is useful for finding the corridor between two ellipses. It would be handy in a buffering type of scenario.

GetWellKnownBinaryCore(RingOrder, WkbByteOrder)

This method returns a byte array that represents the shape in well-known binary.

protected override byte[] GetWellKnownBinaryCore(RingOrder outerRingOrder, WkbByteOrder byteOrder)

Parameters

outerRingOrder RingOrder
byteOrder WkbByteOrder

This parameter specifies whether the byte order is big- or little-endian.

Returns

byte[]

This method returns a byte array that represents the shape in well-known binary.

Remarks

This method returns a byte array that represents the shape in well known binary. Well-known binary allows you to describe geometries as a binary array. Well-known binary is useful when you want to save a geometry in an efficient format using as little space as possible. An alternative to well-known binary is well-known text, which is a textual representation of a geometry object. We also have methods that work with well-known text.

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

InvalidOperationException

In the event you attempt to call this method on a shape which has no points, it will throw an InvalidOperationException.

ArgumentOutOfRangeException

If you pass in a ByteOrder that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

GetWellKnownBinaryCore(RingOrder, WkbByteOrder, int)

protected byte[] GetWellKnownBinaryCore(RingOrder outerRingOrder, WkbByteOrder byteOrder, int vertexCountInQuarter)

Parameters

outerRingOrder RingOrder
byteOrder WkbByteOrder
vertexCountInQuarter int

Returns

byte[]

GetWellKnownBinaryCore(WkbByteOrder, int)

This method returns a byte array that represents the shape in well-known binary.

protected byte[] GetWellKnownBinaryCore(WkbByteOrder byteOrder, int vertexCountInQuarter)

Parameters

byteOrder WkbByteOrder

This parameter specifies whether the byte order is big- or little-endian.

vertexCountInQuarter int

This parameter specifies how many points will make up each quarter of the ellipse.

Returns

byte[]

This method returns a byte array that represents the shape in well-known binary.

Remarks

This method returns a byte array that represents the shape in well known binary. Well-known binary allows you to describe geometries as a binary array. Well-known binary is useful when you want to save a geometry in an efficient format using as little space as possible. An alternative to well-known binary is well-known text, which is a textual representation of a geometry object. We also have methods that work with well-known text.

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

InvalidOperationException

In the event you attempt to call this method on a shape which has no points, it will throw an InvalidOperationException.

ArgumentOutOfRangeException

If you pass in a ByteOrder that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

ArgumentOutOfRangeException

Passing an invalid vertexCountInQuarter which is not greater than 0 will throw an ArgumentOutOfRangeException.

GetWellKnownTextCore(int)

This method returns the well-known text representation of this shape.

protected string GetWellKnownTextCore(int vertexCountInQuarter)

Parameters

vertexCountInQuarter int

This parameter specifies how many points will make up each quarter of the ellipse.

Returns

string

This method returns a stringthat represents the shape in well-known text.

Remarks

This method returns a string that represents the shape in well-known text. Well-known text allows you to describe geometries as a string of text. Well-known text is useful when you want to save a geometry in a format such as a text file, or when you simply want to cut and paste the text between other applications. An alternative to well-known text is well-known binary, which is a binary representation of a geometry object. We also have methods that work with well-known binary. Below are some samples of what well-known text might look like for various kinds of geometries.

POINT(5 17)

LINESTRING(4 5,10 50,25 80)

POLYGON((2 2,6 2,6 6,2 6,2 2),(3 3,4 3,4 4,3 4,3 3))

MULTIPOINT(3.7 9.7,4.9 11.6)

MULTILINESTRING((4 5,11 51,21 26),(-4 -7,-9 -7,-14 -3))

MULTIPOLYGON(((2 2,6 2,6 6,2 6,2 2),(3 3,4 3,4 4,3 4,3 3)),((4 4,7 3,7 5,4 4)))

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

InvalidOperationException

In the event you attempt to call this method on this shape which has invalid upper left and lower right points, it will throw an InvalidOperationException.

ArgumentOutOfRangeException

Passing an invalid vertexCountInQuarter which is not greater than 0 will throw an ArgumentOutOfRangeException.

GetWellKnownTextCore(RingOrder)

This method returns the well-known text representation of this shape.

protected override string GetWellKnownTextCore(RingOrder outerRingOrder)

Parameters

outerRingOrder RingOrder

Returns

string

This method returns a string that represents the shape in well-known text.

Remarks

This method returns a string that represents the shape in well-known text. Well-known text allows you to describe geometries as a string of text. Well-known text is useful when you want to save a geometry in a format such as a text file, or when you simply want to cut and paste the text between other applications. An alternative to well-known text is well-known binary, which is a binary representation of a geometry object. We also have methods that work with well-known binary. Below are some samples of what well-known text might look like for various kinds of geometries.

POINT(5 17)

LINESTRING(4 5,10 50,25 80)

POLYGON((2 2,6 2,6 6,2 6,2 2),(3 3,4 3,4 4,3 4,3 3))

MULTIPOINT(3.7 9.7,4.9 11.6)

MULTILINESTRING((4 5,11 51,21 26),(-4 -7,-9 -7,-14 -3))

MULTIPOLYGON(((2 2,6 2,6 6,2 6,2 2),(3 3,4 3,4 4,3 4,3 3)),((4 4,7 3,7 5,4 4)))

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

InvalidOperationException

In the event you attempt to call this method on a shape which has no points, it will throw an InvalidOperationException.

GetWellKnownTextCore(RingOrder, int)

protected string GetWellKnownTextCore(RingOrder outerRingOrder, int vertexCountInQuarter)

Parameters

outerRingOrder RingOrder
vertexCountInQuarter int

Returns

string

GetWellKnownTypeCore()

This method returns the well-known type for the shape.

protected override WellKnownType GetWellKnownTypeCore()

Returns

WellKnownType

This method returns the well-known type for the shape.

Remarks

None

GetWidthByUnit(GeographyUnit, DistanceUnit)

This method returns the width of the EllipseShape in the unit specified in the returningUnit parameter.

public double GetWidthByUnit(GeographyUnit shapeUnit, DistanceUnit returningUnit)

Parameters

shapeUnit GeographyUnit

This parameter is the unit of the current shape.

returningUnit DistanceUnit

This is the unit you would like to use for the return value. For example, if you select miles as your returningUnit, then the distance will be returned in miles.

Returns

double

This method returns the width of the EllipseShape in the unit specified in the returningUnit parameter.

Remarks

None

Exceptions

InvalidOperationException

In the event you attempt to call this method on a shape which has no points, it will throw an InvalidOperationException.

ArgumentOutOfRangeException

If you pass in a shapeUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a returningUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

IntersectsCore(BaseShape)

This method returns whether the current shape and the targetShape have at least one point in common.

protected override bool IntersectsCore(BaseShape targetShape)

Parameters

targetShape BaseShape

The shape you wish to compare the current one to.

Returns

bool

This method returns whether the current shape and the targetShape have at least one point in common.

Remarks

<br />
<br />

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

InvalidOperationException

In the event you attempt to call this method on a shape which has no points, it will throw an InvalidOperationException.

ArgumentException

If you pass in a targetShape which is invalid, we will throw an ArgumentException.

ArgumentNullException

If you pass a null as the targetShape, we will throw an ArgumentNullException.

LoadFromWellKnownDataCore(byte[])

This method hydrates the current shape with its data from well-known binary.

protected override void LoadFromWellKnownDataCore(byte[] wellKnownBinary)

Parameters

wellKnownBinary byte[]

This parameter is the well-known binary used to populate the shape.

Remarks

This is used when you want to hydrate a shape based on well-known binary. You can create the shape and then load the well-known binary using this method.

Exceptions

ArgumentException

Passing invalid well-known binary in the bytes parameter will throw an ArgumentException.

ArgumentNullException

Passing a null as the bytes parameter will throw an ArgumentNullException.

LoadFromWellKnownDataCore(string)

This method hydrates the current shape with its data from well-known text.

protected override void LoadFromWellKnownDataCore(string wellKnownText)

Parameters

wellKnownText string

This parameter is the well-known text you will use to hydrate your object.

Remarks

None

Exceptions

ArgumentException

Passing invalid well-known text in the wellKnownText parameter will throw an ArgumentException.

ArgumentNullException

Passing a null as the wellKnownText parameter will throw an ArgumentNullException.

RegisterCore(PointShape, PointShape, DistanceUnit, GeographyUnit)

This method returns a BaseShape which has been registered from its original coordinate system to another based on two anchor PointShapes.

protected override BaseShape RegisterCore(PointShape fromPoint, PointShape toPoint, DistanceUnit fromUnit, GeographyUnit toUnit)

Parameters

fromPoint PointShape

This parameter is the anchor PointShape in the coordinate of origin.

toPoint PointShape

This parameter is the anchor PointShape in the coordinate of destination.

fromUnit DistanceUnit

This parameter is the DistanceUnit of the coordinate of origin.

toUnit GeographyUnit

This parameter is the GeographyUnit of the coordinate of destination.

Returns

BaseShape

This method returns a BaseShape which has been registered from its original coordinate system to another based on two anchor PointShapes.

Remarks

Registering allows you to take a geometric shape generated in a planar system and attach it to the ground in a Geographic Unit.

A common scenario is integrating geometric shapes from external programs (such as CAD software or a modeling system) and placing them onto a map. You may have the schematics of a building in a CAD system and the relationship between all the points of the building are in feet. You want to then take the CAD image and attach it to where it really exists on a map. You would use the register method to do this.

Registering is also useful for scientific modeling, where software models things such as a plume of hazardous materials or the fallout from a volcano. The modeling software typically generates these models in a fictitious planar system. You would then use the register to take the abstract model and attach it to a map with real coordinates.

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

ArgumentOutOfRangeException

If you pass in a fromUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a toUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

InvalidOperationException

In the event you attempt to call this method on a shape which has no points, it will throw an InvalidOperationException.

ArgumentNullException

Passing a null as the fromPoint parameter will throw an ArgumentNullException.

ArgumentNullException

Passing a null as the toPoint parameter will throw an ArgumentNullException.

RotateCore(PointShape, double)

This method rotates the shape a number of degrees based on a pivot point.

protected override void RotateCore(PointShape pivotPoint, double degreeAngle)

Parameters

pivotPoint PointShape

The pivotPoint represents the center of rotation.

degreeAngle double

The number of degrees of rotation required from 0 to 360.

Remarks

This method rotates the shape by a number of degrees based on a pivot point. By placing the pivot point in the center of the shape, you can acheive in-place rotation. By moving the pivot point outside of the center of the shape, you can translate the shape in a circular motion. Moving the pivot point further away from the center will make the circular area larger.

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

ArgumentNullException

If you pass a null as the pivotPoint, we will throw an ArgumentNullException.

ArgumentOutOfRangeException

Passing an invalid degreeAngle which is not between 0 and 360 will throw an ArgumentOutOfRangeException.

InvalidOperationException

In the event you attempt to call this method on a shape which is not valid, it will throw an InvalidOperationException.

ScaleDownCore(double)

This method decreases the size of the area shape by the percentage given in the percentage parameter.

protected override void ScaleDownCore(double percentage)

Parameters

percentage double

This is the percentage by which to decrease the shape's size.

Remarks

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

InvalidOperationException

In the event you attempt to call this method on a shape which has no points, it will throw an InvalidOperationException.

ArgumentOutOfRangeException

Passing an invalid percentage which is less than 0 will throw an ArgumentOutOfRangeException.

ScaleUpCore(double)

This method increases the size of the area shape by the percentage given in the percentage parameter.

protected override void ScaleUpCore(double percentage)

Parameters

percentage double

This is the percentage by which to increase the shape's size.

Remarks

This method is useful when you would like to increase the size of the shape. Note that a larger percentage will scale the shape up faster, as you are applying the operation multiple times. There is also a ScaleDown method that will shrink the shape.

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

InvalidOperationException

In the event you attempt to call this method on a shape which has no points, it will throw an InvalidOperationException.

ArgumentOutOfRangeException

Passing an invalid percentage which is less than 0 will throw an ArgumentOutOfRangeException.

SetHeightByUnit(double, GeographyUnit, DistanceUnit)

This method allows you to set the height of the EllipseShape in the unit specified in the unitOfWidth.

public void SetHeightByUnit(double newHeight, GeographyUnit shapeUnit, DistanceUnit unitOfHeight)

Parameters

newHeight double

This parameter is the newHeight of the ellipse shape.

shapeUnit GeographyUnit

This parameter is the unit of the current shape.

unitOfHeight DistanceUnit

This is the unit you would like to use for the setting value. For example, if you select miles as your unitOfHeight, then the distance will be set in miles.

Remarks

None

Exceptions

ArgumentOutOfRangeException

Passing an invalid height which is not greater than 0 will throw an ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a shapeUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a unitOfHeight that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

SetWidthByUnit(double, GeographyUnit, DistanceUnit)

This method allows you to set the width of the EllipseShape in the unit specified in the unitOfWidth parameter.

public void SetWidthByUnit(double newWidth, GeographyUnit shapeUnit, DistanceUnit unitOfWidth)

Parameters

newWidth double

This parameter is the newWidth of the ellipse shape.

shapeUnit GeographyUnit

This parameter is the unit of the current shape.

unitOfWidth DistanceUnit

This is the unit you would like to use as the setting value. For example, if you select miles as your unitOfWidth, then the distance will be set in miles.

Remarks

None

Exceptions

ArgumentOutOfRangeException

Passing an invalid width which is not greater than 0 will throw an ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a shapeUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a unitOfWidth that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

ToPolygon()

This method returns the current shape as a PolygonShape.

public PolygonShape ToPolygon()

Returns

PolygonShape

This method returns the current shape as a PolygonShape.

Remarks

This method is mainly used to convert this non GIS standard shape to a GIS standard shape.

Exceptions

InvalidOperationException

In the event you attempt to call this method on this shape which has invalid upper left and lower right points, it will throw an InvalidOperationException.

ToPolygon(int)

This method returns the current shape as a PolygonShape.

public PolygonShape ToPolygon(int vertexCountInQuarter)

Parameters

vertexCountInQuarter int

This parameter specifies how many points will make up each quarter of the ellipse.

Returns

PolygonShape

This method returns the current shape as a PolygonShape.

Remarks

This method is mainly used to convert a GIS non-standard shape to a GIS standard shape.

Exceptions

InvalidOperationException

In the event you attempt to call this method on this shape which has invalid upper left and lower right points, it will throw an InvalidOperationException.

ArgumentOutOfRangeException

Passing an invalid vertexCountInQuarter which is not greater than 0 will throw an ArgumentOutOfRangeException.

TranslateByDegreeCore(double, double, GeographyUnit, DistanceUnit)

This method moves the base shape from one location to another based on a direction in degrees and distance.

protected override void TranslateByDegreeCore(double distance, double angleInDegrees, GeographyUnit shapeUnit, DistanceUnit distanceUnit)

Parameters

distance double

The distance is the number of units to move the shape using the angle specified. The distance unit will be the DistanceUnit specified in the distanceUnit parameter. The distance must be greater than or equal to 0.

angleInDegrees double

A number between 0 and 360 degrees that represents the direction you wish to move the shape with zero being up.

shapeUnit GeographyUnit

This is the GeographicUnit of the shape you are performing the operation on.

distanceUnit DistanceUnit

This is the DistanceUnit you would like to use as the measurement for the move. For example, if you select miles as your distanceUnit, then the distance will be calculated in miles.

Remarks

This method moves the base shape from one location to another based on angleInDegrees and distance parameter. It is important to note that with this overload the distance units are based on the distanceUnit parameter. For example, if your shape is in decimal degrees and you call this method with a distanceUnit in miles, you're going to move this shape a number of miles based on the distance and the angleInDegrees. In this way, you can easily move a shape in decimal degrees five miles to the north.

If you pass a distance of 0, then the operation is ignored.

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

ArgumentOutOfRangeException

Passing an invalid angleInDegrees which is not between 0 and 360 will throw an ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a shapeUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a distanceUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

InvalidOperationException

In the event you attempt to call this method from a shape which has no points, it will throw an InvalidOperationException.

ArgumentOutOfRangeException

Passing an invalid distance which is not greater than or equal to 0 will throw an ArgumentOutOfRangeException.

TranslateByOffsetCore(double, double, GeographyUnit, DistanceUnit)

This method moves the base shape from one location to another based on an X and Y offset distance.

protected override void TranslateByOffsetCore(double xOffsetDistance, double yOffsetDistance, GeographyUnit shapeUnit, DistanceUnit distanceUnit)

Parameters

xOffsetDistance double

This is the number of horizontal units of movement in the DistanceUnit specified by the distanceUnit parameter.

yOffsetDistance double

This is the number of horizontal units of movement in the DistanceUnit specified by the distanceUnit parameter.

shapeUnit GeographyUnit

This is the GeographicUnit of the shape you are performing the operation on.

distanceUnit DistanceUnit

This is the DistanceUnit you would like to use as the measurement for the move. For example, if you select miles as your distanceUnit, then the xOffsetDistance and yOffsetDistance will be calculated in miles.

Remarks

This method moves the base shape from one location to another based on an X and Y offset distance. It is important to note that with this overload the X and Y offset units are based on the distanceUnit parameter. For example, if your shape is in decimal degrees and you call this method with an X offset of one and a Y offset of one, you're going to move this shape one unit of the distanceUnit in the horizontal direction and one unit of the distanceUnit in the vertical direction. In this way, you can easily move a shape in decimal degrees five miles to on the X axis and 3 miles on the Y axis.

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

ArgumentOutOfRangeException

If you pass in a distanceUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

ArgumentOutOfRangeException

If you pass in a shapeUnit that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.

InvalidOperationException

In the event you attempt to call this method from a shape which has no points, it will throw an InvalidOperationException.

ValidateCore(ShapeValidationMode)

This method returns a ShapeValidationResult based on a series of tests.

protected override ShapeValidationResult ValidateCore(ShapeValidationMode validationMode)

Parameters

validationMode ShapeValidationMode

This parameter determines whether the test is simple or advanced. In some cases, the advanced tests can take some time. The simple test is designed to always be fast.

Returns

ShapeValidationResult

This method returns a ShapeValidationResult based on a series of tests.

Remarks

We use this method, with the simple enumeration, internally before doing any kind of other methods on the shape. In this way, we are able to verify the integrity of the shape itself. If you wish to test things such as whether a polygon self-intersects, we invite you to call this method with the advanced ShapeValidationMode. One thing to consider is that for complex polygon shapes this operation could take some time, which is why we only run the basic, faster test. If you are dealing with polygon shapes that are suspect, we suggest you run the advanced test.

Overriding:

Please ensure that you validate the parameters being passed in and raise the exceptions defined above.

Exceptions

ArgumentOutOfRangeException

If you pass in a validationMode that is not defined in the enumeration, it will throw a ArgumentOutOfRangeException.