Initial commit
This commit is contained in:
204
Torque/SDK/lib/mayasdk5/include/maya/MLockMessage.h
Normal file
204
Torque/SDK/lib/mayasdk5/include/maya/MLockMessage.h
Normal file
@@ -0,0 +1,204 @@
|
||||
#ifndef LINUX
|
||||
#pragma once
|
||||
#endif
|
||||
#ifndef _MLockMessage
|
||||
#define _MLockMessage
|
||||
//
|
||||
// *****************************************************************************
|
||||
//
|
||||
// Copyright (C) 1998-2003 Alias|Wavefront Inc.
|
||||
//
|
||||
// These coded instructions, statements and computer programs contain
|
||||
// unpublished information proprietary to Alias|Wavefront Inc. and are
|
||||
// protected by Canadian and US federal copyright laws. They may not be
|
||||
// disclosed to third parties or copied or duplicated, in whole or in part,
|
||||
// without prior written consent of Alias|Wavefront Inc.
|
||||
//
|
||||
// Unpublished-rights reserved under the Copyright Laws of the United States.
|
||||
//
|
||||
// *****************************************************************************
|
||||
//
|
||||
// CLASS: MLockMessage
|
||||
//
|
||||
// *****************************************************************************
|
||||
//
|
||||
// CLASS DESCRIPTION (MLockMessage)
|
||||
//
|
||||
// This class is used to register callbacks for conditional node and
|
||||
// plug locking. These callbacks allow you to intercept events that
|
||||
// involve the internal testing of the lock flag on a node or
|
||||
// plug. If the node, or plug, is locked the assigned API callback
|
||||
// routine, if attached to the node, will be invoked, and, at this
|
||||
// time, you have the option to override the lock. This allows the
|
||||
// API programmer the ability to ignore a lock and allow a lock event
|
||||
// to occur. This allows the API programmer to adjust the level of
|
||||
// granularity on the locking mechanism. There are three levels of
|
||||
// locking callbacks.
|
||||
//
|
||||
// \begin{itemize}
|
||||
// \item {\bf DAG Level Events}
|
||||
// \item {\bf All Other Node Level Events}
|
||||
// \item {\bf Plug Level Events}
|
||||
// \end{itemize}
|
||||
//
|
||||
// To remove a callback use MMessage::removeCallback. All callbacks
|
||||
// that are registered by a plug-in must be removed by that plug-in
|
||||
// when it is unloaded. Failure to do so will result in a fatal error.
|
||||
//
|
||||
// *****************************************************************************
|
||||
|
||||
#if defined __cplusplus
|
||||
|
||||
// *****************************************************************************
|
||||
|
||||
// INCLUDED HEADER FILES
|
||||
|
||||
#include <maya/MMessage.h>
|
||||
|
||||
// *****************************************************************************
|
||||
|
||||
// DECLARATIONS
|
||||
|
||||
class MPlug;
|
||||
class MObject;
|
||||
class MDGModifier;
|
||||
class MDagPath;
|
||||
|
||||
// *****************************************************************************
|
||||
|
||||
// CLASS DECLARATION (MLockMessage)
|
||||
|
||||
/// Node/plug locking messages.
|
||||
/**
|
||||
*/
|
||||
#ifdef _WIN32
|
||||
#pragma warning(disable: 4522)
|
||||
#endif // _WIN32
|
||||
|
||||
class OPENMAYA_EXPORT MLockMessage : public MMessage
|
||||
{
|
||||
public:
|
||||
/// Plug related locking events
|
||||
enum LockPlugEvent {
|
||||
/// An invalid plug event received.
|
||||
kInvalidPlug = 0,
|
||||
/// User is trying to lock the plug.
|
||||
kPlugLockAttr,
|
||||
/// User is trying to unlock the plug.
|
||||
kPlugUnlockAttr,
|
||||
/// Plug lock query on plug value change.
|
||||
kPlugAttrValChange,
|
||||
/// Plug lock query on a remove attribute event.
|
||||
kPlugRemoveAttr,
|
||||
/// Plug lock query on a rename attribute event.
|
||||
kPlugRenameAttr,
|
||||
/// Plug lock query on a connect to a locked attribute.
|
||||
kPlugConnect,
|
||||
/// Plug lock query on a disconnect from a locked source attribute.
|
||||
kPlugDisconnect,
|
||||
/// Used for internal bounds checking.
|
||||
kLastPlug
|
||||
};
|
||||
|
||||
/// DAG related locking events
|
||||
enum LockDAGEvent {
|
||||
/// Invalid DAG event received.
|
||||
kInvalidDAG = 0,
|
||||
/// Lock query on group action.
|
||||
kGroup,
|
||||
/// Lock query on ungroup action.
|
||||
kUnGroup,
|
||||
/// Lock query on reparent action.
|
||||
kReparent,
|
||||
/// Lock query on a child add action.
|
||||
kChildReorder,
|
||||
/// Lock query on an instance event.
|
||||
kCreateNodeInstance,
|
||||
/// Lock query on node whose children will be instanced.
|
||||
kCreateChildInstance,
|
||||
/// Lock query on node whose parent will be instanced.
|
||||
kCreateParentInstance,
|
||||
/// Used for internal bounds checking.
|
||||
kLastDAG
|
||||
};
|
||||
|
||||
/// Miscellaneous lock event types
|
||||
enum LockEvent {
|
||||
/// Invalid node lock event received.
|
||||
kInvalid = 0,
|
||||
/// Lock query on a rename event.
|
||||
kRename,
|
||||
/// Lock query on a delete event.
|
||||
kDelete,
|
||||
/// Lock query on a lock event.
|
||||
kLockNode,
|
||||
/// Lock query on an unlock event.
|
||||
kUnlockNode,
|
||||
/// Lock query on an add attribute event.
|
||||
kAddAttr,
|
||||
/// Lock query on an remove attribute event.
|
||||
kRemoveAttr,
|
||||
/// Lock query on an rename attribute event.
|
||||
kRenameAttr,
|
||||
/// Lock query on an unlock attribute event.
|
||||
kUnlockAttr,
|
||||
/// Lock query on a lock attribute event.
|
||||
kLockAttr,
|
||||
/// Used for internal bounds checking.
|
||||
kLast
|
||||
};
|
||||
|
||||
public:
|
||||
///
|
||||
static MCallbackId setNodeLockQueryCallback(
|
||||
MObject& node,
|
||||
void (*func)( MObject &node,
|
||||
MObject &aux,
|
||||
void *clientData,
|
||||
LockEvent eventType,
|
||||
bool &decision ),
|
||||
void *clientData = NULL,
|
||||
MStatus *status = NULL );
|
||||
///
|
||||
static MCallbackId setNodeLockDAGQueryCallback(
|
||||
MDagPath& path,
|
||||
void (*func)( MDagPath &dagPath,
|
||||
MDagPath &otherPath,
|
||||
void *clientData,
|
||||
LockDAGEvent eventType,
|
||||
bool &decision ),
|
||||
void *clientData = NULL,
|
||||
MStatus *status = NULL );
|
||||
///
|
||||
static MCallbackId setPlugLockQueryCallback(
|
||||
MPlug& plug,
|
||||
void (*func)( MPlug &plug,
|
||||
MPlug &otherPlug,
|
||||
void *clientData,
|
||||
LockPlugEvent eventType,
|
||||
bool &decision ),
|
||||
void *clientData = NULL,
|
||||
MStatus *status = NULL );
|
||||
///
|
||||
static MCallbackId setPlugLockQueryCallback(
|
||||
MObject& node,
|
||||
void (*func)( MPlug &plug,
|
||||
MPlug &otherPlug,
|
||||
void *clientData,
|
||||
LockPlugEvent eventType,
|
||||
bool &decision ),
|
||||
void *clientData = NULL,
|
||||
MStatus *status = NULL );
|
||||
|
||||
private:
|
||||
static const char* className();
|
||||
};
|
||||
|
||||
#ifdef _WIN32
|
||||
#pragma warning(default: 4522)
|
||||
#endif // _WIN32
|
||||
|
||||
// *****************************************************************************
|
||||
|
||||
#endif /* __cplusplus */
|
||||
#endif /* _MLockMessage */
|
||||
Reference in New Issue
Block a user