Coin  4.0.3
Coin3D core library
Loading...
Searching...
No Matches
SoDetail Class Referenceabstract

The SoDetail class is the superclass for all classes storing detailed information about particular shapes. More...

#include <Inventor/details/SoDetail.h>

Inheritance diagram for SoDetail:
SoConeDetail SoCubeDetail SoCylinderDetail SoFaceDetail SoLineDetail SoNodeKitDetail SoPointDetail SoTextDetail

Public Member Functions

virtual ~SoDetail ()
 
virtual SoDetailcopy (void) const =0
 
virtual SoType getTypeId (void) const =0
 
SbBool isOfType (const SoType type) const
 

Static Public Member Functions

static SoType getClassTypeId (void)
 
static void initClass (void)
 
static void initClasses (void)
 

Protected Member Functions

 SoDetail (void)
 

Detailed Description

The SoDetail class is the superclass for all classes storing detailed information about particular shapes.

Detail information about shapes is used in relation to picking actions in Coin. They typically contain the relevant information about what particular part of the shape a pick ray intersected with.

Constructor & Destructor Documentation

◆ ~SoDetail()

SoDetail::~SoDetail ( )
virtual

Destructor.

◆ SoDetail()

SoDetail::SoDetail ( void )
protected

Default constructor.

Member Function Documentation

◆ copy()

SoDetail * SoDetail::copy ( void ) const
pure virtual

Return a deep copy of ourself.

Note that if the Coin library has been built as a DLL under Microsoft Windows and you use this method from application code, you must make sure that both the Coin DLL and the application executable are using the same instance of a C Run-Time (CRT) library. Otherwise, you will get memory heap corruption upon deallocating the returned instances, eventually leading to mysterious crashes.

Implemented in SoConeDetail, SoCubeDetail, SoCylinderDetail, SoFaceDetail, SoLineDetail, SoNodeKitDetail, SoPointDetail, and SoTextDetail.

◆ getClassTypeId()

SoType SoDetail::getClassTypeId ( void )
static

Returns the type identification for this class.

◆ getTypeId()

SoType SoDetail::getTypeId ( void ) const
pure virtual

Returns the type identification of a detail derived from a class inheriting SoDetail. This is used for runtime type checking and "downward" casting.

Usage example:

void fuhbear(SoDetail * detail)
{
// safe downward cast, know the type
}
return; // ignore if not a SoFaceDetail
}
The SbList class is a template container class for lists.
Definition SbList.h:70
The SoDetail class is the superclass for all classes storing detailed information about particular sh...
Definition SoDetail.h:39
virtual SoType getTypeId(void) const =0
The SoFaceDetail class is for storing detailed polygon information.
Definition SoFaceDetail.h:38
static SoType getClassTypeId(void)
Definition SoFaceDetail.cpp:53

For application programmers wanting to extend the library with new detail classes: this method needs to be overridden in all subclasses. This is typically done as part of setting up the full type system for extension classes, which is usually accomplished by using the predefined macros available through Inventor/nodes/SoSubDetail.h: SO_DETAIL_SOURCE and SO_DETAIL_INIT_CLASS.

Implemented in SoConeDetail, SoCubeDetail, SoCylinderDetail, SoFaceDetail, SoLineDetail, SoNodeKitDetail, SoPointDetail, and SoTextDetail.

◆ initClass()

void SoDetail::initClass ( void )
static

Initialize relevant common data for all instances, like the type system.

◆ initClasses()

void SoDetail::initClasses ( void )
static

Call the initClass() methods of all built-in detail classes.

(The initClass() method of user extension detail classes – if any – must be called explicitly by the application programmer in the application initialization code.)

◆ isOfType()

SbBool SoDetail::isOfType ( const SoType type) const

Returns TRUE if type is derived from (or is) this class.


The documentation for this class was generated from the following files: