Files
eepp/src/ui/cuicomplexcontrol.cpp
spartanj 9f4f013a9e Added cUISelectButton control.
Added cUIWinMenu control ( window menu ).
Some minor changes on the UI controls.
2011-04-18 19:45:13 -03:00

160 lines
3.9 KiB
C++

#include "cuicomplexcontrol.hpp"
#include "cuimanager.hpp"
namespace EE { namespace UI {
cUIComplexControl::cUIComplexControl( const cUIComplexControl::CreateParams& Params ) :
cUIControlAnim( Params ),
mTooltip( NULL ),
mMinControlSize( Params.MinControlSize )
{
mType |= UI_TYPE_GET( UI_TYPE_CONTROL_COMPLEX );
CalcDistToBorder();
TooltipText( Params.TooltipText );
}
cUIComplexControl::~cUIComplexControl() {
eeSAFE_DELETE( mTooltip );
}
void cUIComplexControl::CalcDistToBorder() {
mDistToBorder = eeVector2i( mParentCtrl->Size().x - ( mPos.x + mSize.x ), mParentCtrl->Size().y - ( mPos.y + mSize.y ) );
}
void cUIComplexControl::Update() {
if ( mVisible && NULL != mTooltip && mTooltip->Text().size() ) {
if ( IsMouseOverMeOrChilds() ) {
eeVector2i Pos = cUIManager::instance()->GetMousePos();
Pos.x += cUIThemeManager::instance()->CursorSize().x;
Pos.y += cUIThemeManager::instance()->CursorSize().y;
if ( Pos.x + mTooltip->Size().Width() > cUIManager::instance()->MainControl()->Size().Width() ) {
Pos.x = cUIManager::instance()->GetMousePos().x - mTooltip->Size().Width();
}
if ( Pos.y + mTooltip->Size().Height() > cUIManager::instance()->MainControl()->Size().Height() ) {
Pos.y = cUIManager::instance()->GetMousePos().y - mTooltip->Size().Height();
}
if ( 0 == cUIThemeManager::instance()->TooltipTimeToShow() ) {
if ( !mTooltip->Visible() || cUIThemeManager::instance()->TooltipFollowMouse() )
mTooltip->Pos( Pos );
mTooltip->Show();
} else {
if ( -1.f != mTooltip->TooltipTime() ) {
mTooltip->TooltipTimeAdd( cUIManager::instance()->Elapsed() );
}
if ( mTooltip->TooltipTime() >= cUIThemeManager::instance()->TooltipTimeToShow() ) {
if ( mTooltip->TooltipTime() != -1.f ) {
mTooltip->Pos( Pos );
mTooltip->Show();
mTooltip->TooltipTime( -1.f );
}
}
}
if ( cUIThemeManager::instance()->TooltipFollowMouse() ) {
mTooltip->Pos( Pos );
}
} else {
mTooltip->TooltipTime( 0.f );
if ( mTooltip->Visible() )
mTooltip->Hide();
}
}
cUIControlAnim::Update();
}
void cUIComplexControl::CreateTooltip() {
if ( NULL != mTooltip )
return;
cUITooltip::CreateParams Params;
Params.Parent( cUIManager::instance()->MainControl() );
Params.Flags = UI_VALIGN_CENTER | UI_HALIGN_CENTER | UI_AUTO_PADDING | UI_AUTO_SIZE;
mTooltip = eeNew( cUITooltip, ( Params, this ) );
}
void cUIComplexControl::TooltipText( const String& Text ) {
if ( NULL == mTooltip ) { // If the tooltip wasn't created it will avoid to create a new one if the string is ""
if ( Text.size() ) {
CreateTooltip();
mTooltip->Text( Text );
}
} else { // but if it's created, i will allow it
mTooltip->Text( Text );
}
}
String cUIComplexControl::TooltipText() {
if ( NULL != mTooltip )
return mTooltip->Text();
return String();
}
void cUIComplexControl::TooltipRemove() {
mTooltip = NULL;
}
void cUIComplexControl::Size( const eeSize &Size ) {
eeSize s( Size );
if ( s.x < mMinControlSize.x )
s.x = mMinControlSize.x;
if ( s.y < mMinControlSize.y )
s.y = mMinControlSize.y;
cUIControlAnim::Size( s );
}
void cUIComplexControl::Size( const Int32& Width, const Int32& Height ) {
cUIControlAnim::Size( Width, Height );
}
const eeSize& cUIComplexControl::Size() {
return cUIControlAnim::Size();
}
void cUIComplexControl::OnParentSizeChange() {
eeSize newSize( mSize );
if ( mFlags & UI_ANCHOR_LEFT ) {
// Nothing ?
}
if ( mFlags & UI_ANCHOR_RIGHT ) {
newSize.x = mParentCtrl->Size().Width() - mPos.x - mDistToBorder.x;
if ( newSize.x < mMinControlSize.Width() )
newSize.y = mMinControlSize.Width();
}
if ( mFlags & UI_ANCHOR_TOP ) {
// Nothing ?
}
if ( mFlags & UI_ANCHOR_BOTTOM ) {
newSize.y = Parent()->Size().y - mPos.y - mDistToBorder.y;
if ( newSize.y < mMinControlSize.Height() )
newSize.y = mMinControlSize.Height();
}
Size( newSize );
cUIControlAnim::OnParentSizeChange();
}
}}