Iterator for NURBS curve CVs.
This class is the iterator class for NURBS curve control vertices (CVs). The iteration can be for a given curve or for a group of CVs.
Example: Translates the CVs for a curve in the X direction (world space).
MItCurveCV* cvIter = new MItCurveCV( curve, &stat ); MVector vector(1.0,0.0,0.0); if ( MStatus::kSuccess == stat ) { for ( ; !cvIter->isDone(); cvIter->next() ) { cvIter->translateBy( vector, MSpace::kWorld ); } cvIter->updateCurve(); // Tell curve is has been changed } else { cerr << "Error creating iterator!" << endl; }
cvPosCmd.cpp, lassoTool.cpp, moveCurveCVsCmd.cpp, moveTool.cpp, and translateCmd.cpp.
#include <MItCurveCV.h>
Public Member Functions |
|
MItCurveCV (MObject &curve, MStatus *ReturnStatus=NULL) | |
Constructor. |
|
MItCurveCV (const MDagPath &curve, MObject &component=MObject::kNullObj, MStatus *ReturnStatus=NULL) | |
Constructor. |
|
virtual | ~MItCurveCV () |
Class destructor. |
|
bool | isDone (MStatus *ReturnStatus=NULL) const |
Returns true if the iteration is
finished, i.e. |
|
MStatus | next () |
Advance to the next CV in the iteration.
|
|
MStatus | reset () |
Reset the iterator to the first CV. |
|
MStatus | reset (MObject &curve) |
Reset the iterator to the specified curve.
|
|
MStatus | reset (const MDagPath &curve, MObject &component=MObject::kNullObj) |
Reset the iterator to the specified curve
and component. |
|
MPoint | position (MSpace::Space space=MSpace::kObject, MStatus *ReturnStatus=NULL) const |
Return the position of the current CV.
|
|
MStatus | setPosition (const MPoint &pt, MSpace::Space space=MSpace::kObject) |
Set the position of the current CV to the
specified point. |
|
MStatus | translateBy (const MVector &vec, MSpace::Space space=MSpace::kObject) |
Translates the current CV by the amount
specified in vec. |
|
int | index (MStatus *ReturnStatus=NULL) const |
This method returns the index of the current
CV in the CV array for this curve. |
|
MObject | cv (MStatus *ReturnStatus=NULL) const |
This method is obsolete. |
|
MObject | currentItem (MStatus *ReturnStatus=NULL) const |
This method returns the current CV as an
MObject.
|
|
bool | hasHistoryOnCreate (MStatus *ReturnStatus=NULL) const |
This method determines if the shape was
created with history. |
|
MStatus | updateCurve () |
This method is used to signal the curve that
it has been changed and needs to redraw itself. |
|
Static Public Member Functions |
|
static const char * | className () |
Returns the name of this class. |
MItCurveCV | ( | MObject & | curve, |
MStatus * | ReturnStatus =
NULL |
||
) |
Constructor.
This constructor is used when iterating over an entire curve.
[in] | curve | The curve for the iteration |
[out] | ReturnStatus | Status code |
MItCurveCV | ( | const MDagPath & | curve, |
MObject & | component = MObject::kNullObj , |
||
MStatus * | ReturnStatus =
NULL |
||
) |
Constructor.
This constructor is used when iterating over a group of CVs. If the component is not given then the iteration will be for the whole curve.
[in] | curve | Dag path to the curve for the iteration |
[in] | component | A group of CVs to be iterated on |
[out] | ReturnStatus | Status code |
~MItCurveCV | ( | ) | [virtual] |
Class destructor.
Deallocates memory used by this iterator.
bool isDone | ( | MStatus * | ReturnStatus =
NULL |
) | const |
Returns true if the iteration is finished, i.e.
there are no more CVs to iterate on.
[out] | ReturnStatus | Status code |
MStatus next | ( | ) |
Advance to the next CV in the iteration.
If the iterator is already at the last CV then this method has no effect. Use isDone to determine if the iterator is at the last CV.
MStatus reset | ( | ) |
Reset the iterator to the first CV.
Reset the iterator to the specified curve.
[in] | curve | The curve for the iteration |
MStatus reset | ( | const MDagPath & | curve, |
MObject & | component = MObject::kNullObj |
||
) |
Reset the iterator to the specified curve and component.
The component is a group of CVs belonging to the specified curve. The component defaults to MObject::kNullObj. If a component is not given then the iterator will be reset for the whole curve.
[in] | curve | Dag path to the curve for the iteration |
[in] | component | A group of CVs to be iterated on |
MPoint position | ( | MSpace::Space | space =
MSpace::kObject , |
MStatus * | ReturnStatus =
NULL |
||
) | const |
Return the position of the current CV.
[in] | space | the co-oordinate system for the returned point |
[out] | ReturnStatus | Status code |
MStatus setPosition | ( | const MPoint & | pt, |
MSpace::Space | space =
MSpace::kObject |
||
) |
Set the position of the current CV to the specified point.
[in] | pt | new position of CV |
[in] | space | the co-ordinate system for this transformation. |
MStatus translateBy | ( | const MVector & | vec, |
MSpace::Space | space =
MSpace::kObject |
||
) |
Translates the current CV by the amount specified in vec.
[in] | vec | translation to be applied to the CV |
[in] | space | the co-oordinate system for this transformation. |
int index | ( | MStatus * | ReturnStatus =
NULL |
) | const |
This method returns the index of the current CV in the CV array for this curve.
[out] | ReturnStatus | Status code |
This method is obsolete.
This method returns the current CV as an MObject.
[out] | ReturnStatus | Status code |
This method returns the current CV as an MObject.
[out] | ReturnStatus | Status code |
bool hasHistoryOnCreate | ( | MStatus * | ReturnStatus =
NULL |
) | const |
This method determines if the shape was created with history.
If the object that this iterator is attached to is not a shape then this method will fail.
[out] | ReturnStatus |
MStatus updateCurve | ( | ) |
This method is used to signal the curve that it has been changed and needs to redraw itself.
When modifying a large number of CVs, it is most efficient to call this method after all of the CVs have been modified.
const char * className | ( | ) | [static] |