Coin3D is Free Software, published under the BSD 3-clause license. |
https://bitbucket.org/Coin3D/ http://www.kongsberg.com/kogt/ |
The SoPickedPoint class is used for specifying picked points. More...
#include <Inventor/SoPickedPoint.h>
Public Member Functions | |
SoPickedPoint (const SoPickedPoint &pp) | |
SoPickedPoint (const SoPath *const path, SoState *const state, const SbVec3f &objSpacePoint) | |
~SoPickedPoint () | |
SoPickedPoint * | copy () const |
const SbVec3f & | getPoint () const |
const SbVec3f & | getNormal () const |
const SbVec4f & | getTextureCoords () const |
int | getMaterialIndex () const |
SoPath * | getPath () const |
SbBool | isOnGeometry () const |
const SoDetail * | getDetail (const SoNode *const node=NULL) const |
const SbMatrix & | getObjectToWorld (const SoNode *const node=NULL) const |
const SbMatrix & | getWorldToObject (const SoNode *const node=NULL) const |
const SbMatrix & | getObjectToImage (const SoNode *const node=NULL) const |
const SbMatrix & | getImageToObject (const SoNode *const node=NULL) const |
SbVec3f | getObjectPoint (const SoNode *const node=NULL) const |
SbVec3f | getObjectNormal (const SoNode *const node=NULL) const |
SbVec4f | getObjectTextureCoords (const SoNode *const node=NULL) const |
void | setObjectNormal (const SbVec3f &normal) |
void | setObjectTextureCoords (const SbVec4f &texCoords) |
void | setMaterialIndex (const int index) |
void | setDetail (SoDetail *detail, SoNode *node) |
The SoPickedPoint class is used for specifying picked points.
It holds miscellaneous information about the picked point, such as position, normal, texture coordinate and material index in the current material. It might also hold detail information (an SoDetail subclass) for every node in the picked path.
SoPickedPoint::SoPickedPoint | ( | const SoPickedPoint & | pp | ) |
Copy constructor.
SoPickedPoint::SoPickedPoint | ( | const SoPath *const | pathptr, |
SoState *const | stateptr, | ||
const SbVec3f & | objSpacePoint | ||
) |
Constructor. Uses the state to convert between world and object space for the data.
SoPickedPoint::~SoPickedPoint | ( | ) |
Destructor.
SoPickedPoint * SoPickedPoint::copy | ( | ) | const |
Returns a copy of this picked point.
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.
const SbVec3f & SoPickedPoint::getPoint | ( | ) | const |
Returns the world space point.
const SbVec3f & SoPickedPoint::getNormal | ( | void | ) | const |
Returns the world space normal.
const SbVec4f & SoPickedPoint::getTextureCoords | ( | ) | const |
Returns the image space texture coordinates.
int SoPickedPoint::getMaterialIndex | ( | ) | const |
Returns the material index.
SoPath * SoPickedPoint::getPath | ( | ) | const |
Returns the path to the picked object.
SbBool SoPickedPoint::isOnGeometry | ( | ) | const |
Returns TRUE if this picked point is on the actual geometry of the picked object, or FALSE if not (it might for instance be on the bounding box if picking was done on bounding boxes).
Returns detail for node. If node equals NULL, the detail for the picked object is returned.
Returns the matrix which converts from object (specified by node) to world space. If node equals NULL, the object space of the picked object will used.
Returns the matrix which converts from world to object (specified by node) space. If node equals NULL, the object space of the picked object will used.
Returns the matrix which converts from object (specified by node) to image space. If node equals NULL, the object space of the picked object will used.
Returns the matrix which converts from image to object (specified by node) space. If node equals NULL, the object space of the picked object will used.
Returns the object space point, in the object space specified by node. If node equals NULL
, the object space of the node where the point was actually picked will be used (this is what one would usually be interested in).
node can be any node in the scenegraph.
Returns the object space (specified by node) normal. If node equals NULL, the picked point object space will be used.
Returns the object space (specified by node) texture coordinates. If node equals NULL, the picked point object space will be used.
void SoPickedPoint::setObjectNormal | ( | const SbVec3f & | normalref | ) |
Sets the picked point objects space normal vector.
void SoPickedPoint::setObjectTextureCoords | ( | const SbVec4f & | texCoordsref | ) |
Sets the picked point object space texture coordinates.
void SoPickedPoint::setMaterialIndex | ( | const int | index | ) |
Sets the material index.
Sets the detail for node. node must be in the picked path, of course. Set to NULL if you want to remove a detail for a node.