Main MRPT website > C++ reference
MRPT logo
Classes | Public Types | Public Member Functions | Static Public Member Functions | Static Public Attributes | Protected Member Functions | Static Protected Member Functions | Protected Attributes | Private Types | Private Member Functions | Private Attributes | Friends
mrpt::opengl::CPointCloudColoured Class Reference

Detailed Description

A cloud of points, each one with an individual colour (R,G,B).

The alpha component is shared by all the points and is stored in the base member m_color_A.

To load from a points-map, CPointCloudColoured::loadFromPointsMap().

This class uses smart optimizations while rendering to efficiently draw clouds of millions of points, as described in this page: http://www.mrpt.org/Efficiently_rendering_point_clouds_of_millions_of_points

See also:
opengl::COpenGLScene, opengl::CPointCloud
mrpt::opengl::CPointCloudColoured
preview_CPointCloudColoured.png

#include <mrpt/opengl/CPointCloudColoured.h>

Inheritance diagram for mrpt::opengl::CPointCloudColoured:
Inheritance graph
[legend]

List of all members.

Classes

struct  TPointColour

Public Types

enum  

Public Member Functions

void render () const
 Render.
void render_subset (const bool all, const std::vector< size_t > &idxs, const float render_area_sqpixels) const
 Render a subset of points (required by octree renderer)
CRenderizableclone () const
 Interface for the stlplus smart pointer class.
virtual bool traceRay (const mrpt::poses::CPose3D &o, double &dist) const
 Simulation of ray-trace, given a pose.
mrpt::utils::CObjectPtr duplicateGetSmartPtr () const
 Returns a copy of the object, indepently of its class, as a smart pointer (the newly created object will exist as long as any copy of this smart pointer).
size_t octree_get_node_count () const
 Return the number of octree nodes (all of them, including the empty ones)
size_t octree_get_visible_nodes () const
 Return the number of visible octree nodes in the last render event.
void octree_mark_as_outdated ()
 Called from the derived class (or the user) to indicate we have/want to rebuild the entire node tree (for example, after modifying the point cloud or any global octree parameter)
void octree_get_graphics_boundingboxes (mrpt::opengl::CSetOfObjects &gl_bb, const double lines_width=1, const TColorf lines_color=TColorf(1, 1, 1)) const
 Returns a graphical representation of all the bounding boxes of the octree (leaf) nodes.
void octree_debug_dump_tree (std::ostream &o) const
 Used for debug only.
bool loadFromPlyFile (const std::string &filename, CStringList *file_comments=NULL, CStringList *file_obj_info=NULL)
 Loads from a PLY file.
std::string getLoadPLYErrorString () const
 Return a description of the error if loadFromPlyFile() returned false, or an empty string if the file was loaded without problems.
bool saveToPlyFile (const std::string &filename, bool save_in_binary=false, const CStringList &file_comments=CStringList(), const CStringList &file_obj_info=CStringList()) const
 Saves to a PLY file.
std::string getSavePLYErrorString () const
 Return a description of the error if loadFromPlyFile() returned false, or an empty string if the file was loaded without problems.
Read/Write of the list of points to render
void push_back (float x, float y, float z, float R, float G, float B)
 Inserts a new point into the point cloud.
void resize (size_t N)
 Set the number of points, with undefined contents.
void reserve (size_t N)
 Like STL std::vector's reserve.
const TPointColouroperator[] (size_t i) const
 Read access to each individual point (checks for "i" in the valid range only in Debug).
const TPointColourgetPoint (size_t i) const
 Read access to each individual point (checks for "i" in the valid range only in Debug).
mrpt::math::TPoint3Df getPointf (size_t i) const
 Read access to each individual point (checks for "i" in the valid range only in Debug).
void setPoint (size_t i, const TPointColour &p)
 Write an individual point (checks for "i" in the valid range only in Debug).
size_t size () const
 Return the number of points.
void clear ()
 Erase all the points.
template<class POINTSMAP >
void loadFromPointsMap (const POINTSMAP *m)
 Load the points from a points map (passed as a pointer), depending on the type of point map passed: for the case of a mrpt::slam::CColouredPointMap the colours of individual points will be also copied.
size_t getActuallyRendered () const
 Get the number of elements actually rendered in the last render event.
Modify the appearance of the rendered points
void setPointSize (float pointSize)
float getPointSize () const
void enablePointSmooth (bool enable=true)
void disablePointSmooth ()
bool isPointSmoothEnabled () const
Changes the appearance of the object to render
void setName (const std::string &n)
 Changes the name of the object.
const std::stringgetName () const
 Returns the name of the object.
bool isVisible () const
 Is the object visible?
void setVisibility (bool visible=true)
 Set object visibility (default=true)
void enableShowName (bool showName=true)
 Enables or disables showing the name of the object as a label when rendering.
bool isShowNameEnabled () const
CRenderizablesetPose (const mrpt::poses::CPose3D &o)
 Set the 3D pose from a mrpt::poses::CPose3D object (return a ref to this)
CRenderizablesetPose (const mrpt::math::TPose3D &o)
 Set the 3D pose from a mrpt::math::TPose3D object (return a ref to this)
CRenderizablesetPose (const mrpt::poses::CPoint3D &o)
 Set the 3D pose from a mrpt::poses::CPose3D object (return a ref to this)
CRenderizablesetPose (const mrpt::poses::CPoint2D &o)
 Set the 3D pose from a mrpt::poses::CPose3D object (return a ref to this)
mrpt::math::TPose3D getPose () const
 Returns the 3D pose of the object as TPose3D.
const mrpt::poses::CPose3DgetPoseRef () const
 Returns a const ref to the 3D pose of the object as CPose3D (which explicitly contains the 3x3 rotation matrix)
CRenderizablesetLocation (double x, double y, double z)
 Changes the location of the object, keeping untouched the orientation.
CRenderizablesetLocation (const mrpt::math::TPoint3D &p)
 Changes the location of the object, keeping untouched the orientation.
double getPoseX () const
 Translation relative to parent coordinate origin.
double getPoseY () const
 Translation relative to parent coordinate origin.
double getPoseZ () const
 Translation relative to parent coordinate origin.
double getPoseYaw () const
 Rotation relative to parent coordinate origin, in **DEGREES**.
double getPosePitch () const
 Rotation relative to parent coordinate origin, in **DEGREES**.
double getPoseRoll () const
 Rotation relative to parent coordinate origin, in **DEGREES**.
double getPoseYawRad () const
 Rotation relative to parent coordinate origin, in radians.
double getPosePitchRad () const
 Rotation relative to parent coordinate origin, in radians.
double getPoseRollRad () const
 Rotation relative to parent coordinate origin, in radians.
double getColorR () const
 Color components in the range [0,1].
double getColorG () const
 Color components in the range [0,1].
double getColorB () const
 Color components in the range [0,1].
double getColorA () const
 Color components in the range [0,1].
uint8_t getColorR_u8 () const
 Color components in the range [0,255].
uint8_t getColorG_u8 () const
 Color components in the range [0,255].
uint8_t getColorB_u8 () const
 Color components in the range [0,255].
uint8_t getColorA_u8 () const
 Color components in the range [0,255].
CRenderizablesetColorR (const double r)
 Color components in the range [0,1].
CRenderizablesetColorG (const double g)
 Color components in the range [0,1].
CRenderizablesetColorB (const double b)
 Color components in the range [0,1].
CRenderizablesetColorA (const double a)
 Color components in the range [0,1].
virtual CRenderizablesetColorR_u8 (const uint8_t r)
 Color components in the range [0,255].
virtual CRenderizablesetColorG_u8 (const uint8_t g)
 Color components in the range [0,255].
virtual CRenderizablesetColorB_u8 (const uint8_t b)
 Color components in the range [0,255].
virtual CRenderizablesetColorA_u8 (const uint8_t a)
 Color components in the range [0,255].
CRenderizablesetScale (float s)
 Scale to apply to the object, in all three axes (default=1)
CRenderizablesetScale (float sx, float sy, float sz)
 Scale to apply to the object in each axis (default=1)
float getScaleX () const
 Get the current scaling factor in one axis.
float getScaleY () const
 Get the current scaling factor in one axis.
float getScaleZ () const
 Get the current scaling factor in one axis.
mrpt::utils::TColorf getColor () const
 Returns the object color property as a TColorf.
CRenderizablesetColor (const mrpt::utils::TColorf &c)
CRenderizablesetColor (double R, double G, double B, double A=1)
 Set the color components of this object (R,G,B,Alpha, in the range 0-1)
const mrpt::utils::TColorgetColor_u8 () const
 Returns the object color property as a TColor.
virtual CRenderizablesetColor_u8 (const mrpt::utils::TColor &c)
CRenderizablesetColor_u8 (uint8_t R, uint8_t G, uint8_t B, uint8_t A=255)
 Set the color components of this object (R,G,B,Alpha, in the range 0-1)

Static Public Member Functions

static void renderTextBitmap (const char *str, void *fontStyle)
 This method is safe for calling from within ::render() methods.
static void renderTextBitmap (int screen_x, int screen_y, const std::string &str, float color_r=1, float color_g=1, float color_b=1, mrpt::opengl::TOpenGLFont font=mrpt::opengl::MRPT_GLUT_BITMAP_TIMES_ROMAN_24)
 Render a text message in the current rendering context, creating a glViewport in the way (do not call within ::render() methods)
static int textBitmapWidth (const std::string &str, mrpt::opengl::TOpenGLFont font=mrpt::opengl::MRPT_GLUT_BITMAP_TIMES_ROMAN_24)
 Return the exact width in pixels for a given string, as will be rendered by renderTextBitmap().

Static Public Attributes

static const
mrpt::utils::TRuntimeClassId 
classCObject
RTTI stuff
static const
mrpt::utils::TRuntimeClassId 
classCSerializable

Protected Member Functions

void writeToStreamRender (utils::CStream &out) const
void readFromStreamRender (utils::CStream &in)
virtual void writeToStream (mrpt::utils::CStream &out, int *getVersion) const =0
 Introduces a pure virtual method responsible for writing to a CStream.
virtual void readFromStream (mrpt::utils::CStream &in, int version)=0
 Introduces a pure virtual method responsible for loading from a CStream This can not be used directly be users, instead use "stream >> object;" for reading it from a stream or "stream >> object_ptr;" if the class is unknown apriori.
Derived & octree_derived ()
const Derived & octree_derived () const
void octree_assure_uptodate () const
 Must be called at children class' render() previously to octree_render()
void octree_render (const mrpt::opengl::gl_utils::TRenderInfo &ri) const
 Render the entire octree recursively.
PLY Import virtual methods to implement in base classes
virtual void PLY_import_set_vertex_count (const size_t N)
 In a base class, reserve memory to prepare subsequent calls to PLY_import_set_vertex.
virtual void PLY_import_set_face_count (const size_t N)
 In a base class, reserve memory to prepare subsequent calls to PLY_import_set_face.
virtual void PLY_import_set_vertex (const size_t idx, const mrpt::math::TPoint3Df &pt, const mrpt::utils::TColorf *pt_color=NULL)
 In a base class, will be called after PLY_import_set_vertex_count() once for each loaded point.
PLY Export virtual methods to implement in base classes
virtual size_t PLY_export_get_vertex_count () const
 In a base class, return the number of vertices.
virtual size_t PLY_export_get_face_count () const
 In a base class, return the number of faces.
virtual void PLY_export_get_vertex (const size_t idx, mrpt::math::TPoint3Df &pt, bool &pt_has_color, mrpt::utils::TColorf &pt_color) const
 In a base class, will be called after PLY_export_get_vertex_count() once for each exported point.

Static Protected Member Functions

static void checkOpenGLError ()
 Checks glGetError and throws an exception if an error situation is found.
static unsigned int getNewTextureNumber ()
 Returns the lowest next free texture name (avoid using OpenGL's own function since we may call them from different threads and seem it's not cool).
static void releaseTextureName (unsigned int i)

Protected Attributes

std::string m_name
bool m_show_name
mrpt::utils::TColor m_color
 Color components in the range [0,255].
mrpt::poses::CPose3D m_pose
 6D pose wrt the parent coordinate reference. This class automatically holds the cached 3x3 rotation matrix for quick load into opengl stack.
float m_scale_x
float m_scale_y
float m_scale_z
 Scale components to apply to the object (default=1)
bool m_visible
 Is the object visible? (default=true)

Private Types

typedef std::vector< TPointColourTListPointColour
typedef TListPointColour::iterator iterator
typedef
TListPointColour::const_iterator 
const_iterator

Private Member Functions

iterator begin ()
const_iterator begin () const
iterator end ()
const_iterator end () const
 CPointCloudColoured ()
 Constructor.
virtual ~CPointCloudColoured ()
 Private, virtual destructor: only can be deleted from smart pointers.
void markAllPointsAsNew ()
 Do needed internal work if all points are new (octree rebuilt,...)

Private Attributes

TListPointColour m_points
float m_pointSize
 By default is 1.0.
bool m_pointSmooth
 Default: false.
volatile size_t m_last_rendered_count
volatile size_t m_last_rendered_count_ongoing

Friends

class mrpt::opengl::COpenGLViewport
class mrpt::opengl::CSetOfObjects

RTTI stuff

typedef CPointCloudColouredPtr SmartPtr
static mrpt::utils::CLASSINIT _init_CPointCloudColoured
static mrpt::utils::TRuntimeClassId classCPointCloudColoured
static const
mrpt::utils::TRuntimeClassId
classinfo
static const
mrpt::utils::TRuntimeClassId
_GetBaseClass ()
virtual const
mrpt::utils::TRuntimeClassId
GetRuntimeClass () const
 Returns information about the class of an object in runtime.
virtual mrpt::utils::CObjectduplicate () const
 Returns a copy of the object, indepently of its class.
static mrpt::utils::CObjectCreateObject ()
static CPointCloudColouredPtr Create ()

RTTI stuff

static const
mrpt::utils::TRuntimeClassId 
classCRenderizable
class mrpt::utils::CStream

Member Typedef Documentation

Definition at line 84 of file CPointCloudColoured.h.

Definition at line 83 of file CPointCloudColoured.h.

A typedef for the associated smart pointer

Definition at line 69 of file CPointCloudColoured.h.

Definition at line 80 of file CPointCloudColoured.h.


Member Enumeration Documentation

anonymous enum [inherited]

Definition at line 81 of file COctreePointRenderer.h.


Constructor & Destructor Documentation

mrpt::opengl::CPointCloudColoured::CPointCloudColoured ( ) [inline, private]

Constructor.

Definition at line 97 of file CPointCloudColoured.h.

virtual mrpt::opengl::CPointCloudColoured::~CPointCloudColoured ( ) [inline, private, virtual]

Private, virtual destructor: only can be deleted from smart pointers.

Definition at line 106 of file CPointCloudColoured.h.


Member Function Documentation

static const mrpt::utils::TRuntimeClassId* mrpt::opengl::CPointCloudColoured::_GetBaseClass ( ) [static, protected]

Reimplemented from mrpt::opengl::CRenderizable.

iterator mrpt::opengl::CPointCloudColoured::begin ( ) [inline, private]

Definition at line 85 of file CPointCloudColoured.h.

const_iterator mrpt::opengl::CPointCloudColoured::begin ( ) const [inline, private]

Definition at line 86 of file CPointCloudColoured.h.

static void mrpt::opengl::CRenderizable::checkOpenGLError ( ) [static, protected, inherited]

Checks glGetError and throws an exception if an error situation is found.

void mrpt::opengl::CPointCloudColoured::clear ( void  ) [inline]

Erase all the points.

Definition at line 153 of file CPointCloudColoured.h.

CRenderizable* mrpt::opengl::CRenderizable::clone ( ) const [inline, inherited]

Interface for the stlplus smart pointer class.

Reimplemented from mrpt::utils::CObject.

Reimplemented in mrpt::opengl::CRenderizableDisplayList.

Definition at line 174 of file CRenderizable.h.

static CPointCloudColouredPtr mrpt::opengl::CPointCloudColoured::Create ( ) [static]
static mrpt::utils::CObject* mrpt::opengl::CPointCloudColoured::CreateObject ( ) [static]
void mrpt::opengl::CPointCloudColoured::disablePointSmooth ( ) [inline]

Definition at line 213 of file CPointCloudColoured.h.

virtual mrpt::utils::CObject* mrpt::opengl::CPointCloudColoured::duplicate ( ) const [virtual]

Returns a copy of the object, indepently of its class.

Implements mrpt::utils::CObject.

mrpt::utils::CObjectPtr mrpt::utils::CObject::duplicateGetSmartPtr ( ) const [inline, inherited]

Returns a copy of the object, indepently of its class, as a smart pointer (the newly created object will exist as long as any copy of this smart pointer).

Definition at line 151 of file CObject.h.

void mrpt::opengl::CPointCloudColoured::enablePointSmooth ( bool  enable = true) [inline]

Definition at line 212 of file CPointCloudColoured.h.

void mrpt::opengl::CRenderizable::enableShowName ( bool  showName = true) [inline, inherited]

Enables or disables showing the name of the object as a label when rendering.

Definition at line 95 of file CRenderizable.h.

iterator mrpt::opengl::CPointCloudColoured::end ( ) [inline, private]

Definition at line 87 of file CPointCloudColoured.h.

const_iterator mrpt::opengl::CPointCloudColoured::end ( ) const [inline, private]

Definition at line 88 of file CPointCloudColoured.h.

size_t mrpt::opengl::CPointCloudColoured::getActuallyRendered ( ) const [inline]

Get the number of elements actually rendered in the last render event.

Definition at line 201 of file CPointCloudColoured.h.

mrpt::utils::TColorf mrpt::opengl::CRenderizable::getColor ( ) const [inline, inherited]

Returns the object color property as a TColorf.

Definition at line 150 of file CRenderizable.h.

const mrpt::utils::TColor& mrpt::opengl::CRenderizable::getColor_u8 ( ) const [inline, inherited]

Returns the object color property as a TColor.

Definition at line 159 of file CRenderizable.h.

double mrpt::opengl::CRenderizable::getColorA ( ) const [inline, inherited]

Color components in the range [0,1].

Definition at line 126 of file CRenderizable.h.

uint8_t mrpt::opengl::CRenderizable::getColorA_u8 ( ) const [inline, inherited]

Color components in the range [0,255].

Definition at line 131 of file CRenderizable.h.

double mrpt::opengl::CRenderizable::getColorB ( ) const [inline, inherited]

Color components in the range [0,1].

Definition at line 125 of file CRenderizable.h.

uint8_t mrpt::opengl::CRenderizable::getColorB_u8 ( ) const [inline, inherited]

Color components in the range [0,255].

Definition at line 130 of file CRenderizable.h.

double mrpt::opengl::CRenderizable::getColorG ( ) const [inline, inherited]

Color components in the range [0,1].

Definition at line 124 of file CRenderizable.h.

uint8_t mrpt::opengl::CRenderizable::getColorG_u8 ( ) const [inline, inherited]

Color components in the range [0,255].

Definition at line 129 of file CRenderizable.h.

double mrpt::opengl::CRenderizable::getColorR ( ) const [inline, inherited]

Color components in the range [0,1].

Definition at line 123 of file CRenderizable.h.

uint8_t mrpt::opengl::CRenderizable::getColorR_u8 ( ) const [inline, inherited]

Color components in the range [0,255].

Definition at line 128 of file CRenderizable.h.

std::string mrpt::utils::PLY_Importer::getLoadPLYErrorString ( ) const [inline, inherited]

Return a description of the error if loadFromPlyFile() returned false, or an empty string if the file was loaded without problems.

Definition at line 60 of file PLY_import_export.h.

const std::string& mrpt::opengl::CRenderizable::getName ( ) const [inline, inherited]

Returns the name of the object.

Definition at line 90 of file CRenderizable.h.

static unsigned int mrpt::opengl::CRenderizable::getNewTextureNumber ( ) [static, protected, inherited]

Returns the lowest next free texture name (avoid using OpenGL's own function since we may call them from different threads and seem it's not cool).

const TPointColour& mrpt::opengl::CPointCloudColoured::getPoint ( size_t  i) const [inline]

Read access to each individual point (checks for "i" in the valid range only in Debug).

Definition at line 133 of file CPointCloudColoured.h.

References ASSERT_BELOW_, and mrpt::math::size().

mrpt::math::TPoint3Df mrpt::opengl::CPointCloudColoured::getPointf ( size_t  i) const [inline]

Read access to each individual point (checks for "i" in the valid range only in Debug).

Definition at line 141 of file CPointCloudColoured.h.

References ASSERT_BELOW_, mrpt::math::size(), and Eigen::internal::y.

float mrpt::opengl::CPointCloudColoured::getPointSize ( ) const [inline]

Definition at line 210 of file CPointCloudColoured.h.

mrpt::math::TPose3D mrpt::opengl::CRenderizable::getPose ( ) const [inherited]

Returns the 3D pose of the object as TPose3D.

double mrpt::opengl::CRenderizable::getPosePitch ( ) const [inline, inherited]

Rotation relative to parent coordinate origin, in **DEGREES**.

Definition at line 117 of file CRenderizable.h.

References mrpt::utils::RAD2DEG().

double mrpt::opengl::CRenderizable::getPosePitchRad ( ) const [inline, inherited]

Rotation relative to parent coordinate origin, in radians.

Definition at line 120 of file CRenderizable.h.

const mrpt::poses::CPose3D& mrpt::opengl::CRenderizable::getPoseRef ( ) const [inline, inherited]

Returns a const ref to the 3D pose of the object as CPose3D (which explicitly contains the 3x3 rotation matrix)

Definition at line 105 of file CRenderizable.h.

double mrpt::opengl::CRenderizable::getPoseRoll ( ) const [inline, inherited]

Rotation relative to parent coordinate origin, in **DEGREES**.

Definition at line 118 of file CRenderizable.h.

References mrpt::utils::RAD2DEG().

double mrpt::opengl::CRenderizable::getPoseRollRad ( ) const [inline, inherited]

Rotation relative to parent coordinate origin, in radians.

Definition at line 121 of file CRenderizable.h.

double mrpt::opengl::CRenderizable::getPoseX ( ) const [inline, inherited]

Translation relative to parent coordinate origin.

Definition at line 113 of file CRenderizable.h.

double mrpt::opengl::CRenderizable::getPoseY ( ) const [inline, inherited]

Translation relative to parent coordinate origin.

Definition at line 114 of file CRenderizable.h.

double mrpt::opengl::CRenderizable::getPoseYaw ( ) const [inline, inherited]

Rotation relative to parent coordinate origin, in **DEGREES**.

Definition at line 116 of file CRenderizable.h.

References mrpt::utils::RAD2DEG().

double mrpt::opengl::CRenderizable::getPoseYawRad ( ) const [inline, inherited]

Rotation relative to parent coordinate origin, in radians.

Definition at line 119 of file CRenderizable.h.

double mrpt::opengl::CRenderizable::getPoseZ ( ) const [inline, inherited]

Translation relative to parent coordinate origin.

Definition at line 115 of file CRenderizable.h.

virtual const mrpt::utils::TRuntimeClassId* mrpt::opengl::CPointCloudColoured::GetRuntimeClass ( ) const [virtual]

Returns information about the class of an object in runtime.

Reimplemented from mrpt::opengl::CRenderizable.

std::string mrpt::utils::PLY_Exporter::getSavePLYErrorString ( ) const [inline, inherited]

Return a description of the error if loadFromPlyFile() returned false, or an empty string if the file was loaded without problems.

Definition at line 106 of file PLY_import_export.h.

float mrpt::opengl::CRenderizable::getScaleX ( ) const [inline, inherited]

Get the current scaling factor in one axis.

Definition at line 145 of file CRenderizable.h.

float mrpt::opengl::CRenderizable::getScaleY ( ) const [inline, inherited]

Get the current scaling factor in one axis.

Definition at line 146 of file CRenderizable.h.

float mrpt::opengl::CRenderizable::getScaleZ ( ) const [inline, inherited]

Get the current scaling factor in one axis.

Definition at line 147 of file CRenderizable.h.

bool mrpt::opengl::CPointCloudColoured::isPointSmoothEnabled ( ) const [inline]

Definition at line 214 of file CPointCloudColoured.h.

bool mrpt::opengl::CRenderizable::isShowNameEnabled ( ) const [inline, inherited]
See also:
enableShowName

Definition at line 96 of file CRenderizable.h.

bool mrpt::opengl::CRenderizable::isVisible ( ) const [inline, inherited]

Is the object visible?

See also:
setVisibility

Definition at line 92 of file CRenderizable.h.

bool mrpt::utils::PLY_Importer::loadFromPlyFile ( const std::string filename,
CStringList file_comments = NULL,
CStringList file_obj_info = NULL 
) [inherited]

Loads from a PLY file.

Parameters:
[in]filenameThe filename to open. It can be either in binary or text format.
[out]file_commentsIf provided (!=NULL) the list of comment strings stored in the file will be returned.
[out]file_obj_infoIf provided (!=NULL) the list of "object info" strings stored in the file will be returned.
Returns:
false on any error in the file format or reading it. To obtain more details on the error you can call getLoadPLYErrorString()
template<class POINTSMAP >
void mrpt::opengl::CPointCloudColoured::loadFromPointsMap ( const POINTSMAP *  m) [inline]

Load the points from a points map (passed as a pointer), depending on the type of point map passed: for the case of a mrpt::slam::CColouredPointMap the colours of individual points will be also copied.

The possible classes accepted as arguments are: mrpt::slam::CColouredPointsMap, or in general any mrpt::slam::CPointsMap.

Note:
The method is a template since CPointsMap belongs to a different mrpt library.

Definition at line 161 of file CPointCloudColoured.h.

References Eigen::internal::y, mrpt::utils::TColorf::R, mrpt::utils::TColorf::G, and mrpt::utils::TColorf::B.

void mrpt::opengl::CPointCloudColoured::markAllPointsAsNew ( ) [private]

Do needed internal work if all points are new (octree rebuilt,...)

void mrpt::opengl::COctreePointRenderer::octree_assure_uptodate ( ) const [inline, protected, inherited]

Must be called at children class' render() previously to octree_render()

Definition at line 89 of file COctreePointRenderer.h.

References mrpt::opengl::COctreePointRenderer::internal_octree_assure_uptodate().

void mrpt::opengl::COctreePointRenderer::octree_debug_dump_tree ( std::ostream o) const [inline, inherited]
Derived& mrpt::opengl::COctreePointRenderer::octree_derived ( ) [inline, protected, inherited]

Definition at line 85 of file COctreePointRenderer.h.

const Derived& mrpt::opengl::COctreePointRenderer::octree_derived ( ) const [inline, protected, inherited]

Definition at line 86 of file COctreePointRenderer.h.

void mrpt::opengl::COctreePointRenderer::octree_get_graphics_boundingboxes ( mrpt::opengl::CSetOfObjects gl_bb,
const double  lines_width = 1,
const TColorf  lines_color = TColorf(1,1,1) 
) const [inline, inherited]
size_t mrpt::opengl::COctreePointRenderer::octree_get_node_count ( ) const [inline, inherited]

Return the number of octree nodes (all of them, including the empty ones)

See also:
octree_get_nonempty_node_count

Definition at line 538 of file COctreePointRenderer.h.

References mrpt::opengl::COctreePointRenderer::m_octree_nodes.

size_t mrpt::opengl::COctreePointRenderer::octree_get_visible_nodes ( ) const [inline, inherited]

Return the number of visible octree nodes in the last render event.

Definition at line 541 of file COctreePointRenderer.h.

References mrpt::opengl::COctreePointRenderer::m_visible_octree_nodes.

void mrpt::opengl::COctreePointRenderer::octree_mark_as_outdated ( ) [inline, inherited]

Called from the derived class (or the user) to indicate we have/want to rebuild the entire node tree (for example, after modifying the point cloud or any global octree parameter)

Definition at line 544 of file COctreePointRenderer.h.

References mrpt::opengl::COctreePointRenderer::m_octree_has_to_rebuild_all.

void mrpt::opengl::COctreePointRenderer::octree_render ( const mrpt::opengl::gl_utils::TRenderInfo ri) const [inline, protected, inherited]
const TPointColour& mrpt::opengl::CPointCloudColoured::operator[] ( size_t  i) const [inline]

Read access to each individual point (checks for "i" in the valid range only in Debug).

Definition at line 125 of file CPointCloudColoured.h.

References ASSERT_BELOW_, and mrpt::math::size().

virtual size_t mrpt::opengl::CPointCloudColoured::PLY_export_get_face_count ( ) const [inline, protected, virtual]

In a base class, return the number of faces.

Implements mrpt::utils::PLY_Exporter.

Definition at line 245 of file CPointCloudColoured.h.

virtual void mrpt::opengl::CPointCloudColoured::PLY_export_get_vertex ( const size_t  idx,
mrpt::math::TPoint3Df pt,
bool &  pt_has_color,
mrpt::utils::TColorf pt_color 
) const [protected, virtual]

In a base class, will be called after PLY_export_get_vertex_count() once for each exported point.

Parameters:
pt_colorWill be NULL if the loaded file does not provide color info.

Implements mrpt::utils::PLY_Exporter.

virtual size_t mrpt::opengl::CPointCloudColoured::PLY_export_get_vertex_count ( ) const [protected, virtual]

In a base class, return the number of vertices.

Implements mrpt::utils::PLY_Exporter.

virtual void mrpt::opengl::CPointCloudColoured::PLY_import_set_face_count ( const size_t  N) [inline, protected, virtual]

In a base class, reserve memory to prepare subsequent calls to PLY_import_set_face.

Implements mrpt::utils::PLY_Importer.

Definition at line 231 of file CPointCloudColoured.h.

virtual void mrpt::opengl::CPointCloudColoured::PLY_import_set_vertex ( const size_t  idx,
const mrpt::math::TPoint3Df pt,
const mrpt::utils::TColorf pt_color = NULL 
) [protected, virtual]

In a base class, will be called after PLY_import_set_vertex_count() once for each loaded point.

Parameters:
pt_colorWill be NULL if the loaded file does not provide color info.

Implements mrpt::utils::PLY_Importer.

virtual void mrpt::opengl::CPointCloudColoured::PLY_import_set_vertex_count ( const size_t  N) [protected, virtual]

In a base class, reserve memory to prepare subsequent calls to PLY_import_set_vertex.

Implements mrpt::utils::PLY_Importer.

void mrpt::opengl::CPointCloudColoured::push_back ( float  x,
float  y,
float  z,
float  R,
float  G,
float  B 
)

Inserts a new point into the point cloud.

virtual void mrpt::utils::CSerializable::readFromStream ( mrpt::utils::CStream in,
int  version 
) [protected, pure virtual, inherited]

Introduces a pure virtual method responsible for loading from a CStream This can not be used directly be users, instead use "stream >> object;" for reading it from a stream or "stream >> object_ptr;" if the class is unknown apriori.

Parameters:
inThe input binary stream where the object data must read from.
versionThe version of the object stored in the stream: use this version number in your code to know how to read the incoming data.
Exceptions:
std::exceptionOn any error, see CStream::ReadBuffer
See also:
CStream

Implemented in mrpt::math::CMatrixD, and mrpt::math::CMatrix.

void mrpt::opengl::CRenderizable::readFromStreamRender ( utils::CStream in) [protected, inherited]
static void mrpt::opengl::CRenderizable::releaseTextureName ( unsigned int  i) [static, protected, inherited]
void mrpt::opengl::CPointCloudColoured::render ( ) const [virtual]

Render.

Implements mrpt::opengl::CRenderizable.

void mrpt::opengl::CPointCloudColoured::render_subset ( const bool  all,
const std::vector< size_t > &  idxs,
const float  render_area_sqpixels 
) const

Render a subset of points (required by octree renderer)

static void mrpt::opengl::CRenderizable::renderTextBitmap ( const char *  str,
void *  fontStyle 
) [static, inherited]

This method is safe for calling from within ::render() methods.

See also:
renderTextBitmap, mrpt::opengl::gl_utils
static void mrpt::opengl::CRenderizable::renderTextBitmap ( int  screen_x,
int  screen_y,
const std::string str,
float  color_r = 1,
float  color_g = 1,
float  color_b = 1,
mrpt::opengl::TOpenGLFont  font = mrpt::opengl::MRPT_GLUT_BITMAP_TIMES_ROMAN_24 
) [static, inherited]

Render a text message in the current rendering context, creating a glViewport in the way (do not call within ::render() methods)

  • Coordinates (x,y) are 2D pixels, starting at bottom-left of the viewport. Negative numbers will wrap to the opposite side of the viewport (e.g. x=-10 means 10px fromt the right).
  • The text color is defined by (color_r,color_g,color_b), each float numbers in the range [0,1].
    See also:
    renderTextBitmap, textBitmapWidth, mrpt::opengl::gl_utils
void mrpt::opengl::CPointCloudColoured::reserve ( size_t  N) [inline]

Like STL std::vector's reserve.

Definition at line 122 of file CPointCloudColoured.h.

void mrpt::opengl::CPointCloudColoured::resize ( size_t  N) [inline]

Set the number of points, with undefined contents.

Definition at line 119 of file CPointCloudColoured.h.

bool mrpt::utils::PLY_Exporter::saveToPlyFile ( const std::string filename,
bool  save_in_binary = false,
const CStringList file_comments = CStringList(),
const CStringList file_obj_info = CStringList() 
) const [inherited]

Saves to a PLY file.

Parameters:
[in]filenameThe filename to be saved.
[in]file_commentsIf provided (!=NULL) the list of comment strings stored in the file will be returned.
[in]file_obj_infoIf provided (!=NULL) the list of "object info" strings stored in the file will be returned.
Returns:
false on any error writing the file. To obtain more details on the error you can call getSavePLYErrorString()
CRenderizable& mrpt::opengl::CRenderizable::setColor ( const mrpt::utils::TColorf c) [inline, inherited]
Parameters:
cChanges the default object color
Returns:
a ref to this

Definition at line 151 of file CRenderizable.h.

References mrpt::utils::TColorf::R, mrpt::utils::TColorf::G, mrpt::utils::TColorf::B, and mrpt::utils::TColorf::A.

CRenderizable& mrpt::opengl::CRenderizable::setColor ( double  R,
double  G,
double  B,
double  A = 1 
) [inline, inherited]

Set the color components of this object (R,G,B,Alpha, in the range 0-1)

Returns:
a ref to this

Definition at line 157 of file CRenderizable.h.

virtual CRenderizable& mrpt::opengl::CRenderizable::setColor_u8 ( const mrpt::utils::TColor c) [virtual, inherited]
CRenderizable& mrpt::opengl::CRenderizable::setColor_u8 ( uint8_t  R,
uint8_t  G,
uint8_t  B,
uint8_t  A = 255 
) [inline, inherited]

Set the color components of this object (R,G,B,Alpha, in the range 0-1)

Returns:
a ref to this

Definition at line 164 of file CRenderizable.h.

References mrpt::opengl::CRenderizable::setColor_u8().

Referenced by mrpt::opengl::CRenderizable::setColor_u8().

CRenderizable& mrpt::opengl::CRenderizable::setColorA ( const double  a) [inline, inherited]

Color components in the range [0,1].

Returns:
a ref to this

Definition at line 136 of file CRenderizable.h.

virtual CRenderizable& mrpt::opengl::CRenderizable::setColorA_u8 ( const uint8_t  a) [inline, virtual, inherited]

Color components in the range [0,255].

Returns:
a ref to this

Reimplemented in mrpt::opengl::CSetOfObjects, mrpt::opengl::CSetOfTriangles, and mrpt::opengl::CRenderizableDisplayList.

Definition at line 141 of file CRenderizable.h.

CRenderizable& mrpt::opengl::CRenderizable::setColorB ( const double  b) [inline, inherited]

Color components in the range [0,1].

Returns:
a ref to this

Definition at line 135 of file CRenderizable.h.

virtual CRenderizable& mrpt::opengl::CRenderizable::setColorB_u8 ( const uint8_t  b) [inline, virtual, inherited]

Color components in the range [0,255].

Returns:
a ref to this

Reimplemented in mrpt::opengl::CSetOfObjects, mrpt::opengl::CSetOfTriangles, and mrpt::opengl::CRenderizableDisplayList.

Definition at line 140 of file CRenderizable.h.

CRenderizable& mrpt::opengl::CRenderizable::setColorG ( const double  g) [inline, inherited]

Color components in the range [0,1].

Returns:
a ref to this

Definition at line 134 of file CRenderizable.h.

virtual CRenderizable& mrpt::opengl::CRenderizable::setColorG_u8 ( const uint8_t  g) [inline, virtual, inherited]

Color components in the range [0,255].

Returns:
a ref to this

Reimplemented in mrpt::opengl::CSetOfObjects, mrpt::opengl::CSetOfTriangles, and mrpt::opengl::CRenderizableDisplayList.

Definition at line 139 of file CRenderizable.h.

CRenderizable& mrpt::opengl::CRenderizable::setColorR ( const double  r) [inline, inherited]

Color components in the range [0,1].

Returns:
a ref to this

Definition at line 133 of file CRenderizable.h.

virtual CRenderizable& mrpt::opengl::CRenderizable::setColorR_u8 ( const uint8_t  r) [inline, virtual, inherited]

Color components in the range [0,255].

Returns:
a ref to this

Reimplemented in mrpt::opengl::CSetOfObjects, mrpt::opengl::CSetOfTriangles, and mrpt::opengl::CRenderizableDisplayList.

Definition at line 138 of file CRenderizable.h.

CRenderizable& mrpt::opengl::CRenderizable::setLocation ( double  x,
double  y,
double  z 
) [inline, inherited]

Changes the location of the object, keeping untouched the orientation.

Returns:
a ref to this

Definition at line 108 of file CRenderizable.h.

CRenderizable& mrpt::opengl::CRenderizable::setLocation ( const mrpt::math::TPoint3D p) [inline, inherited]

Changes the location of the object, keeping untouched the orientation.

Returns:
a ref to this

Definition at line 111 of file CRenderizable.h.

References mrpt::math::TPoint3D::x, mrpt::math::TPoint3D::y, and mrpt::math::TPoint3D::z.

void mrpt::opengl::CRenderizable::setName ( const std::string n) [inline, inherited]

Changes the name of the object.

Definition at line 89 of file CRenderizable.h.

void mrpt::opengl::CPointCloudColoured::setPoint ( size_t  i,
const TPointColour p 
)

Write an individual point (checks for "i" in the valid range only in Debug).

void mrpt::opengl::CPointCloudColoured::setPointSize ( float  pointSize) [inline]

Definition at line 209 of file CPointCloudColoured.h.

CRenderizable& mrpt::opengl::CRenderizable::setPose ( const mrpt::poses::CPose3D o) [inherited]

Set the 3D pose from a mrpt::poses::CPose3D object (return a ref to this)

CRenderizable& mrpt::opengl::CRenderizable::setPose ( const mrpt::math::TPose3D o) [inherited]

Set the 3D pose from a mrpt::math::TPose3D object (return a ref to this)

CRenderizable& mrpt::opengl::CRenderizable::setPose ( const mrpt::poses::CPoint3D o) [inherited]

Set the 3D pose from a mrpt::poses::CPose3D object (return a ref to this)

CRenderizable& mrpt::opengl::CRenderizable::setPose ( const mrpt::poses::CPoint2D o) [inherited]

Set the 3D pose from a mrpt::poses::CPose3D object (return a ref to this)

CRenderizable& mrpt::opengl::CRenderizable::setScale ( float  s) [inline, inherited]

Scale to apply to the object, in all three axes (default=1)

Returns:
a ref to this

Definition at line 143 of file CRenderizable.h.

CRenderizable& mrpt::opengl::CRenderizable::setScale ( float  sx,
float  sy,
float  sz 
) [inline, inherited]

Scale to apply to the object in each axis (default=1)

Returns:
a ref to this

Definition at line 144 of file CRenderizable.h.

void mrpt::opengl::CRenderizable::setVisibility ( bool  visible = true) [inline, inherited]

Set object visibility (default=true)

See also:
isVisible

Definition at line 93 of file CRenderizable.h.

size_t mrpt::opengl::CPointCloudColoured::size ( ) const [inline]

Return the number of points.

Definition at line 151 of file CPointCloudColoured.h.

static int mrpt::opengl::CRenderizable::textBitmapWidth ( const std::string str,
mrpt::opengl::TOpenGLFont  font = mrpt::opengl::MRPT_GLUT_BITMAP_TIMES_ROMAN_24 
) [static, inherited]

Return the exact width in pixels for a given string, as will be rendered by renderTextBitmap().

See also:
renderTextBitmap, mrpt::opengl::gl_utils
virtual bool mrpt::opengl::CRenderizable::traceRay ( const mrpt::poses::CPose3D o,
double &  dist 
) const [virtual, inherited]

Simulation of ray-trace, given a pose.

Returns true if the ray effectively collisions with the object (returning the distance to the origin of the ray in "dist"), or false in other case. "dist" variable yields undefined behaviour when false is returned

Reimplemented in mrpt::opengl::CPolyhedron, mrpt::opengl::CAngularObservationMesh, mrpt::opengl::CMesh, mrpt::opengl::CGeneralizedCylinder, mrpt::opengl::CSetOfObjects, mrpt::opengl::CSetOfTriangles, mrpt::opengl::CEllipsoid, mrpt::opengl::CSetOfTexturedTriangles, mrpt::opengl::CTexturedPlane, mrpt::opengl::CSphere, mrpt::opengl::CCylinder, mrpt::opengl::C3DSScene, mrpt::opengl::CDisk, and mrpt::opengl::CBox.

virtual void mrpt::utils::CSerializable::writeToStream ( mrpt::utils::CStream out,
int *  getVersion 
) const [protected, pure virtual, inherited]

Introduces a pure virtual method responsible for writing to a CStream.

This can not be used directly be users, instead use "stream << object;" for writing it to a stream.

Parameters:
outThe output binary stream where object must be dumped.
getVersionIf NULL, the object must be dumped. If not, only the version of the object dump must be returned in this pointer. This enables the versioning of objects dumping and backward compatibility with previously stored data.
Exceptions:
std::exceptionOn any error, see CStream::WriteBuffer
See also:
CStream

Implemented in mrpt::math::CMatrixD, and mrpt::math::CMatrix.

void mrpt::opengl::CRenderizable::writeToStreamRender ( utils::CStream out) const [protected, inherited]

Friends And Related Function Documentation

friend class mrpt::opengl::COpenGLViewport [friend, inherited]

Definition at line 74 of file CRenderizable.h.

friend class mrpt::opengl::CSetOfObjects [friend, inherited]

Definition at line 75 of file CRenderizable.h.

friend class mrpt::utils::CStream [friend, inherited]

Reimplemented from mrpt::utils::CSerializable.

Reimplemented in mrpt::opengl::CRenderizableDisplayList, and mrpt::opengl::CTexturedObject.

Definition at line 72 of file CRenderizable.h.


Member Data Documentation

Definition at line 69 of file CPointCloudColoured.h.

Definition at line 139 of file CObject.h.

Definition at line 69 of file CPointCloudColoured.h.

Definition at line 72 of file CRenderizable.h.

Definition at line 56 of file CSerializable.h.

Definition at line 69 of file CPointCloudColoured.h.

Color components in the range [0,255].

Definition at line 80 of file CRenderizable.h.

Definition at line 93 of file CPointCloudColoured.h.

Definition at line 93 of file CPointCloudColoured.h.

Definition at line 78 of file CRenderizable.h.

Definition at line 81 of file CPointCloudColoured.h.

By default is 1.0.

Definition at line 91 of file CPointCloudColoured.h.

Default: false.

Definition at line 92 of file CPointCloudColoured.h.

6D pose wrt the parent coordinate reference. This class automatically holds the cached 3x3 rotation matrix for quick load into opengl stack.

Definition at line 81 of file CRenderizable.h.

float mrpt::opengl::CRenderizable::m_scale_x [protected, inherited]

Definition at line 82 of file CRenderizable.h.

float mrpt::opengl::CRenderizable::m_scale_y [protected, inherited]

Definition at line 82 of file CRenderizable.h.

float mrpt::opengl::CRenderizable::m_scale_z [protected, inherited]

Scale components to apply to the object (default=1)

Definition at line 82 of file CRenderizable.h.

bool mrpt::opengl::CRenderizable::m_show_name [protected, inherited]

Definition at line 79 of file CRenderizable.h.

bool mrpt::opengl::CRenderizable::m_visible [protected, inherited]

Is the object visible? (default=true)

Definition at line 83 of file CRenderizable.h.




Page generated by Doxygen 1.7.5 for MRPT 0.9.5 SVN: at Thu Oct 13 21:25:36 UTC 2011