30 #if MRPT_HAS_OPENGL_GLUT 36 GLUquadricObj*
obj = gluNewQuadric();
38 gluDisk(
obj, m_radiusIn, m_radiusOut, m_nSlices, m_nLoops);
40 gluDeleteQuadric(
obj);
49 writeToStreamRender(out);
50 out << m_radiusIn << m_radiusOut;
51 out << m_nSlices << m_nLoops;
60 readFromStreamRender(
in);
61 in >> m_radiusIn >> m_radiusOut;
81 CPose3D transf = this->m_pose - o;
82 double x = transf.
x(),
y = transf.
y(),
z = transf.z(),
w = transf.
yaw(),
84 double coef = sin(
w) * sin(
r) + cos(
w) * sin(
p) * cos(
r);
90 if (coef == 0)
return false;
94 dist =
x + (
y * (sin(
p) * sin(
w) * cos(
r) - cos(
w) * sin(
r)) +
95 z * cos(
p) * cos(
r)) /
97 if (dist < 0)
return false;
99 double d2 = (
x - dist) * (
x - dist) +
y *
y +
z *
z;
100 return d2 >= (m_radiusIn * m_radiusIn) && d2 <= (m_radiusOut * m_radiusOut);
109 bb_min.x = -std::max(m_radiusIn, m_radiusOut);
113 bb_max.x = std::max(m_radiusIn, m_radiusOut);
void notifyChange() const
Must be called to notify that the object has changed (so, the display list must be updated) ...
GLAPI void GLAPIENTRY glEnable(GLenum cap)
#define IMPLEMENTS_SERIALIZABLE(class_name, base, NameSpace)
To be added to all CSerializable-classes implementation files.
uint8_t serializeGetVersion() const override
Must return the current versioning number of the object.
void getBoundingBox(mrpt::math::TPoint3D &bb_min, mrpt::math::TPoint3D &bb_max) const override
Evaluates the bounding box of this object (including possible children) in the coordinate frame of th...
double pitch() const
Get the PITCH angle (in radians)
double yaw() const
Get the YAW angle (in radians)
#define GL_ONE_MINUS_SRC_ALPHA
GLsizei GLsizei GLuint * obj
void serializeFrom(mrpt::serialization::CArchive &in, uint8_t serial_version) override
Pure virtual method for reading (deserializing) from an abstract archive.
GLubyte GLubyte GLubyte GLubyte w
GLAPI void GLAPIENTRY glBlendFunc(GLenum sfactor, GLenum dfactor)
A renderizable object suitable for rendering with OpenGL's display lists.
#define MRPT_THROW_UNKNOWN_SERIALIZATION_VERSION(__V)
For use in CSerializable implementations.
A planar disk in the XY plane.
void serializeTo(mrpt::serialization::CArchive &out) const override
Pure virtual method for writing (serializing) to an abstract archive.
double x() const
Common members of all points & poses classes.
double roll() const
Get the ROLL angle (in radians)
This is the global namespace for all Mobile Robot Programming Toolkit (MRPT) libraries.
Virtual base class for "archives": classes abstracting I/O streams.
GLdouble GLdouble GLdouble r
A class used to store a 3D pose (a 3D translation + a rotation in 3D).
void checkOpenGLError()
Checks glGetError and throws an exception if an error situation is found.
The namespace for 3D scene representation and rendering.
typedef void(APIENTRYP PFNGLBLENDCOLORPROC)(GLclampf red
GLAPI void GLAPIENTRY glDisable(GLenum cap)
bool traceRay(const mrpt::poses::CPose3D &o, double &dist) const override
Ray tracing.