143 lines
3.6 KiB
Text
143 lines
3.6 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 lineSegs.I
|
||
|
* @author drose
|
||
|
* @date 2002-03-16
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
*
|
||
|
*/
|
||
|
INLINE LineSegs::Point::
|
||
|
Point() {
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
*
|
||
|
*/
|
||
|
INLINE LineSegs::Point::
|
||
|
Point(const LVecBase3 &point, const LColor &color) :
|
||
|
_point(point[0], point[1], point[2]),
|
||
|
_color(color)
|
||
|
{
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
*
|
||
|
*/
|
||
|
INLINE LineSegs::Point::
|
||
|
Point(const LineSegs::Point ©) :
|
||
|
_point(copy._point),
|
||
|
_color(copy._color)
|
||
|
{
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
*
|
||
|
*/
|
||
|
INLINE void LineSegs::Point::
|
||
|
operator = (const LineSegs::Point ©) {
|
||
|
_point = copy._point;
|
||
|
_color = copy._color;
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* Establishes the color that will be assigned to all vertices created by
|
||
|
* future calls to move_to() and draw_to().
|
||
|
*/
|
||
|
INLINE void LineSegs::
|
||
|
set_color(PN_stdfloat r, PN_stdfloat g, PN_stdfloat b, PN_stdfloat a) {
|
||
|
_color.set(r, g, b, a);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Establishes the color that will be assigned to all vertices created by
|
||
|
* future calls to move_to() and draw_to().
|
||
|
*/
|
||
|
INLINE void LineSegs::
|
||
|
set_color(const LColor &color) {
|
||
|
_color = color;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Establishes the line thickness or point size in pixels that will be
|
||
|
* assigned to all lines and points created by future calls to create().
|
||
|
*/
|
||
|
INLINE void LineSegs::
|
||
|
set_thickness(PN_stdfloat thick) {
|
||
|
_thick = thick;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Moves the pen to the given point without drawing a line. When followed by
|
||
|
* draw_to(), this marks the first point of a line segment; when followed by
|
||
|
* move_to() or create(), this creates a single point.
|
||
|
*/
|
||
|
INLINE void LineSegs::
|
||
|
move_to(PN_stdfloat x, PN_stdfloat y, PN_stdfloat z) {
|
||
|
move_to(LVertex(x, y, z));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Draws a line segment from the pen's last position (the last call to move_to
|
||
|
* or draw_to) to the indicated point. move_to() and draw_to() only update
|
||
|
* tables; the actual drawing is performed when create() is called.
|
||
|
*/
|
||
|
INLINE void LineSegs::
|
||
|
draw_to(PN_stdfloat x, PN_stdfloat y, PN_stdfloat z) {
|
||
|
draw_to(LVertex(x, y, z));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Creates a new GeomNode that will render the series of line segments and
|
||
|
* points described via calls to move_to() and draw_to(). The lines and
|
||
|
* points are created with the color and thickness established by calls to
|
||
|
* set_color() and set_thick().
|
||
|
*
|
||
|
* If dynamic is true, the line segments will be created with the dynamic Geom
|
||
|
* setting, optimizing them for runtime vertex animation.
|
||
|
*/
|
||
|
INLINE GeomNode *LineSegs::
|
||
|
create(bool dynamic) {
|
||
|
GeomNode *gnode = new GeomNode(get_name());
|
||
|
return create(gnode, dynamic);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the total number of line segment and point vertices generated by
|
||
|
* the last call to create(). The positions of these vertices may be read and
|
||
|
* adjusted through get_vertex() and set_vertex().
|
||
|
*/
|
||
|
INLINE int LineSegs::
|
||
|
get_num_vertices() const {
|
||
|
if (_created_data == nullptr) {
|
||
|
return 0;
|
||
|
}
|
||
|
return _created_data->get_num_rows();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Moves the nth point or vertex of the line segment sequence generated by the
|
||
|
* last call to create(). The first move_to() generates vertex 0; subsequent
|
||
|
* move_to() and draw_to() calls generate consecutively higher vertex numbers.
|
||
|
*/
|
||
|
INLINE void LineSegs::
|
||
|
set_vertex(int n, PN_stdfloat x, PN_stdfloat y, PN_stdfloat z) {
|
||
|
set_vertex(n, LVertex(x, y, z));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Changes the vertex color of the nth point or vertex. See set_vertex().
|
||
|
*/
|
||
|
INLINE void LineSegs::
|
||
|
set_vertex_color(int n, PN_stdfloat r, PN_stdfloat g, PN_stdfloat b, PN_stdfloat a) {
|
||
|
set_vertex_color(n, LColor(r, g, b, a));
|
||
|
}
|