You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

390 lines
9.8 KiB

/*==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/>.
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==*/
//////////////////////////////////////////////
//
//
///////////////////////////////////////////////
#include "pyKey.h"
#include "pyColor.h"
#include "cyPythonInterface.h"
#include "../pfGameGUIMgr/pfGameGUIMgr.h"
#include "../pfGameGUIMgr/pfGUIPopUpMenu.h"
#include "pyGUIPopUpMenu.h"
// the rest of the controls
#include "pyGUIControlButton.h"
#include "pyGUIControlCheckBox.h"
#include "pyGUIControlEditBox.h"
#include "pyGUIControlListBox.h"
#include "pyGUIControlRadioGroup.h"
#include "pyGUIControlTextBox.h"
#include "pyGUIControlValue.h"
#include "pyGUIControlDynamicText.h"
#include "pyGUIControlMultiLineEdit.h"
#include "../pfGameGUIMgr/pfGUIControlHandlers.h"
#define kGetMenuPtr( ret ) if( fGCkey == nil ) return ret; \
pfGUIPopUpMenu *menu = pfGUIPopUpMenu::ConvertNoRef( fGCkey->ObjectIsLoaded() ); \
if( menu == nil ) return ret;
pyGUIPopUpMenu::pyGUIPopUpMenu(pyKey& gckey)
{
fGCkey = gckey.getKey();
fBuiltMenu = nil;
}
pyGUIPopUpMenu::pyGUIPopUpMenu(plKey objkey)
{
fGCkey = objkey;
fBuiltMenu = nil;
}
pyGUIPopUpMenu::pyGUIPopUpMenu()
{
fGCkey = nil;
fBuiltMenu = nil;
}
pyGUIPopUpMenu::pyGUIPopUpMenu( const char *name, hsScalar screenOriginX, hsScalar screenOriginY, const plLocation &destLoc/* = plLocation::kGlobalFixedLoc */)
{
fBuiltMenu = pfGUIPopUpMenu::Build( name, nil, screenOriginX, screenOriginY, destLoc );
if( fBuiltMenu != nil )
{
fGCkey = fBuiltMenu->GetKey();
fGCkey->RefObject();
}
else
fGCkey = nil;
}
pyGUIPopUpMenu::pyGUIPopUpMenu( const char *name, pyGUIPopUpMenu &parent, hsScalar screenOriginX, hsScalar screenOriginY )
{
pfGUIPopUpMenu *parentMenu = pfGUIPopUpMenu::ConvertNoRef( parent.fGCkey->ObjectIsLoaded() );
const plLocation &parentLoc = ( parentMenu != nil ) ? parentMenu->GetKey()->GetUoid().GetLocation() : plLocation::kGlobalFixedLoc;
fBuiltMenu = pfGUIPopUpMenu::Build( name, parentMenu, screenOriginX, screenOriginY, parentLoc );
if( fBuiltMenu != nil )
{
fGCkey = fBuiltMenu->GetKey();
fGCkey->RefObject();
}
else
fGCkey = nil;
}
pyGUIPopUpMenu::~pyGUIPopUpMenu()
{
// Optimistic, I know, to assume the destructor will be called, but still...
if( fBuiltMenu != nil )
{
fBuiltMenu->GetKey()->UnRefObject();
fBuiltMenu = nil;
}
}
void pyGUIPopUpMenu::setup(plKey objkey)
{
// kill any previous menu
if( fBuiltMenu != nil )
{
fBuiltMenu->GetKey()->UnRefObject();
fBuiltMenu = nil;
}
// setup the new one
fGCkey = objkey;
}
void pyGUIPopUpMenu::setup(const char *name, hsScalar screenOriginX, hsScalar screenOriginY, const plLocation &destLoc /* = plLocation::kGlobalFixedLoc */)
{
// kill any previous menu
if( fBuiltMenu != nil )
{
fBuiltMenu->GetKey()->UnRefObject();
fBuiltMenu = nil;
}
// setup the new one
fBuiltMenu = pfGUIPopUpMenu::Build( name, nil, screenOriginX, screenOriginY, destLoc );
if( fBuiltMenu != nil )
{
fGCkey = fBuiltMenu->GetKey();
fGCkey->RefObject();
}
else
fGCkey = nil;
}
void pyGUIPopUpMenu::setup(const char *name, pyGUIPopUpMenu &parent, hsScalar screenOriginX, hsScalar screenOriginY)
{
// kill any previous menu
if( fBuiltMenu != nil )
{
fBuiltMenu->GetKey()->UnRefObject();
fBuiltMenu = nil;
}
// setup the new one
pfGUIPopUpMenu *parentMenu = pfGUIPopUpMenu::ConvertNoRef( parent.fGCkey->ObjectIsLoaded() );
const plLocation &parentLoc = ( parentMenu != nil ) ? parentMenu->GetKey()->GetUoid().GetLocation() : plLocation::kGlobalFixedLoc;
fBuiltMenu = pfGUIPopUpMenu::Build( name, parentMenu, screenOriginX, screenOriginY, parentLoc );
if( fBuiltMenu != nil )
{
fGCkey = fBuiltMenu->GetKey();
fGCkey->RefObject();
}
else
fGCkey = nil;
}
hsBool pyGUIPopUpMenu::IsGUIPopUpMenu(pyKey& gckey)
{
if ( gckey.getKey() && pfGUIPopUpMenu::ConvertNoRef(gckey.getKey()->GetObjectPtr()) )
return true;
return false;
}
// override the equals to operator
hsBool pyGUIPopUpMenu::operator==(const pyGUIPopUpMenu &gcobj) const
{
plKey theirs = ((pyGUIPopUpMenu&)gcobj).getObjKey();
if ( fGCkey == nil && theirs == nil )
return true;
else if ( fGCkey != nil && theirs != nil )
return (fGCkey->GetUoid()==theirs->GetUoid());
else
return false;
}
// getter and setters
plKey pyGUIPopUpMenu::getObjKey()
{
return fGCkey;
}
PyObject* pyGUIPopUpMenu::getObjPyKey()
{
// create a pyKey object that Python will manage
return pyKey::New(fGCkey);
}
// interface functions
UInt32 pyGUIPopUpMenu::GetTagID()
{
kGetMenuPtr( 0 );
return menu->GetTagID();
}
void pyGUIPopUpMenu::SetEnabled( hsBool e )
{
kGetMenuPtr( ; );
menu->SetEnabled(e);
}
hsBool pyGUIPopUpMenu::IsEnabled( void )
{
kGetMenuPtr( false );
return menu->IsEnabled();
}
const char* pyGUIPopUpMenu::GetName( void )
{
kGetMenuPtr( "" );
return menu->GetName();
}
UInt32 pyGUIPopUpMenu::GetVersion(void)
{
kGetMenuPtr( 0 );
return menu->GetVersion();
}
void pyGUIPopUpMenu::Show( void )
{
kGetMenuPtr( ; );
( (pfGUIDialogMod *)menu )->Show();
}
void pyGUIPopUpMenu::Hide( void )
{
kGetMenuPtr( ; );
menu->Hide();
}
// get color schemes
PyObject* pyGUIPopUpMenu::GetForeColor()
{
kGetMenuPtr( nil );
pfGUIColorScheme* color = menu->GetColorScheme();
return pyColor::New(color->fForeColor.r,color->fForeColor.g,color->fForeColor.b,color->fForeColor.a);
}
PyObject* pyGUIPopUpMenu::GetSelColor()
{
kGetMenuPtr( nil );
pfGUIColorScheme* color = menu->GetColorScheme();
return pyColor::New(color->fSelForeColor.r,color->fSelForeColor.g,color->fSelForeColor.b,color->fSelForeColor.a);
}
PyObject* pyGUIPopUpMenu::GetBackColor()
{
kGetMenuPtr( nil );
pfGUIColorScheme* color = menu->GetColorScheme();
return pyColor::New(color->fBackColor.r,color->fBackColor.g,color->fBackColor.b,color->fBackColor.a);
}
PyObject* pyGUIPopUpMenu::GetBackSelColor()
{
kGetMenuPtr( nil );
pfGUIColorScheme* color = menu->GetColorScheme();
return pyColor::New(color->fSelBackColor.r,color->fSelBackColor.g,color->fSelBackColor.b,color->fSelBackColor.a);
}
// set color scheme
void pyGUIPopUpMenu::SetForeColor( hsScalar r, hsScalar g, hsScalar b, hsScalar a )
{
kGetMenuPtr( ; );
pfGUIColorScheme* color = menu->GetColorScheme();
if ( r >= 0.0 && r <= 1.0 )
color->fForeColor.r = r;
if ( g >= 0.0 && g <= 1.0 )
color->fForeColor.g = g;
if ( b >= 0.0 && g <= 1.0 )
color->fForeColor.b = b;
if ( a >= 0.0 && g <= 1.0 )
color->fForeColor.a = a;
}
void pyGUIPopUpMenu::SetSelColor( hsScalar r, hsScalar g, hsScalar b, hsScalar a )
{
kGetMenuPtr( ; );
pfGUIColorScheme* color = menu->GetColorScheme();
if ( r >= 0.0 && r <= 1.0 )
color->fSelForeColor.r = r;
if ( g >= 0.0 && g <= 1.0 )
color->fSelForeColor.g = g;
if ( b >= 0.0 && g <= 1.0 )
color->fSelForeColor.b = b;
if ( a >= 0.0 && g <= 1.0 )
color->fSelForeColor.a = a;
}
void pyGUIPopUpMenu::SetBackColor( hsScalar r, hsScalar g, hsScalar b, hsScalar a )
{
kGetMenuPtr( ; );
pfGUIColorScheme* color = menu->GetColorScheme();
if ( r >= 0.0 && r <= 1.0 )
color->fBackColor.r = r;
if ( g >= 0.0 && g <= 1.0 )
color->fBackColor.g = g;
if ( b >= 0.0 && g <= 1.0 )
color->fBackColor.b = b;
if ( a >= 0.0 && g <= 1.0 )
color->fBackColor.a = a;
}
void pyGUIPopUpMenu::SetBackSelColor( hsScalar r, hsScalar g, hsScalar b, hsScalar a )
{
kGetMenuPtr( ; );
pfGUIColorScheme* color = menu->GetColorScheme();
if ( r >= 0.0 && r <= 1.0 )
color->fSelBackColor.r = r;
if ( g >= 0.0 && g <= 1.0 )
color->fSelBackColor.g = g;
if ( b >= 0.0 && g <= 1.0 )
color->fSelBackColor.b = b;
if ( a >= 0.0 && g <= 1.0 )
color->fSelBackColor.a = a;
}
void pyGUIPopUpMenu::AddConsoleCmdItem( const char *name, const char *consoleCmd )
{
wchar_t *wName = hsStringToWString(name);
AddConsoleCmdItemW(wName,consoleCmd);
delete [] wName;
}
void pyGUIPopUpMenu::AddConsoleCmdItemW( std::wstring name, const char *consoleCmd )
{
kGetMenuPtr( ; );
menu->AddItem( name.c_str(), TRACKED_NEW pfGUIConsoleCmdProc( consoleCmd ), nil );
}
void pyGUIPopUpMenu::AddNotifyItem( const char *name )
{
wchar_t *wName = hsStringToWString(name);
AddNotifyItemW(wName);
delete [] wName;
}
void pyGUIPopUpMenu::AddNotifyItemW( std::wstring name )
{
kGetMenuPtr( ; );
menu->AddItem( name.c_str(), (pfGUICtrlProcObject *)( menu->GetHandler() ), nil );
}
void pyGUIPopUpMenu::AddSubMenuItem( const char *name, pyGUIPopUpMenu &subMenu )
{
wchar_t *wName = hsStringToWString(name);
AddSubMenuItemW(wName,subMenu);
delete [] wName;
}
void pyGUIPopUpMenu::AddSubMenuItemW( std::wstring name, pyGUIPopUpMenu &subMenu )
{
kGetMenuPtr( ; );
if( subMenu.fGCkey == nil )
return;
pfGUIPopUpMenu *subM = pfGUIPopUpMenu::ConvertNoRef( subMenu.fGCkey->ObjectIsLoaded() );
if( subM == nil )
return;
menu->AddItem( name.c_str(), nil, subM );
}