Public Member Functions | Public Attributes

CL_LineSegment2d Class Reference
[clanCore Math]

2D line segment - Double More...

#include <line_segment.h>

Inheritance diagram for CL_LineSegment2d:
Inheritance graph
[legend]

List of all members.

Public Member Functions

 CL_LineSegment2d ()
 CL_LineSegment2d (const CL_Vec2< double > &point_p, const CL_Vec2< double > &point_q)
 CL_LineSegment2d (const CL_LineSegment2x< double > &copy)
Attributes

CL_Vec2< double > get_midpoint () const
 Get the midpoint of this line.
double point_distance (const CL_Vec2< double > &point)
 Return the distance from a point to a line.
bool collinear (const CL_LineSegment2x< double > &second) const
 Return true if two line segments are collinear. (All points are on the same line.).
bool intersects (const CL_LineSegment2x< double > &second, bool collinear_intersect) const
 Return true if two line segments intersect.
CL_Vec2< double > get_intersection (const CL_LineSegment2x< double > &second, bool &intersect) const
 Return the intersection point of two lines.
double point_right_of_line (const CL_Vec2< double > &point) const
 Return [<0, 0, >0] if the Point P is right, on or left of the line trough A,B.
CL_Vec2< double > normal () const
 Return the normal vector of the line from point A to point B.
Operations

CL_LineSegment2x< double > & clip (const CL_Rectx< double > &rect, bool &clipped)
 Clip this line to a rectangle.
Operators

bool operator== (const CL_LineSegment2x< double > &line) const
 == operator.
bool operator!= (const CL_LineSegment2x< double > &line) const
 != operator.

Public Attributes

CL_Vec2< double > p
 Start point on the line.
CL_Vec2< double > q

Detailed Description

2D line segment - Double

A line segment has a start point and an end point


Constructor & Destructor Documentation

CL_LineSegment2d::CL_LineSegment2d (  )  [inline]
CL_LineSegment2d::CL_LineSegment2d ( const CL_LineSegment2x< double > &  copy  )  [inline]
CL_LineSegment2d::CL_LineSegment2d ( const CL_Vec2< double > &  point_p,
const CL_Vec2< double > &  point_q 
) [inline]

Member Function Documentation

CL_LineSegment2x<double >& CL_LineSegment2x< double >::clip ( const CL_Rectx< double > &  rect,
bool &  clipped 
) [inherited]

Clip this line to a rectangle.

If clipping was not successful, this object is undefined

Parameters:
rect = Rectangle to clip to
clipped = On Return: true if the line could be clipped, false if line exists outside the rectangle
Returns:
reference to this object
bool CL_LineSegment2x< double >::collinear ( const CL_LineSegment2x< double > &  second  )  const [inherited]

Return true if two line segments are collinear. (All points are on the same line.).

Parameters:
second = The second line to check with
Returns:
true = They are collinear
CL_Vec2<double > CL_LineSegment2x< double >::get_intersection ( const CL_LineSegment2x< double > &  second,
bool &  intersect 
) const [inherited]

Return the intersection point of two lines.

Parameters:
second = Second line.
intersect = On Return: The intercept. If the lines are parallel, this contains this line's first point
Returns:
true if the lines intersect, false if the lines are parallel
CL_Vec2<double > CL_LineSegment2x< double >::get_midpoint (  )  const [inline, inherited]

Get the midpoint of this line.

Returns:
The midpoint
bool CL_LineSegment2x< double >::intersects ( const CL_LineSegment2x< double > &  second,
bool  collinear_intersect 
) const [inherited]

Return true if two line segments intersect.

Parameters:
second = Second line.
collinear_intersect = true if a collision is reported when all points are on the same line.
Returns:
true = Intersects
CL_Vec2<double > CL_LineSegment2x< double >::normal (  )  const [inherited]

Return the normal vector of the line from point A to point B.

When using CL_Vec2i, the vector is an 8 bit fraction (multiplied by 256)

Returns:
The normal vector
bool CL_LineSegment2x< double >::operator!= ( const CL_LineSegment2x< double > &  line  )  const [inline, inherited]

!= operator.

bool CL_LineSegment2x< double >::operator== ( const CL_LineSegment2x< double > &  line  )  const [inline, inherited]

== operator.

double CL_LineSegment2x< double >::point_distance ( const CL_Vec2< double > &  point  )  [inherited]

Return the distance from a point to a line.

Parameters:
point = The point.
double CL_LineSegment2x< double >::point_right_of_line ( const CL_Vec2< double > &  point  )  const [inline, inherited]

Return [<0, 0, >0] if the Point P is right, on or left of the line trough A,B.

Parameters:
point = The point
Returns:
Value representing - left (>0), centre (=0), or right (<0)

Member Data Documentation

CL_Vec2<double > CL_LineSegment2x< double >::p [inherited]

Start point on the line.

CL_Vec2<double > CL_LineSegment2x< double >::q [inherited]

The documentation for this class was generated from the following file: