3ds Max C++ API Reference
IBaseGrip Class Referenceabstract

A pure virtual interface for implementing grips. More...

#include <igrip.h>

+ Inheritance diagram for IBaseGrip:

Classes

struct  ComboLabel
 The label and icon that make up each individual option for Type::eCombo grip item. More...
 
struct  GripValue
 The grip value that's used by the grip item when it's value is retrieved via GetValue or set via SetValue. More...
 

Public Types

enum  Type {
  eInvalid = -1 , eInt = 0 , eFloat , eTime ,
  eUniverse , eCombo , eToggle , eAction ,
  eCommand , eStatus
}
 
enum  Customization { eSameRow = 0x1 , eTurnOffLabel = 0x2 , eDisableAlt = 0x4 }
 
- Public Types inherited from BaseInterface
enum  LifetimeType { noRelease , immediateRelease , wantsRelease , serverControlled }
 

Public Member Functions

virtual ~IBaseGrip ()
 Deconstructor. More...
 
virtual void GetGripName (MSTR &string)=0
 Get the name of the grip. More...
 
virtual int GetNumGripItems ()=0
 Get the number of grip items this grip contains. More...
 
virtual IBaseGrip::Type GetType (int which)=0
 Get the type that the specified grip item will control. More...
 
virtual bool GetText (int which, MSTR &string)=0
 Get the name of the specified grip item. More...
 
virtual bool GetResolvedIconName (int which, MSTR &string)=0
 Get the file path of the icon that represents the specified grip item. More...
 
virtual DWORD GetCustomization (int which)=0
 Get any special customization flags that this grip item needs to follow. More...
 
virtual bool GetComboOptions (int which, Tab< ComboLabel * > &comboOptions)=0
 Get the option possibilities for this combo grip item. More...
 
virtual bool GetCommandIcon (int which, MSTR &string)=0
 Get an icon for the IBaseGrip::eCommand grip item. More...
 
virtual bool GetValue (int which, TimeValue t, IBaseGrip::GripValue &value)=0
 Get the value of the specified grip item. More...
 
virtual bool ShowKeyBrackets (int which, TimeValue t)=0
 Whether or not key brackets, which will show in a spinner that a key is present, should be shown at the specified time. More...
 
virtual bool GetRange (int which, IBaseGrip::GripValue &minRange, IBaseGrip::GripValue &maxRange)=0
 Get the range of this grip values. More...
 
virtual bool GetResetValue (int which, IBaseGrip::GripValue &resetValue)=0
 Get the reset value of the grip. More...
 
virtual bool ResetValue (TimeValue t, int which)=0
 Reset the specified grip. More...
 
Operations

The Okay, Cancel and Apply operations that a grip may implement.

virtual bool SupportsOkayApplyCancel ()=0
 Whether or not, the Okay, Apply and Cancel grip buttons will get shown or not. More...
 
virtual void Okay (TimeValue t)=0
 Accept any necessary changes and disable the grip to close the UI. More...
 
virtual void Cancel ()=0
 Disregard and cancel any necessary changes and disable the grip to close the UI. More...
 
virtual void Apply (TimeValue t)=0
 Accept any necessary changes and perform any pending action if needed. More...
 
Set Functions

Set of functions which are called when setting a value. Note that SetValue may be called multiple times within each StartSetValue \ EndSetValue pair.

virtual bool SetValue (int which, TimeValue t, IBaseGrip::GripValue &value)=0
 Set the value of the specified. More...
 
virtual bool StartSetValue (int which, TimeValue t)=0
 Get ready to set this value. More...
 
virtual bool EndSetValue (int which, TimeValue t, bool accepted)=0
 The value is done setting values. More...
 
Scaling Functions

Set of functions which are called when the grip is scaled by either incrementing or decrementing it. This value is the value that will thus added or subtracted from it. Only supports those grip items which have spinners.

virtual bool GetAutoScale (int which)=0
 Whether or nor we will use auto scaling when incrementing or decrementing this item. More...
 
virtual bool GetScale (int which, IBaseGrip::GripValue &scaleValue)=0
 Get the scale value for this item when we increment or decrement it. More...
 
virtual bool GetScaleInViewSpace (int which, float &depth)=0
 Get the scale value for this grip in view space, if one exists. More...
 
- Public Member Functions inherited from BaseInterface
virtual UtilExport ~BaseInterface ()
 Destructor. More...
 
UtilExport BaseInterfaceGetInterface (Interface_ID id) override
 
virtual UtilExport Interface_ID GetID ()
 
virtual LifetimeType LifetimeControl ()
 
virtual bool RegisterNotifyCallback (InterfaceNotifyCallback *incb)
 
virtual void UnRegisterNotifyCallback (InterfaceNotifyCallback *incb)
 
virtual BaseInterfaceAcquireInterface ()
 
virtual void ReleaseInterface ()
 
virtual void DeleteInterface ()
 
virtual BaseInterfaceCloneInterface (void *remapDir=nullptr)
 
- Public Member Functions inherited from InterfaceServer
virtual UtilExport ~InterfaceServer ()
 Destructor. More...
 
template<class InterfaceType >
InterfaceType * GetTypedInterface ()
 

Additional Inherited Members

- Static Public Member Functions inherited from MaxHeapOperators
static UtilExport voidoperator new (size_t size)
 Standard new operator used to allocate objects If there is insufficient memory, an exception will be thrown. More...
 
static UtilExport voidoperator new (size_t size, const std::nothrow_t &e)
 Standard new operator used to allocate objects if there is insufficient memory, NULL will be returned. More...
 
static UtilExport voidoperator new (size_t size, const char *filename, int line)
 New operator used to allocate objects that takes the filename and line number where the new was called If there is insufficient memory, an exception will be thrown. More...
 
static UtilExport voidoperator new (size_t size, int block_type, const char *filename, int line)
 New operator used to allocate objects that takes the type of memory, filename and line number where the new was called If there is insufficient memory, an exception will be thrown. More...
 
static UtilExport voidoperator new (size_t size, const std::nothrow_t &e, const char *filename, int line)
 New operator used to allocate objects that takes the filename and line number where the new was called If there is insufficient memory, NULL will be returned. More...
 
static UtilExport voidoperator new (size_t size, unsigned long flags)
 New operator used to allocate objects that takes extra flags to specify special operations If there is insufficient memory, an exception will be thrown. More...
 
static UtilExport voidoperator new (size_t size, const std::nothrow_t &e, unsigned long flags)
 New operator used to allocate objects that takes extra flags to specify special operations If there is insufficient memory, NULL will be returned. More...
 
static UtilExport voidoperator new[] (size_t size)
 New operator used to allocate arrays of objects If there is insufficient memory, an exception will be thrown. More...
 
static UtilExport voidoperator new[] (size_t size, const std::nothrow_t &e)
 New operator used to allocate arrays of objects If there is insufficient memory, NULL will be returned. More...
 
static UtilExport voidoperator new[] (size_t size, const char *filename, int line)
 New operator used to allocate arrays of objects If there is insufficient memory, an exception will be thrown. More...
 
static UtilExport voidoperator new[] (size_t size, int block_type, const char *filename, int line)
 New operator used to allocate arrays of objects. More...
 
static UtilExport voidoperator new[] (size_t size, const std::nothrow_t &e, const char *filename, int line)
 New operator used to allocate arrays of objects If there is insufficient memory, NULL will be returned. More...
 
static UtilExport voidoperator new[] (size_t size, unsigned long flags)
 New operator used to allocate arrays of objects If there is insufficient memory, an exception will be thrown. More...
 
static UtilExport voidoperator new[] (size_t size, const std::nothrow_t &e, unsigned long flags)
 New operator used to allocate arrays of objects If there is insufficient memory, NULL will be returned. More...
 
static UtilExport void operator delete (void *ptr)
 Standard delete operator used to deallocate an object If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport void operator delete (void *ptr, const std::nothrow_t &e)
 Standard delete operator used to deallocate an object If the pointer is invalid, nothing will happen. More...
 
static UtilExport void operator delete (void *ptr, const char *filename, int line)
 Delete operator used to deallocate an object that takes the filename and line number where the delete was called If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport void operator delete (void *ptr, int block_type, const char *filename, int line)
 Delete operator used to deallocate an object that takes the type of memory, filename and line number where the delete was called If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport void operator delete (void *ptr, const std::nothrow_t &e, const char *filename, int line)
 Delete operator used to deallocate an object that takes the filename and line number where the delete was called If the pointer is invalid, nothing will happen. More...
 
static UtilExport void operator delete (void *ptr, unsigned long flags)
 Delete operator used to deallocate an object that takes extra flags to specify special operations If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport void operator delete (void *ptr, const std::nothrow_t &e, unsigned long flags)
 Delete operator used to deallocate an object that takes extra flags to specify special operations If the pointer is invalid, nothing will happen. More...
 
static UtilExport void operator delete[] (void *ptr)
 Standard delete operator used to deallocate an array of objects If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport void operator delete[] (void *ptr, const std::nothrow_t &e)
 Standard delete operator used to deallocate an array of objects If the pointer is invalid, nothing will happen. More...
 
static UtilExport void operator delete[] (void *ptr, const char *filename, int line)
 Delete operator used to deallocate an array of objects that takes the filename and line number where the delete was called If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport void operator delete[] (void *ptr, int block_type, const char *filename, int line)
 Delete operator used to deallocate an array of objects that takes the type of memory, filename and line number where the delete was called If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport void operator delete[] (void *ptr, const std::nothrow_t &e, const char *filename, int line)
 Delete operator used to deallocate an array of objects that takes the filename and line number where the delete was called If the pointer is invalid, nothing will happen. More...
 
static UtilExport void operator delete[] (void *ptr, unsigned long flags)
 Delete operator used to deallocate an array of objects that takes extra flags to specify special operations If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport void operator delete[] (void *ptr, const std::nothrow_t &e, unsigned long flags)
 Delete operator used to deallocate an array of objects that takes extra flags to specify special operations If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport voidoperator new (size_t size, void *placement_ptr)
 Placement new operator. More...
 
static UtilExport void operator delete (void *ptr, void *placement_ptr)
 Placement delete operator. More...
 
static UtilExport voidaligned_malloc (size_t size, size_t alignment)
 Allocates memory on a specified alignment boundary. More...
 
static UtilExport voidaligned_realloc (void *ptr, size_t size, size_t alignment)
 Reallocates memory on a specified alignment boundary. More...
 
static UtilExport void aligned_free (void *ptr)
 Frees a block of memory that was allocated with aligned_malloc/aligned_realloc. More...
 

Detailed Description

A pure virtual interface for implementing grips.

A Grip or Caddy is a collection of modeless, transparent, in canvas UI elements that lets a user perform actions or modify values. A user can create their own grip by inheriting from IBaseGrip, implementing IBaseGrip's pure virtual functions, and then enable it on via the IGripManager interface. Based upon the number of grip items the grip contains and the type each item is, the system will create a set of in canvas UI representations for each item, which then interact with the IBaseGrip item via various functions. Usually the implementation of the IBaseGrip acts as a bridge between some existing data and the in canvas UI. For example if a grip was created to modify different soft selection values in a modifier, the grip would get the values from that modifier and then set the values back onto it. The grip itself will get displayed via the IGripManager::EnableGrip function which basically calls various IBaseGrip functions to set up the in canvas UI and then ferry messages to and from the UI to the grip.

See also
IGripManager. There are a collection of implemented grips present in the sdk at maxsdk\samples\mesh\editablepoly\polygrips.h, polygrips.cpp

Constructor & Destructor Documentation

◆ ~IBaseGrip()

virtual ~IBaseGrip ( )
inlinevirtual

Deconstructor.

38 {};

Member Function Documentation

◆ SupportsOkayApplyCancel()

virtual bool SupportsOkayApplyCancel ( )
pure virtual

Whether or not, the Okay, Apply and Cancel grip buttons will get shown or not.

Returns
If true the grip will have Okay, Apply and grip buttons that will then trigger the correct callback functions listed below. If false, then the grip won't show these buttons.

◆ Okay()

virtual void Okay ( TimeValue  t)
pure virtual

Accept any necessary changes and disable the grip to close the UI.

Basically do whatever operations you would do similar if the Okay button was pressed in a modeless dialog. Note that it's the implementations responsibility to disable the grip.

Parameters
[in]tThe time at which to perform the okay.

◆ Cancel()

virtual void Cancel ( )
pure virtual

Disregard and cancel any necessary changes and disable the grip to close the UI.

Basically do whatever operations you would do similar if the Cancel button was pressed in a modeless dialog. Note that it's the implementations responsibility to disable the grip.

◆ Apply()

virtual void Apply ( TimeValue  t)
pure virtual

Accept any necessary changes and perform any pending action if needed.

Unlike Okay, after an Apply the grip stays active and displayed.

Parameters
[in]tThe time at which to perform the apply.

◆ GetGripName()

virtual void GetGripName ( MSTR string)
pure virtual

Get the name of the grip.

Parameters
[out]stringThe name of the grip.

◆ GetNumGripItems()

virtual int GetNumGripItems ( )
pure virtual

Get the number of grip items this grip contains.

Returns
The number of grip items this grip contains.

◆ GetType()

virtual IBaseGrip::Type GetType ( int  which)
pure virtual

Get the type that the specified grip item will control.

Parameters
[in]whichThe zero based index of the item.
Returns
The type of the specified grip item. IBaseGrip::Type to see the different types that a grip item may be. The type that the grip item is determines what IBaseGrip::Value values the grip item supports. If the index is out of range then return Type::eInvalid.

◆ GetText()

virtual bool GetText ( int  which,
MSTR string 
)
pure virtual

Get the name of the specified grip item.

Parameters
[in]whichThe zero based index of the item.
[out]stringThe name of the specified grip item.
Returns
true if the operation succeeded, false otherwise.

◆ GetResolvedIconName()

virtual bool GetResolvedIconName ( int  which,
MSTR string 
)
pure virtual

Get the file path of the icon that represents the specified grip item.

Every grip item no matter it's type should try to provide an icon that represents the string that's returned by GetText.

Parameters
[in]whichThe zero based index of the grip item.
[out]stringThe name of the resolved path of the icon. It's this functions responsibility to resolve the path completely.
Returns
true if the operation succeeded, false otherwise.

◆ GetCustomization()

virtual DWORD GetCustomization ( int  which)
pure virtual

Get any special customization flags that this grip item needs to follow.

See also
IBaseGrip::Customization.
Parameters
[in]whichThe zero based index of the item.
Returns
Returns a bitwise union of IBaseGrip::Customization types, casted to a DWORD, that specify what if any customizations this grip item will have that differ from the default behavior of that grip item. Note that this customization is only checked when the grip is activated and its UI is constructed. Return zero if index is invalid or no customization occurs.

◆ GetComboOptions()

virtual bool GetComboOptions ( int  which,
Tab< ComboLabel * > &  comboOptions 
)
pure virtual

Get the option possibilities for this combo grip item.

Parameters
[in]whichThe zero based index of the item.
[out]comboOptionsA returned tab of labels that describes each possible option for the IBaseGrip::eCombo type grip button. These values will be presented in the UI as the possible options which can be selected. Note that it's the responsibility of the client of this function to delete each allocated ComboLabel pointer in the Tab.
Returns
Returns true if the options were correctly set up, false if not, for example if this grip item isn't a eCombo type.

◆ GetCommandIcon()

virtual bool GetCommandIcon ( int  which,
MSTR string 
)
pure virtual

Get an icon for the IBaseGrip::eCommand grip item.

Since a IBaseGrip::eCommand can have two different states,
the grip item can show additional icons, in addition to the one returned by GetResolvedIconName, to represent these states.

Parameters
[in]whichThe zero based index of the grip item.
[out]stringThe name of the resolved path of the icon. It's this functions responsibility to resolve the path completely.
Returns
Returns true if an icon was resolved up, false if not, for example if this grip item isn't a IBaseGrip::eCommmand type.

◆ GetValue()

virtual bool GetValue ( int  which,
TimeValue  t,
IBaseGrip::GripValue value 
)
pure virtual

Get the value of the specified grip item.

Parameters
[in]whichThe zero based index of the grip item.
[in]tThe time at which to get the value.
[out]valueThe value for that grip. See IBaseGrip::GripValue to see the values that are supported.
Returns
true if the operation succeeded, false otherwise.

◆ SetValue()

virtual bool SetValue ( int  which,
TimeValue  t,
IBaseGrip::GripValue value 
)
pure virtual

Set the value of the specified.

Parameters
[in]whichThe zero based index of the grip item.
[in]tThe time at which to set the value.
[in]valueThe value for that grip. See IBaseGrip::GripValue to see the values that are supported.
Returns
true if the operation succeeded, false otherwise.

◆ StartSetValue()

virtual bool StartSetValue ( int  which,
TimeValue  t 
)
pure virtual

Get ready to set this value.

Sometimes an item needs to do some setup before a value get's set, for example cache some values, or get ready for an undo. This is called before SetValue is called and SetValue may be called multiple times after StartSetValue is called.

Parameters
[in]whichThe zero based index of the grip item.
[in]tThe time at which to set the value.
Returns
true if the operation succeeded, false otherwise.

◆ EndSetValue()

virtual bool EndSetValue ( int  which,
TimeValue  t,
bool  accepted 
)
pure virtual

The value is done setting values.

Sometimes an item needs to do some cleanup after a value get's set, for example delete some cached values or accept an undo. This will get called immediately after the last SetValue function get's called.

Parameters
[in]whichThe zero based index of the grip item.
[in]tThe time at which the value was set.
[in]acceptedIf true the setvalue operation has succeeded and any undo's may be accepted if needed. If false then the setvalue operation was canceled and it's the implementors responsibility to rever the value back to it's original value it had when StartSetValue was called, for example it could do this by canceling the hold.
Returns
true if the operation succeeded, false otherwise.

◆ ShowKeyBrackets()

virtual bool ShowKeyBrackets ( int  which,
TimeValue  t 
)
pure virtual

Whether or not key brackets, which will show in a spinner that a key is present, should be shown at the specified time.


Usually this function will check to see if a key exists at this time.

Parameters
[in]whichThe zero based index of the grip item, which we are checking key brackets for. Will only check for those grip items which have spinners.
[in]tThe time at which we are checking to see if we should show a key bracket.
Returns
true if a key bracket should be shown at that time, false otherwise.

◆ GetAutoScale()

virtual bool GetAutoScale ( int  which)
pure virtual

Whether or nor we will use auto scaling when incrementing or decrementing this item.


Parameters
[in]whichThe zero based index of the grip item.
Returns
Returns true if the grip should auto scale this value, false if not.

◆ GetScale()

virtual bool GetScale ( int  which,
IBaseGrip::GripValue scaleValue 
)
pure virtual

Get the scale value for this item when we increment or decrement it.

Will normally only get used if GetAutoScale and GetSCaleInViewSpace returns false.

Parameters
[in]whichThe zero based index of the grip item.
[out]scaleValueThe value of the scale.
Returns
true if the operation succeeded, false otherwise.

◆ GetScaleInViewSpace()

virtual bool GetScaleInViewSpace ( int  which,
float &  depth 
)
pure virtual

Get the scale value for this grip in view space, if one exists.

Parameters
[in]whichThe zero based index of the grip item.
[out]depthThe screen space depth that the scale should use. /see ViewExp::MapScreenToView for a more in depth description on screen depth. -200 is usually a good default value.
Returns
Returns true if we should support scaling in view space, false if not. If false then we either using auto scaling or the normal incremental scale value specified by GetScale, based upon the result of GetAutoScale. Screen space scaling is used when dragging on a grip item spinner.

◆ GetRange()

virtual bool GetRange ( int  which,
IBaseGrip::GripValue minRange,
IBaseGrip::GripValue maxRange 
)
pure virtual

Get the range of this grip values.

Parameters
[in]whichThe grip item
[in]minRangeThe minimum range value for this grip. If the grip type is Type::eAction then no valid value is expected.
[in]maxRangeThe maximum range value for this grip. If the grip type is Type::eAction then no valid value is expected.
Returns
true if the operation succeeded, false otherwise.

◆ GetResetValue()

virtual bool GetResetValue ( int  which,
IBaseGrip::GripValue resetValue 
)
pure virtual

Get the reset value of the grip.

Parameters
[in]whichThe grip item whose reset value we will get.
[out]resetValueThe resetValue for that value. If the grip type is eAction then no valid value is expected.
Returns
true if the operation succeeded, false otherwise.

◆ ResetValue()

virtual bool ResetValue ( TimeValue  t,
int  which 
)
pure virtual

Reset the specified grip.

Parameters
[in]tThe time at which to reset.
[in]whichWhich grip item to reset.
Returns
true if the operation succeeded, false otherwise.