Coin
4.0.3
Coin3D core library
|
The SbLineProjector class projects 2D points to 3D points along a line. More...
#include <Inventor/projectors/SbLineProjector.h>
Public Member Functions | |
SbLineProjector (void) | |
virtual SbProjector * | copy (void) const |
const SbLine & | getLine (void) const |
virtual SbVec3f | getVector (const SbVec2f &viewpos) |
virtual SbVec3f | getVector (const SbVec2f &viewpos1, const SbVec2f &viewpos2) |
virtual SbVec3f | project (const SbVec2f &point) |
void | setLine (const SbLine &line) |
void | setStartPosition (const SbVec2f &viewpos) |
void | setStartPosition (const SbVec3f &point) |
virtual SbBool | tryProject (const SbVec2f &point, const float epsilon, SbVec3f &result) |
Public Member Functions inherited from SbProjector | |
const SbViewVolume & | getViewVolume (void) const |
const SbMatrix & | getWorkingSpace (void) const |
virtual void | setViewVolume (const SbViewVolume &vol) |
virtual void | setWorkingSpace (const SbMatrix &space) |
Protected Attributes | |
SbVec3f | lastPoint |
SbLine | line |
Protected Attributes inherited from SbProjector | |
SbViewVolume | viewVol |
SbMatrix | workingToWorld |
SbMatrix | worldToWorking |
Additional Inherited Members | |
Protected Member Functions inherited from SbProjector | |
SbProjector (void) | |
virtual | ~SbProjector () |
float | findVanishingDistance (void) const |
SbLine | getWorkingLine (const SbVec2f &point) const |
SbBool | verifyProjection (const SbVec3f &projpt) const |
The SbLineProjector class projects 2D points to 3D points along a line.
The 3D projection of the 2D coordinates is for this projector class constrained to lie along a predefined line.
Among other places, this is useful within the translation draggers, like for instance SoTranslate1Dragger, where we want to move "pieces" along one or more axes.
SbLineProjector::SbLineProjector | ( | void | ) |
Constructor. Initializes the projector instance to use a line from <0, 0, 0> to <0, 1, 0>.
|
virtual |
Construct and return a copy of this projector. The caller is responsible for destructing the new instance.
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.
Implements SbProjector.
Returns the 3D vector between the last projection and the one calculated for viewpos.
Calculates and returns a vector between the projected 3D position of viewpos1 and viewpos2.
Project the 2D point from normalized viewport coordinates to a 3D point. The mapping will be done in accordance with the type of the projector.
Implements SbProjector.
Set a new projection line. 3D points will be mapped to be on this line.
Explicitly set position of initial projection, so we get correct values for later calls to getVector() etc.
Explicitly set position of initial projection, so we get correct values for later calls to getVector() etc.
|
virtual |
Try projecting the 2D point from normalized viewport coordinates to a 3D point. The mapping will be done in accordance with the type of the projector.
If the projection can't be done safely (for instance when the projection plane or line is parallel to the view volume projection), this function should return FALSE.
Default implementation will call project() and always return TRUE, but subclasses can override this behavior to support safe projections.
Reimplemented from SbProjector.
|
protected |
The last projected point.
|
protected |
The projection line. Projected 3D points will be constrained to be on this line.