LuciadCPillar 2023.1.04
luciad::CircularArcByCenterPoint Class Referencefinal

Represents a circular arc defined by a center point, radius, start angle, end angle, and angle direction. More...

#include <luciad/geometries/CircularArcByCenterPoint.h>

Inheritance diagram for luciad::CircularArcByCenterPoint:
luciad::Curve luciad::Geometry

Public Member Functions

 ~CircularArcByCenterPoint () override
 
Coordinate computePoint (double parameter) const override
 Computes a point of the curve, defined by the given parameter. More...
 
Angle::Direction getAngleDirection () const
 Returns the orientation of the arc. More...
 
Bounds getBounds () const override
 Returns the bounds for the geometry object. More...
 
Coordinate getCenter () const
 Returns the center of the circular arc. More...
 
luciad::Angle getEndAngle () const
 Returns the end angle of the circular arc. More...
 
double getLength2D () const override
 Returns the length of the curve. More...
 
double getRadius () const
 Returns the radius of the circular arc. More...
 
std::shared_ptr< luciad::CoordinateReferencegetReference () const override
 Returns the coordinate reference of the geometry. More...
 
luciad::Angle getStartAngle () const
 Returns the start angle of the circular arc. More...
 
virtual Coordinate computePoint (double parameter) const =0
 Computes a point of the curve, defined by the given parameter. More...
 
virtual double getLength2D () const =0
 Returns the length of the curve. More...
 
- Public Member Functions inherited from luciad::Geometry
virtual ~Geometry ()=default
 
virtual Bounds getBounds () const =0
 Returns the bounds for the geometry object. More...
 
virtual std::shared_ptr< CoordinateReferencegetReference () const =0
 Returns the coordinate reference of the geometry. More...
 

Protected Member Functions

size_t getHash () const override
 Returns the hash value for this geometry. More...
 
virtual size_t getHash () const =0
 Returns the hash value for this geometry. More...
 

Detailed Description

Represents a circular arc defined by a center point, radius, start angle, end angle, and angle direction.

See also
GeometryFactory::createCircularArcByCenterPoint

Constructor & Destructor Documentation

◆ ~CircularArcByCenterPoint()

luciad::CircularArcByCenterPoint::~CircularArcByCenterPoint ( )
override

Member Function Documentation

◆ computePoint()

Coordinate luciad::CircularArcByCenterPoint::computePoint ( double  parameter) const
overridevirtual

Computes a point of the curve, defined by the given parameter.

  1. At parameter 0, the point is the start point of the curve.
  2. At parameter 1, the point is the end point of the curve.
Parameters
parameterthe parameter value, within [0,1], to compute the point location for.
Returns
the computed point location.
Exceptions
luciad::InvalidArgumentExceptionif parameter is not within [0,1], or if the point could not be computed. For example, when the curve is defined by invalid points.

Implements luciad::Curve.

◆ getAngleDirection()

Angle::Direction luciad::CircularArcByCenterPoint::getAngleDirection ( ) const

Returns the orientation of the arc.

This property determines in which direction the arc extends from the start to the end angle.

Returns
the orientation of the arc.

◆ getBounds()

Bounds luciad::CircularArcByCenterPoint::getBounds ( ) const
overridevirtual

Returns the bounds for the geometry object.

Returns
the bounds for the geometry object.
Exceptions
luciad::InvalidArgumentExceptionif the bounds could not be computed. For example, when the geometry is defined by invalid points.

Implements luciad::Geometry.

◆ getCenter()

Coordinate luciad::CircularArcByCenterPoint::getCenter ( ) const

Returns the center of the circular arc.

Returns
the center of the circular arc.

◆ getEndAngle()

luciad::Angle luciad::CircularArcByCenterPoint::getEndAngle ( ) const

Returns the end angle of the circular arc.

Returns
the end angle of the circular arc.

◆ getHash()

size_t luciad::CircularArcByCenterPoint::getHash ( ) const
overrideprotectedvirtual

Returns the hash value for this geometry.

Returns
the hash value for this geometry.

Implements luciad::Geometry.

◆ getLength2D()

double luciad::CircularArcByCenterPoint::getLength2D ( ) const
overridevirtual

Returns the length of the curve.

Returns
the length of the curve.
Exceptions
luciad::InvalidArgumentExceptionif the length could not be computed. For example, when the curve is defined by invalid points.

Implements luciad::Curve.

◆ getRadius()

double luciad::CircularArcByCenterPoint::getRadius ( ) const

Returns the radius of the circular arc.

If the coordinate reference is a geodetic reference, this is expressed in meters. Otherwise the unit of the reference is used.

Returns
the radius of the circular arc.

◆ getReference()

std::shared_ptr< luciad::CoordinateReference > luciad::CircularArcByCenterPoint::getReference ( ) const
overridevirtual

Returns the coordinate reference of the geometry.

Returns
the coordinate reference of the geometry.

Implements luciad::Geometry.

◆ getStartAngle()

luciad::Angle luciad::CircularArcByCenterPoint::getStartAngle ( ) const

Returns the start angle of the circular arc.

Returns
the start angle of the circular arc.