|
|
|
/*==LICENSE==*
|
|
|
|
|
|
|
|
CyanWorlds.com Engine - MMOG client, server and tools
|
|
|
|
Copyright (C) 2011 Cyan Worlds, Inc.
|
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
Additional permissions under GNU GPL version 3 section 7
|
|
|
|
|
|
|
|
If you modify this Program, or any covered work, by linking or
|
|
|
|
combining it with any of RAD Game Tools Bink SDK, Autodesk 3ds Max SDK,
|
|
|
|
NVIDIA PhysX SDK, Microsoft DirectX SDK, OpenSSL library, Independent
|
|
|
|
JPEG Group JPEG library, Microsoft Windows Media SDK, or Apple QuickTime SDK
|
|
|
|
(or a modified version of those libraries),
|
|
|
|
containing parts covered by the terms of the Bink SDK EULA, 3ds Max EULA,
|
|
|
|
PhysX SDK EULA, DirectX SDK EULA, OpenSSL and SSLeay licenses, IJG
|
|
|
|
JPEG Library README, Windows Media SDK EULA, or QuickTime SDK EULA, the
|
|
|
|
licensors of this Program grant you additional
|
|
|
|
permission to convey the resulting work. Corresponding Source for a
|
|
|
|
non-source form of such a combination shall include the source code for
|
|
|
|
the parts of OpenSSL and IJG JPEG Library used as well as that of the covered
|
|
|
|
work.
|
|
|
|
|
|
|
|
You can contact Cyan Worlds, Inc. by email legal@cyan.com
|
|
|
|
or by snail mail at:
|
|
|
|
Cyan Worlds, Inc.
|
|
|
|
14617 N Newport Hwy
|
|
|
|
Mead, WA 99021
|
|
|
|
|
|
|
|
*==LICENSE==*/
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
// //
|
|
|
|
// plGUIComponents Header //
|
|
|
|
// //
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _plGUIComponents_h
|
|
|
|
#define _plGUIComponents_h
|
|
|
|
|
|
|
|
#include "pnKeyedObject/plKey.h"
|
|
|
|
|
|
|
|
#include "plGUICompClassIDs.h"
|
|
|
|
#include "plComponent.h"
|
|
|
|
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
//// Component Class Definitions /////////////////////////////////////////////
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
//// Dialog Component ////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
class plMaxNode;
|
|
|
|
class pfGUIDialogMod;
|
|
|
|
class plErrorMsg;
|
|
|
|
|
|
|
|
class plGUIDialogComponent : public plComponent
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
void IMakeEveryoneOpaqueRecur( plMaxNode *node );
|
|
|
|
void IMakeEveryoneOpaque( plMaxNode *node );
|
|
|
|
|
|
|
|
pfGUIDialogMod *fDialogMod;
|
|
|
|
plKey fProcReceiver; // non-nil means to send out notifys as our proc
|
|
|
|
hsBool fSeqNumValidated;
|
|
|
|
|
|
|
|
virtual pfGUIDialogMod *IMakeDialog( void );
|
|
|
|
|
|
|
|
public:
|
|
|
|
// I believe booleans should always default to false, hence why this is dontInit instead of init. Byte me.
|
|
|
|
plGUIDialogComponent( hsBool dontInit = false );
|
|
|
|
void DeleteThis() { delete this; }
|
|
|
|
|
|
|
|
hsBool SetupProperties( plMaxNode *pNode, plErrorMsg *pErrMsg );
|
|
|
|
hsBool PreConvert( plMaxNode *pNode, plErrorMsg *pErrMsg );
|
|
|
|
hsBool Convert( plMaxNode *node, plErrorMsg *pErrMsg );
|
|
|
|
hsBool DeInit(plMaxNode *node, plErrorMsg *pErrMsg) { fProcReceiver = nil; return true;}
|
|
|
|
|
|
|
|
pfGUIDialogMod *GetModifier( void ) { return fDialogMod; }
|
|
|
|
|
|
|
|
// For those too lazy to get it from the modifier
|
|
|
|
// ... or can't trust that just because you have a modifier doesn't mean that you have a key :-) :-)
|
|
|
|
plKey GetModifierKey( void );
|
|
|
|
|
|
|
|
// Set this to have the dialog send out notify messages on events. Do it before Convert(). Returns false if it failed.
|
|
|
|
bool SetNotifyReceiver( plKey key );
|
|
|
|
|
|
|
|
static pfGUIDialogMod *GetNodeDialog( plMaxNode *childNode );
|
|
|
|
|
|
|
|
enum
|
|
|
|
{
|
|
|
|
kRefDialogName,
|
|
|
|
kRefIsModal,
|
|
|
|
kRefVersion,
|
|
|
|
kRefAgeName,
|
|
|
|
kRefDerivedStart
|
|
|
|
};
|
|
|
|
|
|
|
|
enum
|
|
|
|
{
|
|
|
|
kMainRollout,
|
|
|
|
kTagIDRollout,
|
|
|
|
kSchemeRollout
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
//// Control Component Base Class ////////////////////////////////////////////
|
|
|
|
|
|
|
|
class pfGUIControlMod;
|
|
|
|
class hsGMaterial;
|
|
|
|
|
|
|
|
class plGUIControlBase : public plComponent
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
|
|
|
|
pfGUIControlMod *fControl;
|
|
|
|
|
|
|
|
|
|
|
|
pfGUIDialogMod *IGetDialogMod( plMaxNode *node );
|
|
|
|
|
|
|
|
virtual pfGUIControlMod *IGetNewControl( void ) = 0;
|
|
|
|
virtual bool IHasProcRollout( void ) { return true; }
|
|
|
|
virtual bool INeedsDynamicText( void ) { return false; }
|
|
|
|
virtual bool ICanHaveProxy( void ) { return false; }
|
|
|
|
|
|
|
|
const char *ISetSoundIndex( ParamID checkBoxID, ParamID sndCompID, UInt8 guiCtrlEvent, plMaxNode *node );
|
|
|
|
|
|
|
|
|
|
|
|
// When converting, since we get a new instance per component but not per node,
|
|
|
|
// we need to keep track of which nodes we get PreConverted() on and the controls that
|
|
|
|
// get created for each. Then, on Convert(), we look up the node in our list and grab
|
|
|
|
// the right control. A pain, but what are you going to do?
|
|
|
|
hsTArray<plMaxNode *> fTargetNodes;
|
|
|
|
hsTArray<pfGUIControlMod *> fTargetControls;
|
|
|
|
|
|
|
|
public:
|
|
|
|
plGUIControlBase() {}
|
|
|
|
void DeleteThis() { delete this; }
|
|
|
|
|
|
|
|
hsBool SetupProperties( plMaxNode *pNode, plErrorMsg *pErrMsg );
|
|
|
|
hsBool PreConvert(plMaxNode *node, plErrorMsg *pErrMsg);
|
|
|
|
hsBool Convert(plMaxNode *node, plErrorMsg *pErrMsg);
|
|
|
|
|
|
|
|
virtual void CollectNonDrawables( INodeTab &nonDrawables );
|
|
|
|
|
|
|
|
virtual UInt32 GetNumMtls( void ) const { return 0; }
|
|
|
|
virtual Texmap *GetMtl( UInt32 idx ) { return nil; }
|
|
|
|
|
|
|
|
// Given a maxNode that is really a component, will return a pointer to the GUI control modifier
|
|
|
|
// created for it at export time. Only valid after PreConvert. If you think the control component
|
|
|
|
// might be applied to more than one sceneObject, then you better supply the sceneObject you're
|
|
|
|
// asking for as well to make sure you get the right control. If not, just leave the second
|
|
|
|
// parameter nil, but that can be VERY dangerous if the component results in more than one
|
|
|
|
// GUI control.
|
|
|
|
static pfGUIControlMod *GrabControlMod( INode *node, INode *sceneObjectNode = nil );
|
|
|
|
|
|
|
|
// Like GrabControlMod, but for when you already have a pointer to some kind of component
|
|
|
|
static pfGUIControlMod *ConvertCompToControl( plComponentBase *comp, INode *sceneObjectNode );
|
|
|
|
|
|
|
|
// Given a MAX object node, returns the one (and hopefully only) pfGUIControlMod attached to the scene object. Valid after PreConvert.
|
|
|
|
static pfGUIControlMod *GrabControlFromObject( INode *node );
|
|
|
|
|
|
|
|
// Given an INode, gives you a pointer to the GUI component if it actually is one, nil otherwise
|
|
|
|
static plGUIControlBase *GetGUIComp( INode *node );
|
|
|
|
|
|
|
|
// Or a plComponentBase...
|
|
|
|
static plGUIControlBase *GetGUIComp( plComponentBase *base );
|
|
|
|
|
|
|
|
enum
|
|
|
|
{
|
|
|
|
kBlkProc = plComponent::kBlkComp + 1,
|
|
|
|
kRollMain = 1,
|
|
|
|
kRollProc = 32,
|
|
|
|
kRollProxy = 33
|
|
|
|
};
|
|
|
|
|
|
|
|
enum
|
|
|
|
{
|
|
|
|
kRefChoice = 32,
|
|
|
|
kRefConsoleCmd
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
//// Pop-Up Menu Class ///////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
class pfGUIPopUpMenu;
|
|
|
|
class plGUIMenuComponent : public plGUIDialogComponent
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
|
|
|
|
virtual pfGUIDialogMod *IMakeDialog( void );
|
|
|
|
|
|
|
|
pfGUIPopUpMenu *fConvertedMenu;
|
|
|
|
plKey fConvertedNode;
|
|
|
|
|
|
|
|
public:
|
|
|
|
plGUIMenuComponent();
|
|
|
|
void DeleteThis() { delete this; }
|
|
|
|
|
|
|
|
virtual hsBool SetupProperties( plMaxNode *pNode, plErrorMsg *pErrMsg );
|
|
|
|
virtual hsBool PreConvert( plMaxNode *pNode, plErrorMsg *pErrMsg );
|
|
|
|
virtual hsBool Convert( plMaxNode *node, plErrorMsg *pErrMsg );
|
|
|
|
virtual hsBool DeInit(plMaxNode *node, plErrorMsg *pErrMsg);
|
|
|
|
|
|
|
|
plKey GetConvertedMenuKey( void ) const;
|
|
|
|
|
|
|
|
enum
|
|
|
|
{
|
|
|
|
kRefSkin = kRefDerivedStart,
|
|
|
|
kRefNeverClose,
|
|
|
|
kRefModalOutside,
|
|
|
|
kRefOpenOnHover,
|
|
|
|
kRefAlignment,
|
|
|
|
kRefScaleWithScreenRes
|
|
|
|
};
|
|
|
|
|
|
|
|
/* enum
|
|
|
|
{
|
|
|
|
kMainRollout,
|
|
|
|
kTagIDRollout,
|
|
|
|
kSchemeRollout
|
|
|
|
};
|
|
|
|
*/
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endif //_plGUIComponents_h
|