54 lines
1.1 KiB
Text
54 lines
1.1 KiB
Text
|
/**
|
||
|
* PANDA 3D SOFTWARE
|
||
|
* Copyright (c) Carnegie Mellon University. All rights reserved.
|
||
|
*
|
||
|
* All use of this software is subject to the terms of the revised BSD
|
||
|
* license. You should have received a copy of this license along
|
||
|
* with this source code in a file named "LICENSE."
|
||
|
*
|
||
|
* @file boundingLine.I
|
||
|
* @author drose
|
||
|
* @date 2000-07-04
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
*
|
||
|
*/
|
||
|
INLINE_MATHUTIL BoundingLine::
|
||
|
BoundingLine() {
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
*
|
||
|
*/
|
||
|
INLINE_MATHUTIL BoundingLine::
|
||
|
BoundingLine(const LPoint3 &a, const LPoint3 &b) :
|
||
|
_origin(a), _vector(b - a)
|
||
|
{
|
||
|
_vector.normalize();
|
||
|
_flags = 0;
|
||
|
nassertd(!_origin.is_nan() && !_vector.is_nan()) {
|
||
|
_flags = F_empty;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the first point that defines the line.
|
||
|
*/
|
||
|
INLINE_MATHUTIL const LPoint3 &BoundingLine::
|
||
|
get_point_a() const {
|
||
|
nassertr(!is_empty(), _origin);
|
||
|
nassertr(!is_infinite(), _origin);
|
||
|
return _origin;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the second point that defines the line.
|
||
|
*/
|
||
|
INLINE_MATHUTIL LPoint3 BoundingLine::
|
||
|
get_point_b() const {
|
||
|
nassertr(!is_empty(), _origin);
|
||
|
nassertr(!is_infinite(), _origin);
|
||
|
return _origin + _vector;
|
||
|
}
|