2009-09-08 12:08:10 +00:00
|
|
|
/* PCSX2 - PS2 Emulator for PCs
|
2010-05-03 14:08:02 +00:00
|
|
|
* Copyright (C) 2002-2010 PCSX2 Dev Team
|
2009-09-17 02:12:32 +00:00
|
|
|
*
|
2009-09-08 12:08:10 +00:00
|
|
|
* PCSX2 is free software: you can redistribute it and/or modify it under the terms
|
|
|
|
* of the GNU Lesser General Public License as published by the Free Software Found-
|
|
|
|
* ation, either version 3 of the License, or (at your option) any later version.
|
2009-07-04 20:53:05 +00:00
|
|
|
*
|
2009-09-08 12:08:10 +00:00
|
|
|
* PCSX2 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.
|
2009-07-04 20:53:05 +00:00
|
|
|
*
|
2009-09-08 12:08:10 +00:00
|
|
|
* You should have received a copy of the GNU General Public License along with PCSX2.
|
|
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
2009-07-04 20:53:05 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "PrecompiledHeader.h"
|
2009-11-23 06:54:24 +00:00
|
|
|
#include "wxGuiTools.h"
|
2009-11-18 07:53:02 +00:00
|
|
|
#include "pxStaticText.h"
|
2010-01-22 15:22:01 +00:00
|
|
|
#include "Threading.h"
|
2010-06-06 23:26:07 +00:00
|
|
|
#include "IniInterface.h"
|
2009-07-04 20:53:05 +00:00
|
|
|
|
2014-08-03 18:11:22 +00:00
|
|
|
#ifdef __linux__
|
2011-05-02 19:11:00 +00:00
|
|
|
// I do not know if it is a GCC issue or a bug in wxwidget !
|
|
|
|
// Anyway the code isn't used (m_hasContextHelp always false) so I remove
|
|
|
|
// it for linux. The 'vtable' issue appears with the include of
|
|
|
|
// <wx/cshelp.h> -- Gregory
|
|
|
|
#define GCC_4_6_LTO_COMPILATION_ISSUE
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef GCC_4_6_LTO_COMPILATION_ISSUE
|
2009-07-04 20:53:05 +00:00
|
|
|
#include <wx/cshelp.h>
|
2011-05-02 19:11:00 +00:00
|
|
|
#endif
|
2009-11-18 07:53:02 +00:00
|
|
|
#include <wx/tooltip.h>
|
2010-01-04 11:51:09 +00:00
|
|
|
#include <wx/spinctrl.h>
|
2009-07-04 20:53:05 +00:00
|
|
|
|
2009-11-25 15:38:24 +00:00
|
|
|
using namespace pxSizerFlags;
|
|
|
|
|
2010-06-04 19:50:31 +00:00
|
|
|
pxDialogCreationFlags pxDialogFlags()
|
|
|
|
{
|
2010-06-06 23:26:07 +00:00
|
|
|
return pxDialogCreationFlags().CloseBox().Caption().Vertical();
|
2010-06-04 19:50:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-01-22 15:22:01 +00:00
|
|
|
// --------------------------------------------------------------------------------------
|
2010-04-27 13:12:03 +00:00
|
|
|
// BaseDeletableObject Implementation
|
2010-01-22 15:22:01 +00:00
|
|
|
// --------------------------------------------------------------------------------------
|
|
|
|
// This code probably deserves a better home. It's general purpose non-GUI code (the single
|
|
|
|
// wxApp/Gui dependency is in wxGuiTools.cpp for now).
|
|
|
|
//
|
2010-04-27 13:12:03 +00:00
|
|
|
bool BaseDeletableObject::MarkForDeletion()
|
2010-01-22 15:22:01 +00:00
|
|
|
{
|
2015-01-18 18:25:46 +00:00
|
|
|
return !_InterlockedExchange( &m_IsBeingDeleted, true );
|
2010-01-22 15:22:01 +00:00
|
|
|
}
|
|
|
|
|
2010-04-27 13:12:03 +00:00
|
|
|
void BaseDeletableObject::DeleteSelf()
|
2010-01-22 15:22:01 +00:00
|
|
|
{
|
|
|
|
if( MarkForDeletion() )
|
|
|
|
DoDeletion();
|
|
|
|
}
|
|
|
|
|
2010-04-27 13:12:03 +00:00
|
|
|
BaseDeletableObject::BaseDeletableObject()
|
2010-01-22 15:22:01 +00:00
|
|
|
{
|
|
|
|
#ifdef _MSC_VER
|
|
|
|
// Bleh, this fails because _CrtIsValidHeapPointer calls HeapValidate on the
|
|
|
|
// pointer, but the pointer is a virtual base class, so it's not a valid block. >_<
|
2010-04-27 13:12:03 +00:00
|
|
|
//pxAssertDev( _CrtIsValidHeapPointer( this ), "BaseDeletableObject types cannot be created on the stack or as temporaries!" );
|
2010-01-22 15:22:01 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
m_IsBeingDeleted = false;
|
|
|
|
}
|
|
|
|
|
2010-04-27 13:12:03 +00:00
|
|
|
BaseDeletableObject::~BaseDeletableObject() throw()
|
2010-01-22 15:22:01 +00:00
|
|
|
{
|
2010-04-27 13:12:03 +00:00
|
|
|
AffinityAssert_AllowFrom_MainUI();
|
2010-01-22 15:22:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
2010-01-04 11:51:09 +00:00
|
|
|
// Creates a text control which is right-justified and has it's minimum width configured to suit
|
|
|
|
// the number of digits requested.
|
2010-06-04 16:41:51 +00:00
|
|
|
wxTextCtrl* CreateNumericalTextCtrl( wxWindow* parent, int digits, long flags )
|
2010-01-04 11:51:09 +00:00
|
|
|
{
|
|
|
|
wxTextCtrl* ctrl = new wxTextCtrl( parent, wxID_ANY );
|
2010-06-04 16:41:51 +00:00
|
|
|
ctrl->SetWindowStyleFlag( flags );
|
2010-01-04 11:51:09 +00:00
|
|
|
pxFitToDigits( ctrl, digits );
|
|
|
|
return ctrl;
|
|
|
|
}
|
2009-11-11 11:36:13 +00:00
|
|
|
|
2010-01-04 11:51:09 +00:00
|
|
|
void pxFitToDigits( wxWindow* win, int digits )
|
|
|
|
{
|
|
|
|
int ex;
|
|
|
|
win->GetTextExtent( wxString( L'0', digits+1 ), &ex, NULL );
|
|
|
|
win->SetMinSize( wxSize( ex+10, wxDefaultCoord ) ); // +10 for text control borders/insets and junk.
|
|
|
|
}
|
|
|
|
|
|
|
|
void pxFitToDigits( wxSpinCtrl* win, int digits )
|
|
|
|
{
|
|
|
|
// HACK!! The better way would be to create a pxSpinCtrl class that extends wxSpinCtrl and thus
|
|
|
|
// have access to wxSpinButton::DoGetBestSize(). But since I don't want to do that, we'll just
|
|
|
|
// make/fake it with a value it's pretty common to Win32/GTK/Mac:
|
|
|
|
|
|
|
|
static const int MagicSpinnerSize = 18;
|
|
|
|
|
|
|
|
int ex;
|
|
|
|
win->GetTextExtent( wxString( L'0', digits+1 ), &ex, NULL );
|
|
|
|
win->SetMinSize( wxSize( ex+10+MagicSpinnerSize, wxDefaultCoord ) ); // +10 for text control borders/insets and junk.
|
|
|
|
}
|
2009-11-08 01:56:24 +00:00
|
|
|
|
2009-12-14 12:18:55 +00:00
|
|
|
bool pxDialogExists( const wxString& name )
|
2009-09-16 17:23:02 +00:00
|
|
|
{
|
2009-12-14 12:18:55 +00:00
|
|
|
return wxFindWindowByName( name ) != NULL;
|
2009-09-16 17:23:02 +00:00
|
|
|
}
|
|
|
|
|
2010-01-04 11:51:09 +00:00
|
|
|
// =====================================================================================================
|
|
|
|
// wxDialogWithHelpers Class Implementations
|
|
|
|
// =====================================================================================================
|
|
|
|
|
2010-05-20 22:29:30 +00:00
|
|
|
DEFINE_EVENT_TYPE( pxEvt_OnDialogCreated )
|
|
|
|
|
2009-11-18 07:53:02 +00:00
|
|
|
IMPLEMENT_DYNAMIC_CLASS(wxDialogWithHelpers, wxDialog)
|
|
|
|
|
|
|
|
wxDialogWithHelpers::wxDialogWithHelpers()
|
|
|
|
{
|
|
|
|
m_hasContextHelp = false;
|
2009-11-25 15:38:24 +00:00
|
|
|
m_extraButtonSizer = NULL;
|
2010-04-25 00:31:27 +00:00
|
|
|
|
2010-06-06 23:26:07 +00:00
|
|
|
Init( pxDialogFlags() );
|
2009-12-14 12:18:55 +00:00
|
|
|
}
|
|
|
|
|
2010-06-04 19:50:31 +00:00
|
|
|
wxDialogWithHelpers::wxDialogWithHelpers( wxWindow* parent, const wxString& title, const pxDialogCreationFlags& cflags )
|
|
|
|
: wxDialog( parent, wxID_ANY, title, wxDefaultPosition, wxDefaultSize, cflags.GetWxWindowFlags() )
|
2009-12-14 12:18:55 +00:00
|
|
|
{
|
2010-06-04 19:50:31 +00:00
|
|
|
m_hasContextHelp = cflags.hasContextHelp;
|
|
|
|
if( (int)cflags.BoxSizerOrient != 0 )
|
|
|
|
{
|
|
|
|
SetSizer( new wxBoxSizer( cflags.BoxSizerOrient ) );
|
|
|
|
*this += StdPadding;
|
|
|
|
}
|
2009-11-18 07:53:02 +00:00
|
|
|
|
2010-06-06 23:26:07 +00:00
|
|
|
Init( cflags );
|
|
|
|
SetMinSize( cflags.MinimumSize );
|
2009-12-14 12:18:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
wxDialogWithHelpers::~wxDialogWithHelpers() throw()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2010-06-06 23:26:07 +00:00
|
|
|
void wxDialogWithHelpers::Init( const pxDialogCreationFlags& cflags )
|
2009-12-14 12:18:55 +00:00
|
|
|
{
|
2015-06-24 22:26:22 +00:00
|
|
|
// Note to self: if any comments indicate platform specific behaviour then
|
|
|
|
// ifdef them out to see if they fix the issue. I wasted too much time
|
|
|
|
// figuring out why the close box wouldn't work on wxGTK modal dialogs that
|
|
|
|
// had a minimise button.
|
|
|
|
#if _WIN32
|
2010-06-06 23:26:07 +00:00
|
|
|
// This fixes it so that the dialogs show up in the task bar in Vista:
|
|
|
|
// (otherwise they go stupid iconized mode if the user minimizes them)
|
|
|
|
if( cflags.hasMinimizeBox )
|
|
|
|
SetExtraStyle(GetExtraStyle() & ~wxTOPLEVEL_EX_DIALOG);
|
2015-06-24 22:26:22 +00:00
|
|
|
#endif
|
2010-06-06 23:26:07 +00:00
|
|
|
|
2009-11-25 15:38:24 +00:00
|
|
|
m_extraButtonSizer = NULL;
|
2009-11-14 08:36:57 +00:00
|
|
|
|
2011-05-02 19:11:00 +00:00
|
|
|
#ifndef GCC_4_6_LTO_COMPILATION_ISSUE
|
2009-11-14 08:36:57 +00:00
|
|
|
if( m_hasContextHelp )
|
2009-10-25 22:33:23 +00:00
|
|
|
delete wxHelpProvider::Set( new wxSimpleHelpProvider() );
|
2011-05-02 19:11:00 +00:00
|
|
|
#endif
|
2009-07-04 20:53:05 +00:00
|
|
|
|
2010-05-20 22:29:30 +00:00
|
|
|
Connect( pxEvt_OnDialogCreated, wxCommandEventHandler (wxDialogWithHelpers::OnDialogCreated) );
|
2009-12-14 12:18:55 +00:00
|
|
|
|
|
|
|
Connect( wxID_OK, wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler (wxDialogWithHelpers::OnOkCancel) );
|
|
|
|
Connect( wxID_CANCEL, wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler (wxDialogWithHelpers::OnOkCancel) );
|
|
|
|
Connect( wxEVT_CLOSE_WINDOW, wxCloseEventHandler (wxDialogWithHelpers::OnCloseWindow) );
|
2010-05-20 22:29:30 +00:00
|
|
|
|
|
|
|
wxCommandEvent createEvent( pxEvt_OnDialogCreated );
|
|
|
|
createEvent.SetId( GetId() );
|
|
|
|
AddPendingEvent( createEvent );
|
|
|
|
}
|
|
|
|
|
|
|
|
void wxDialogWithHelpers::OnDialogCreated( wxCommandEvent& evt )
|
|
|
|
{
|
|
|
|
evt.Skip();
|
|
|
|
if( (evt.GetId() == GetId()) && !GetDialogName().IsEmpty() )
|
|
|
|
SetName( L"Dialog:" + GetDialogName() );
|
|
|
|
}
|
|
|
|
|
|
|
|
wxString wxDialogWithHelpers::GetDialogName() const
|
|
|
|
{
|
|
|
|
return wxEmptyString;
|
2009-07-04 20:53:05 +00:00
|
|
|
}
|
|
|
|
|
2010-06-06 23:26:07 +00:00
|
|
|
void wxDialogWithHelpers::DoAutoCenter()
|
2009-09-16 17:23:02 +00:00
|
|
|
{
|
2009-12-14 12:18:55 +00:00
|
|
|
// Smart positioning logic! If our parent window is larger than our window by some
|
|
|
|
// good amount, then we center on that. If not, center relative to the screen. This
|
|
|
|
// avoids the popup automatically eclipsing the parent window (which happens in PCSX2
|
|
|
|
// a lot since the main window is small).
|
|
|
|
|
|
|
|
bool centerfail = true;
|
|
|
|
if( wxWindow* parent = GetParent() )
|
|
|
|
{
|
|
|
|
const wxSize parentSize( parent->GetSize() );
|
|
|
|
|
2010-06-24 17:39:18 +00:00
|
|
|
if( (parentSize.x > ((int)GetSize().x * 1.5)) || (parentSize.y > ((int)GetSize().y * 1.5)) )
|
2009-12-14 12:18:55 +00:00
|
|
|
{
|
|
|
|
CenterOnParent();
|
|
|
|
centerfail = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if( centerfail ) CenterOnScreen();
|
|
|
|
}
|
|
|
|
|
2010-06-06 23:26:07 +00:00
|
|
|
void wxDialogWithHelpers::SmartCenterFit()
|
|
|
|
{
|
|
|
|
Fit();
|
|
|
|
|
|
|
|
const wxString dlgName( GetDialogName() );
|
|
|
|
if( dlgName.IsEmpty() )
|
|
|
|
{
|
|
|
|
DoAutoCenter(); return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if( wxConfigBase* cfg = wxConfigBase::Get( false ) )
|
|
|
|
{
|
|
|
|
wxRect screenRect( GetScreenRect() );
|
|
|
|
|
|
|
|
IniLoader loader( cfg );
|
2010-08-04 19:10:41 +00:00
|
|
|
ScopedIniGroup group( loader, L"DialogPositions" );
|
2010-06-06 23:26:07 +00:00
|
|
|
cfg->SetRecordDefaults( false );
|
|
|
|
|
|
|
|
if( GetWindowStyle() & wxRESIZE_BORDER )
|
|
|
|
{
|
|
|
|
wxSize size;
|
|
|
|
loader.Entry( dlgName + L"_Size", size, screenRect.GetSize() );
|
|
|
|
SetSize( size );
|
|
|
|
}
|
|
|
|
|
|
|
|
if( !cfg->Exists( dlgName + L"_Pos" ) )
|
|
|
|
DoAutoCenter();
|
|
|
|
else
|
|
|
|
{
|
|
|
|
wxPoint pos;
|
|
|
|
loader.Entry( dlgName + L"_Pos", pos, screenRect.GetPosition() );
|
|
|
|
SetPosition( pos );
|
|
|
|
}
|
|
|
|
cfg->SetRecordDefaults( true );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-12-14 12:18:55 +00:00
|
|
|
// Overrides wxDialog behavior to include automatic Fit() and CenterOnParent/Screen. The centering
|
|
|
|
// is based on a heuristic the centers against the parent window if the parent window is at least
|
|
|
|
// 75% larger than the fitted dialog.
|
|
|
|
int wxDialogWithHelpers::ShowModal()
|
|
|
|
{
|
|
|
|
SmartCenterFit();
|
2010-06-06 23:26:07 +00:00
|
|
|
m_CreatedRect = GetScreenRect();
|
2009-12-14 12:18:55 +00:00
|
|
|
return wxDialog::ShowModal();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Overrides wxDialog behavior to include automatic Fit() and CenterOnParent/Screen. The centering
|
|
|
|
// is based on a heuristic the centers against the parent window if the parent window is at least
|
|
|
|
// 75% larger than the fitted dialog.
|
|
|
|
bool wxDialogWithHelpers::Show( bool show )
|
|
|
|
{
|
2010-06-06 23:26:07 +00:00
|
|
|
if( show )
|
|
|
|
{
|
|
|
|
SmartCenterFit();
|
|
|
|
m_CreatedRect = GetScreenRect();
|
|
|
|
}
|
2009-12-14 12:18:55 +00:00
|
|
|
return wxDialog::Show( show );
|
2009-09-16 17:23:02 +00:00
|
|
|
}
|
|
|
|
|
2010-06-04 08:00:19 +00:00
|
|
|
wxStaticText& wxDialogWithHelpers::Label( const wxString& label )
|
2009-11-20 03:26:10 +00:00
|
|
|
{
|
2010-06-04 08:00:19 +00:00
|
|
|
return *new wxStaticText( this, wxID_ANY, label, wxDefaultPosition, wxDefaultSize, wxALIGN_CENTER_VERTICAL );
|
2009-11-20 03:26:10 +00:00
|
|
|
}
|
|
|
|
|
2010-06-04 08:00:19 +00:00
|
|
|
pxStaticText& wxDialogWithHelpers::Text( const wxString& label )
|
2009-11-20 03:26:10 +00:00
|
|
|
{
|
2010-06-04 08:00:19 +00:00
|
|
|
return *new pxStaticText( this, label );
|
|
|
|
}
|
|
|
|
|
|
|
|
pxStaticText& wxDialogWithHelpers::Heading( const wxString& label )
|
|
|
|
{
|
|
|
|
return *new pxStaticHeading( this, label );
|
2009-11-20 03:26:10 +00:00
|
|
|
}
|
|
|
|
|
2010-12-12 07:43:21 +00:00
|
|
|
bool wxDialogWithHelpers::Destroy()
|
2009-12-14 12:18:55 +00:00
|
|
|
{
|
2010-06-06 23:26:07 +00:00
|
|
|
// Save the dialog position if the dialog is named...
|
|
|
|
// FIXME : This doesn't get called if the app is exited by alt-f4'ing the main app window.
|
|
|
|
// ... not sure how to fix that yet. I could register a list of open windows into wxAppWithHelpers
|
|
|
|
// that systematically get closed. Seems like work, maybe later. --air
|
2010-12-12 07:43:21 +00:00
|
|
|
|
2010-06-18 02:44:27 +00:00
|
|
|
if( wxConfigBase* cfg = IsIconized() ? NULL : wxConfigBase::Get( false ) )
|
2010-06-06 23:26:07 +00:00
|
|
|
{
|
|
|
|
const wxString dlgName( GetDialogName() );
|
|
|
|
const wxRect screenRect( GetScreenRect() );
|
|
|
|
if( !dlgName.IsEmpty() && ( m_CreatedRect != screenRect) )
|
|
|
|
{
|
|
|
|
wxPoint pos( screenRect.GetPosition() );
|
|
|
|
IniSaver saver( cfg );
|
2010-08-04 19:10:41 +00:00
|
|
|
ScopedIniGroup group( saver, L"DialogPositions" );
|
2010-06-06 23:26:07 +00:00
|
|
|
|
|
|
|
if( GetWindowStyle() & wxRESIZE_BORDER )
|
|
|
|
{
|
|
|
|
wxSize size( screenRect.GetSize() );
|
|
|
|
saver.Entry( dlgName + L"_Size", size, screenRect.GetSize() );
|
|
|
|
}
|
|
|
|
saver.Entry( dlgName + L"_Pos", pos, screenRect.GetPosition() );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-12-12 07:43:21 +00:00
|
|
|
return _parent::Destroy();
|
|
|
|
}
|
|
|
|
|
|
|
|
void wxDialogWithHelpers::OnCloseWindow( wxCloseEvent& evt )
|
|
|
|
{
|
2009-12-14 12:18:55 +00:00
|
|
|
if( !IsModal() ) Destroy();
|
|
|
|
evt.Skip();
|
|
|
|
}
|
|
|
|
|
|
|
|
void wxDialogWithHelpers::OnOkCancel( wxCommandEvent& evt )
|
|
|
|
{
|
|
|
|
Close();
|
|
|
|
evt.Skip();
|
|
|
|
}
|
|
|
|
|
2009-07-14 06:18:52 +00:00
|
|
|
void wxDialogWithHelpers::AddOkCancel( wxSizer &sizer, bool hasApply )
|
2009-07-04 20:53:05 +00:00
|
|
|
{
|
2009-11-25 15:38:24 +00:00
|
|
|
wxStdDialogButtonSizer& s_buttons( *new wxStdDialogButtonSizer() );
|
|
|
|
|
|
|
|
s_buttons.AddButton( new wxButton( this, wxID_OK ) );
|
|
|
|
s_buttons.AddButton( new wxButton( this, wxID_CANCEL ) );
|
|
|
|
|
|
|
|
if( hasApply )
|
|
|
|
s_buttons.AddButton( new wxButton( this, wxID_APPLY ) );
|
|
|
|
|
|
|
|
m_extraButtonSizer = new wxBoxSizer( wxHORIZONTAL );
|
|
|
|
|
2011-05-02 19:11:00 +00:00
|
|
|
#ifndef GCC_4_6_LTO_COMPILATION_ISSUE
|
2009-11-25 15:38:24 +00:00
|
|
|
// Add the context-sensitive help button on the caption for the platforms
|
|
|
|
// which support it (currently MSW only)
|
2009-07-04 20:53:05 +00:00
|
|
|
if( m_hasContextHelp )
|
|
|
|
{
|
|
|
|
SetExtraStyle( wxDIALOG_EX_CONTEXTHELP );
|
2009-11-27 06:47:32 +00:00
|
|
|
#ifndef __WXMSW__
|
2009-11-26 13:09:23 +00:00
|
|
|
*m_extraButtonSizer += new wxContextHelpButton(this) | StdButton();
|
2009-11-27 06:47:32 +00:00
|
|
|
#endif
|
2009-07-04 20:53:05 +00:00
|
|
|
}
|
2011-05-02 19:11:00 +00:00
|
|
|
#endif
|
2009-11-26 03:37:10 +00:00
|
|
|
|
2009-11-25 15:38:24 +00:00
|
|
|
// create a sizer to hold the help and ok/cancel buttons, for platforms
|
|
|
|
// that need a custom help icon. [fixme: help icon prolly better off somewhere else]
|
|
|
|
wxFlexGridSizer& flex( *new wxFlexGridSizer( 2 ) );
|
|
|
|
flex.AddGrowableCol( 0, 1 );
|
|
|
|
flex.AddGrowableCol( 1, 15 );
|
2009-07-11 08:31:38 +00:00
|
|
|
|
2009-11-26 03:37:10 +00:00
|
|
|
flex += m_extraButtonSizer | pxAlignLeft;
|
2009-12-14 12:18:55 +00:00
|
|
|
flex += s_buttons | (pxExpand & pxCenter);
|
2009-07-11 08:31:38 +00:00
|
|
|
|
2009-11-26 03:37:10 +00:00
|
|
|
sizer += flex | StdExpand();
|
2009-07-11 08:31:38 +00:00
|
|
|
|
|
|
|
s_buttons.Realize();
|
2009-07-04 20:53:05 +00:00
|
|
|
}
|
|
|
|
|
2010-05-03 13:51:46 +00:00
|
|
|
void wxDialogWithHelpers::AddOkCancel( wxSizer *sizer, bool hasApply )
|
|
|
|
{
|
|
|
|
if( sizer == NULL ) sizer = GetSizer();
|
2011-07-24 13:02:50 +00:00
|
|
|
pxAssert( sizer );
|
2010-05-03 13:51:46 +00:00
|
|
|
AddOkCancel( *sizer, hasApply );
|
|
|
|
}
|
|
|
|
|
2010-06-04 08:00:19 +00:00
|
|
|
wxDialogWithHelpers& wxDialogWithHelpers::SetMinWidth( int newWidth )
|
|
|
|
{
|
|
|
|
SetMinSize( wxSize( newWidth, GetMinHeight() ) );
|
|
|
|
if( wxSizer* sizer = GetSizer() )
|
|
|
|
sizer->SetMinSize( wxSize( newWidth, sizer->GetMinSize().GetHeight() ) );
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2010-06-06 23:26:07 +00:00
|
|
|
wxDialogWithHelpers& wxDialogWithHelpers::SetMinHeight( int newHeight )
|
|
|
|
{
|
|
|
|
SetMinSize( wxSize( GetMinWidth(), newHeight ) );
|
|
|
|
if( wxSizer* sizer = GetSizer() )
|
|
|
|
sizer->SetMinSize( wxSize( sizer->GetMinSize().GetWidth(), newHeight ) );
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2010-06-08 12:09:28 +00:00
|
|
|
int wxDialogWithHelpers::GetCharHeight() const
|
|
|
|
{
|
2010-06-09 17:37:11 +00:00
|
|
|
return pxGetCharHeight( this, 1 );
|
2010-06-08 12:09:28 +00:00
|
|
|
}
|
|
|
|
|
2009-11-18 07:53:02 +00:00
|
|
|
// --------------------------------------------------------------------------------------
|
|
|
|
// wxPanelWithHelpers Implementations
|
|
|
|
// --------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
IMPLEMENT_DYNAMIC_CLASS(wxPanelWithHelpers, wxPanel)
|
|
|
|
|
|
|
|
void wxPanelWithHelpers::Init()
|
2009-07-07 20:53:32 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2009-11-21 07:44:11 +00:00
|
|
|
// Creates a Static Box container for this panel. the static box sizer becomes the default
|
|
|
|
// sizer for this panel. If the panel already has a sizer set, then that sizer will be
|
|
|
|
// transfered to the new StaticBoxSizer (and will be the first item in it's list, retaining
|
|
|
|
// consistent and expected layout)
|
|
|
|
wxPanelWithHelpers* wxPanelWithHelpers::AddFrame( const wxString& label, wxOrientation orient )
|
2009-07-07 20:53:32 +00:00
|
|
|
{
|
2009-11-18 07:53:02 +00:00
|
|
|
wxSizer* oldSizer = GetSizer();
|
|
|
|
|
|
|
|
SetSizer( new wxStaticBoxSizer( orient, this, label ), false );
|
|
|
|
Init();
|
|
|
|
|
|
|
|
if( oldSizer )
|
2009-11-25 03:54:57 +00:00
|
|
|
*this += oldSizer | pxExpand;
|
2010-04-25 00:31:27 +00:00
|
|
|
|
2009-11-18 07:53:02 +00:00
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
2010-06-04 08:00:19 +00:00
|
|
|
wxStaticText& wxPanelWithHelpers::Label( const wxString& label )
|
2009-11-20 03:26:10 +00:00
|
|
|
{
|
2010-06-04 08:00:19 +00:00
|
|
|
return *new wxStaticText( this, wxID_ANY, label );
|
2009-11-20 03:26:10 +00:00
|
|
|
}
|
|
|
|
|
2010-06-04 08:00:19 +00:00
|
|
|
pxStaticText& wxPanelWithHelpers::Text( const wxString& label )
|
2009-11-20 03:26:10 +00:00
|
|
|
{
|
2010-06-04 08:00:19 +00:00
|
|
|
return *new pxStaticText( this, label );
|
|
|
|
}
|
|
|
|
|
|
|
|
pxStaticText& wxPanelWithHelpers::Heading( const wxString& label )
|
|
|
|
{
|
|
|
|
return *new pxStaticHeading( this, label );
|
2009-11-20 03:26:10 +00:00
|
|
|
}
|
|
|
|
|
2009-11-18 07:53:02 +00:00
|
|
|
wxPanelWithHelpers::wxPanelWithHelpers( wxWindow* parent, wxOrientation orient, const wxString& staticBoxLabel )
|
|
|
|
: wxPanel( parent )
|
|
|
|
{
|
|
|
|
SetSizer( new wxStaticBoxSizer( orient, this, staticBoxLabel ) );
|
|
|
|
Init();
|
|
|
|
}
|
|
|
|
|
|
|
|
wxPanelWithHelpers::wxPanelWithHelpers( wxWindow* parent, wxOrientation orient )
|
|
|
|
: wxPanel( parent )
|
|
|
|
{
|
|
|
|
SetSizer( new wxBoxSizer( orient ) );
|
|
|
|
Init();
|
|
|
|
}
|
|
|
|
|
|
|
|
wxPanelWithHelpers::wxPanelWithHelpers( wxWindow* parent )
|
|
|
|
: wxPanel( parent )
|
|
|
|
{
|
|
|
|
Init();
|
|
|
|
}
|
|
|
|
|
|
|
|
wxPanelWithHelpers::wxPanelWithHelpers( wxWindow* parent, const wxPoint& pos, const wxSize& size )
|
|
|
|
: wxPanel( parent, wxID_ANY, pos, size )
|
|
|
|
{
|
|
|
|
Init();
|
2009-07-07 20:53:32 +00:00
|
|
|
}
|
2010-06-04 08:00:19 +00:00
|
|
|
|
|
|
|
wxPanelWithHelpers& wxPanelWithHelpers::SetMinWidth( int newWidth )
|
|
|
|
{
|
|
|
|
SetMinSize( wxSize( newWidth, GetMinHeight() ) );
|
|
|
|
if( wxSizer* sizer = GetSizer() )
|
|
|
|
sizer->SetMinSize( wxSize( newWidth, sizer->GetMinSize().GetHeight() ) );
|
|
|
|
return *this;
|
|
|
|
}
|
2010-06-09 17:37:11 +00:00
|
|
|
|
|
|
|
int pxGetCharHeight( const wxWindow* wind, int rows )
|
|
|
|
{
|
|
|
|
if( !wind ) return 0;
|
|
|
|
wxClientDC dc(wx_const_cast(wxWindow*, wind));
|
|
|
|
dc.SetFont( wind->GetFont() );
|
2014-08-03 18:11:22 +00:00
|
|
|
#ifdef __linux__
|
2011-05-10 09:26:39 +00:00
|
|
|
// It seems there is a bad detection of the size of the font (non standard dpi ???). Font are cut in top or bottom.
|
|
|
|
// Add a correction factor to leave enough room. Visualy 1.7 seems fine but feel free to tune it -- Gregory
|
|
|
|
return (dc.GetCharHeight() * 1.7 + 1 ) * rows;
|
|
|
|
#else
|
2010-06-09 17:37:11 +00:00
|
|
|
return (dc.GetCharHeight() + 1 ) * rows;
|
2011-05-10 09:26:39 +00:00
|
|
|
#endif
|
2010-06-09 17:37:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int pxGetCharHeight( const wxWindow& wind, int rows )
|
|
|
|
{
|
|
|
|
return pxGetCharHeight( &wind, rows );
|
|
|
|
}
|