119 lines
3.3 KiB
C++
Executable File
119 lines
3.3 KiB
C++
Executable File
#ifndef _MDagPathArray
|
|
#define _MDagPathArray
|
|
//
|
|
//-
|
|
// ==========================================================================
|
|
// Copyright (C) Alias|Wavefront, a division of Silicon Graphics Limited.
|
|
// All rights reserved. These coded instructions, statements and computer
|
|
// programs contain unpublished information proprietary to Alias|Wavefront,
|
|
// a division of Silicon Graphics Limited, which is protected by the
|
|
// Canadian and US federal copyright law and may not be disclosed to third
|
|
// parties or copied or duplicated, in whole or in part, without prior
|
|
// written consent of Alias|Wavefront, a division of Silicon Graphics Limited
|
|
// ==========================================================================
|
|
//+
|
|
//
|
|
// CLASS: MDagPathArray
|
|
//
|
|
// *****************************************************************************
|
|
//
|
|
// CLASS DESCRIPTION (MDagPathArray)
|
|
//
|
|
// The DAG Path Array Class provides methods for manipulating arrays of DAG
|
|
// Paths.
|
|
//
|
|
// Methods are provided for obtaining the DAG Path elements by index, clearing
|
|
// the array, determining the length of the array, and removing, inserting and
|
|
// appending array elements.
|
|
//
|
|
// *****************************************************************************
|
|
|
|
#if defined __cplusplus
|
|
|
|
// *****************************************************************************
|
|
|
|
// INCLUDED HEADER FILES
|
|
|
|
|
|
|
|
#include <maya/MTypes.h>
|
|
#include <maya/MStatus.h>
|
|
|
|
// *****************************************************************************
|
|
|
|
// DECLARATIONS
|
|
|
|
class MDagPath;
|
|
|
|
// *****************************************************************************
|
|
|
|
// CLASS DECLARATION (MDagPathArray)
|
|
|
|
/// Indexable Array of DAG Paths
|
|
/**
|
|
|
|
Provides methods for manipulating arrays of DAG Paths.
|
|
|
|
Arrays of DAG Paths are useful for storing and manipluating multiple Paths
|
|
to a particular DAG Node. The DAG Path method MDagPath::getAllPathsTo()
|
|
and DAG Node Function Set method MFnDagNode::getAllPaths() implicitly
|
|
return an array of DAG Paths.
|
|
|
|
These arrays may also be used to manage Paths for a number of different
|
|
Nodes.
|
|
|
|
DAG Path arrays are used in conjunction with DAG Paths (MDagPath) and
|
|
individual elements of the arrays can be parameters to some methods of the
|
|
DAG Node Function Set (MFnDagNode).
|
|
|
|
*/
|
|
#ifdef _WIN32
|
|
#pragma warning(disable: 4522)
|
|
#endif // _WIN32
|
|
|
|
class OPENMAYA_EXPORT MDagPathArray
|
|
{
|
|
|
|
public:
|
|
///
|
|
MDagPathArray();
|
|
///
|
|
~MDagPathArray();
|
|
///
|
|
const MDagPath& operator[]( unsigned index ) const;
|
|
///
|
|
MDagPath & operator[]( unsigned index );
|
|
///
|
|
MStatus setLength( unsigned length );
|
|
///
|
|
unsigned length() const;
|
|
///
|
|
MStatus remove( unsigned index );
|
|
///
|
|
MStatus insert( const MDagPath & element, unsigned index );
|
|
///
|
|
MStatus append( const MDagPath & element );
|
|
///
|
|
MStatus clear();
|
|
///
|
|
friend OPENMAYA_EXPORT IOS_REF(ostream) &operator<<(IOS_REF(ostream) &os,
|
|
const MDagPathArray &array);
|
|
|
|
protected:
|
|
// No protected members
|
|
|
|
private:
|
|
///
|
|
void * arr;
|
|
|
|
static const char* className();
|
|
};
|
|
|
|
#ifdef _WIN32
|
|
#pragma warning(default: 4522)
|
|
#endif // _WIN32
|
|
|
|
// *****************************************************************************
|
|
#endif /* __cplusplus */
|
|
#endif /* _MDagPathArray */
|