Chemical Data Processing Library Python API - Version 1.1.0
|
Specifies a line segment in 2D space. More...
Public Member Functions | |
None | __init__ () |
Constructs a line whose starting and end point is set to (0, 0). | |
None | __init__ (Line2D line) |
Initializes a copy of the Line2D instance line. More... | |
None | __init__ (Math.Vector2D beg, Math.Vector2D end) |
Constructs a line with the specified starting and end point. More... | |
None | __init__ (float beg_x, float beg_y, float end_x, float end_y) |
Constructs a line with the starting point set to (beg_x, beg_y) and the end point set to (end_x, end_y). More... | |
int | getObjectID () |
Returns the numeric identifier (ID) of the wrapped C++ class instance. More... | |
Line2D | assign (Line2D line) |
Replaces the current state of self with a copy of the state of the Line2D instance line. More... | |
None | setBegin (Math.Vector2D pt) |
Sets the starting point of the line to pt. More... | |
None | setBegin (float x, float y) |
Sets the starting point of the line to (x, y). More... | |
Math.Vector2D | getBegin () |
Returns the starting point of the line. More... | |
None | setEnd (Math.Vector2D pt) |
Sets the end point of the line to pt. More... | |
None | setEnd (float x, float y) |
Sets the end point of the line to (x, y). More... | |
Math.Vector2D | getEnd () |
Returns the end point of the line. More... | |
None | setPoints (Math.Vector2D beg, Math.Vector2D end) |
Sets the starting point of the line to beg and the end point to end. More... | |
None | setPoints (float beg_x, float beg_y, float end_x, float end_y) |
Sets the starting point of the line to (beg_x, beg_y) and the end point to (end_x, end_y). More... | |
None | swapPoints () |
Swaps the starting and end point of the line. More... | |
Math.Vector2D | getDirection () |
Calculates the normalized direction vector of the line. More... | |
None | getDirection (Math.Vector2D dir) |
Calculates the normalized direction vector of the line and stores the result in dir. More... | |
Math.Vector2D | getCCWPerpDirection () |
Calculates the normalized direction vector rotated by 90 degrees in counter-clockwise direction. More... | |
None | getCCWPerpDirection (Math.Vector2D dir) |
Calculates the normalized direction vector rotated by 90 degrees in counter-clockwise direction and stores the result in dir. More... | |
Math.Vector2D | getCWPerpDirection () |
Calculates the normalized direction vector rotated by 90 degrees in clockwise direction. More... | |
None | getCWPerpDirection (Math.Vector2D dir) |
Calculates the normalized direction vector rotated by 90 degrees in clockwise direction and stores the result in dir. More... | |
Math.Vector2D | getCenter () |
Calculates the center point of the line. More... | |
None | getCenter (Math.Vector2D ctr) |
Calculates the center point of the line and stores the result in ctr. More... | |
float | getLength () |
Returns the length of the line segment. More... | |
None | translate (Math.Vector2D vec) |
Translates the starting and end point of the line by vec. More... | |
None | translateBegin (Math.Vector2D vec) |
Translates the starting point of the line by vec. More... | |
None | translateEnd (Math.Vector2D vec) |
Translates the end of the line point by vec. More... | |
bool | containsPoint (Math.Vector2D pt) |
Tests if the point pt is contained within the boundary of the line segment. More... | |
object | getIntersectionPoint (Line2D pt) |
bool | clipBeginAgainstLineSeg (Line2D line) |
Sets the starting point of the line to the point of intersection with the specified line segment. More... | |
bool | clipEndAgainstLineSeg (Line2D line) |
Sets the end point of the line to the point of intersection with the specified line segment. More... | |
bool | setBeginToLineSegIntersection (Line2D line) |
Sets the starting point of the line to the point of intersection with the specified line segment. More... | |
bool | setEndToLineSegIntersection (Line2D line) |
Sets the end point of the line to the point of intersection with the specified line segment. More... | |
bool | clipBeginAgainstRectangle (Rectangle2D rect) |
Sets the starting point of the line to the point of intersection between this line segment and the edges of the rectangle rect. More... | |
bool | clipEndAgainstRectangle (Rectangle2D rect) |
Sets the end point of the line to the point of intersection between this line segment and the edges of the rectangle rect. More... | |
float | getDistance (Math.Vector2D pt) |
Returns the perpendicular distance of the point pt to this line. More... | |
bool | __eq__ (Line2D line) |
Equality comparison operator. More... | |
bool | __ne__ (Line2D line) |
Inequality comparison operator. More... | |
bool | __contains__ (Math.Vector2D pt) |
Returns the result of the membership test operation pt in self . More... | |
Properties | |
objectID = property(getObjectID) | |
length = property(getLength) | |
begin = property(getBegin, setBegin) | |
end = property(getEnd, setEnd) | |
direction = property(getDirection) | |
ccwPerpDirection = property(getCCWPerpDirection) | |
cwPerpDirection = property(getCWPerpDirection) | |
center = property(getCenter) | |
Specifies a line segment in 2D space.
None CDPL.Vis.Line2D.__init__ | ( | Line2D | line | ) |
Initializes a copy of the Line2D instance line.
line | The Line2D instance to copy. |
Reimplemented in CDPL.Vis.LinePrimitive2D.
None CDPL.Vis.Line2D.__init__ | ( | Math.Vector2D | beg, |
Math.Vector2D | end | ||
) |
Constructs a line with the specified starting and end point.
beg | The starting point. |
end | The end point. |
Reimplemented in CDPL.Vis.LinePrimitive2D.
None CDPL.Vis.Line2D.__init__ | ( | float | beg_x, |
float | beg_y, | ||
float | end_x, | ||
float | end_y | ||
) |
Constructs a line with the starting point set to (beg_x, beg_y) and the end point set to (end_x, end_y).
beg_x | The x-coordinate of the starting point. |
beg_y | The y-coordinate of the starting point. |
end_x | The x-coordinate of the end point. |
end_y | The y-coordinate of the end point. |
int CDPL.Vis.Line2D.getObjectID | ( | ) |
Returns the numeric identifier (ID) of the wrapped C++ class instance.
Different Python Line2D instances may reference the same underlying C++ class instance. The commonly used Python expression a is not b
thus cannot tell reliably whether the two Line2D instances a and b reference different C++ objects. The numeric identifier returned by this method allows to correctly implement such an identity test via the simple expression a.getObjectID() != b.getObjectID()
.
Replaces the current state of self with a copy of the state of the Line2D instance line.
line | The Line2D instance to copy. |
None CDPL.Vis.Line2D.setBegin | ( | Math.Vector2D | pt | ) |
Sets the starting point of the line to pt.
pt | The new starting point of the line. |
None CDPL.Vis.Line2D.setBegin | ( | float | x, |
float | y | ||
) |
Sets the starting point of the line to (x, y).
x | The x-coordinate of the new starting point. |
y | The y-coordinate of the new starting point. |
Math.Vector2D CDPL.Vis.Line2D.getBegin | ( | ) |
Returns the starting point of the line.
None CDPL.Vis.Line2D.setEnd | ( | Math.Vector2D | pt | ) |
Sets the end point of the line to pt.
pt | The new end point of the line. |
None CDPL.Vis.Line2D.setEnd | ( | float | x, |
float | y | ||
) |
Sets the end point of the line to (x, y).
x | The x-coordinate of the new end point. |
y | The y-coordinate of the new end point. |
Math.Vector2D CDPL.Vis.Line2D.getEnd | ( | ) |
Returns the end point of the line.
None CDPL.Vis.Line2D.setPoints | ( | Math.Vector2D | beg, |
Math.Vector2D | end | ||
) |
Sets the starting point of the line to beg and the end point to end.
beg | The new starting point. |
end | The new end point. |
None CDPL.Vis.Line2D.setPoints | ( | float | beg_x, |
float | beg_y, | ||
float | end_x, | ||
float | end_y | ||
) |
Sets the starting point of the line to (beg_x, beg_y) and the end point to (end_x, end_y).
beg_x | The x-coordinate of the new starting point. |
beg_y | The y-coordinate of the new starting point. |
end_x | The x-coordinate of the new end point. |
end_y | The y-coordinate of the new end point. |
None CDPL.Vis.Line2D.swapPoints | ( | ) |
Swaps the starting and end point of the line.
The old starting point becomes the new end point and the old end point becomes the new starting point.
Math.Vector2D CDPL.Vis.Line2D.getDirection | ( | ) |
Calculates the normalized direction vector of the line.
None CDPL.Vis.Line2D.getDirection | ( | Math.Vector2D | dir | ) |
Calculates the normalized direction vector of the line and stores the result in dir.
dir | Holds the calculated direction vector. |
Math.Vector2D CDPL.Vis.Line2D.getCCWPerpDirection | ( | ) |
Calculates the normalized direction vector rotated by 90 degrees in counter-clockwise direction.
None CDPL.Vis.Line2D.getCCWPerpDirection | ( | Math.Vector2D | dir | ) |
Calculates the normalized direction vector rotated by 90 degrees in counter-clockwise direction and stores the result in dir.
dir | Holds the calculated rotated direction vector. |
Math.Vector2D CDPL.Vis.Line2D.getCWPerpDirection | ( | ) |
Calculates the normalized direction vector rotated by 90 degrees in clockwise direction.
None CDPL.Vis.Line2D.getCWPerpDirection | ( | Math.Vector2D | dir | ) |
Calculates the normalized direction vector rotated by 90 degrees in clockwise direction and stores the result in dir.
dir | Holds the calculated rotated direction vector. |
Math.Vector2D CDPL.Vis.Line2D.getCenter | ( | ) |
Calculates the center point of the line.
None CDPL.Vis.Line2D.getCenter | ( | Math.Vector2D | ctr | ) |
Calculates the center point of the line and stores the result in ctr.
ctr | Holds the calculated center point of the line. |
float CDPL.Vis.Line2D.getLength | ( | ) |
Returns the length of the line segment.
None CDPL.Vis.Line2D.translate | ( | Math.Vector2D | vec | ) |
Translates the starting and end point of the line by vec.
vec | The translation vector. |
None CDPL.Vis.Line2D.translateBegin | ( | Math.Vector2D | vec | ) |
Translates the starting point of the line by vec.
vec | The translation vector. |
None CDPL.Vis.Line2D.translateEnd | ( | Math.Vector2D | vec | ) |
Translates the end of the line point by vec.
vec | The translation vector. |
bool CDPL.Vis.Line2D.containsPoint | ( | Math.Vector2D | pt | ) |
Tests if the point pt is contained within the boundary of the line segment.
The point pt is considered to be contained within the boundary of the line segment if the dot product of the line's direction vector and the vector from the starting point to pt is positive or zero, and furthermore the dot product of the direction vector and the vector from the end point to pt is negative or zero.
pt | The point to test. |
True
if pt is contained within the boundary of the line segment, and False
otherwise. object CDPL.Vis.Line2D.getIntersectionPoint | ( | Line2D | pt | ) |
pt |
bool CDPL.Vis.Line2D.clipBeginAgainstLineSeg | ( | Line2D | line | ) |
Sets the starting point of the line to the point of intersection with the specified line segment.
If the lines are parallel or the point of intersection is not within the boundaries of both line segments, the starting point of the line is left unaltered and False
is returned.
line | The other line segment to clip against. |
False
if the lines are parallel or the intersection point is not within the boundaries of both line segments, and True
otherwise. bool CDPL.Vis.Line2D.clipEndAgainstLineSeg | ( | Line2D | line | ) |
Sets the end point of the line to the point of intersection with the specified line segment.
If the lines are parallel or the point of intersection is not within the boundaries of both line segments, the end point of the line is left unaltered and False
is returned.
line | The other line segment to clip against. |
False
if the lines are parallel or the intersection point is not within the boundaries of both line segments, and True
otherwise. bool CDPL.Vis.Line2D.setBeginToLineSegIntersection | ( | Line2D | line | ) |
Sets the starting point of the line to the point of intersection with the specified line segment.
If the lines are parallel or the point of intersection is not within the boundary of the line segment line, the starting point of the line is left unaltered and False
is returned.
line | The other line segment. |
False
if the lines are parallel or the intersection point is not within the boundary of line, and True
otherwise. bool CDPL.Vis.Line2D.setEndToLineSegIntersection | ( | Line2D | line | ) |
Sets the end point of the line to the point of intersection with the specified line segment.
If the lines are parallel or the point of intersection is not within the boundary of the line segment line, the end point of the line is left unaltered and False
is returned.
line | The other line segment. |
False
if the lines are parallel or the intersection point is not within the boundary of line, and True
otherwise. bool CDPL.Vis.Line2D.clipBeginAgainstRectangle | ( | Rectangle2D | rect | ) |
Sets the starting point of the line to the point of intersection between this line segment and the edges of the rectangle rect.
If the line segment intersects with more than one edge of rect, the starting point is set to the intersection point which results in the shortest clipped line segment. If the line segment does not intersect with an edge of rect, the starting point is left unaltered and False
is returned.
rect | The rectangle to clip againts. |
True
if the line segment was clipped against an edge of rect, and False
otherwise. bool CDPL.Vis.Line2D.clipEndAgainstRectangle | ( | Rectangle2D | rect | ) |
Sets the end point of the line to the point of intersection between this line segment and the edges of the rectangle rect.
If the line segment intersects with more than one edge of rect, the end point is set to the intersection point which results in the shortest clipped line segment. If the line segment does not intersect with an edge of rect, the end point is left unaltered and False
is returned.
rect | The rectangle to clip againts. |
True
if the line segment was clipped against an edge of rect, and False
otherwise. float CDPL.Vis.Line2D.getDistance | ( | Math.Vector2D | pt | ) |
Returns the perpendicular distance of the point pt to this line.
The measured distance is the distance between the point pt and the closest point on the infinitely extended line. If pt intersects the line, the method returns 0.0.
pt | The point for which to calculate the shortest distance. |
bool CDPL.Vis.Line2D.__eq__ | ( | Line2D | line | ) |
Equality comparison operator.
line | The other Line2D object to be compared with. |
True
if the starting and end points compare equal, and False
otherwise. bool CDPL.Vis.Line2D.__ne__ | ( | Line2D | line | ) |
Inequality comparison operator.
The result is equivalent to !(self == line)
.
line | The other Line2D object to be compared with. |
True
if either the starting or end points compare non-equal, and False
otherwise. bool CDPL.Vis.Line2D.__contains__ | ( | Math.Vector2D | pt | ) |
Returns the result of the membership test operation pt in self
.
pt | The value to test for membership. |