mirror of https://github.com/PCSX2/pcsx2.git
UI:
* Various configuration dialogs remember their positions now. :) * AboutBox is fixed, and is now resizable. * Fix for Issue 739 : usermode.ini hashes are now case-insensitive on Win32. * Likely Fix for Issue 740 : missing text on Linux/GTK. (need confirmation) DevNotes: * Moved IniInterface.cpp/h to the Utilities lib. Linux makefiles will need to be updated. >_< git-svn-id: http://pcsx2.googlecode.com/svn/trunk@3178 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
parent
a849202d28
commit
e86d1d1bd4
|
@ -219,6 +219,10 @@
|
||||||
RelativePath="..\..\src\Utilities\HashTools.cpp"
|
RelativePath="..\..\src\Utilities\HashTools.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\src\Utilities\IniInterface.cpp"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\src\Utilities\x86\MemcpyFast.cpp"
|
RelativePath="..\..\src\Utilities\x86\MemcpyFast.cpp"
|
||||||
>
|
>
|
||||||
|
@ -381,6 +385,10 @@
|
||||||
RelativePath="..\..\include\Utilities\HashMap.h"
|
RelativePath="..\..\include\Utilities\HashMap.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\include\Utilities\IniInterface.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\include\intrin_x86.h"
|
RelativePath="..\..\include\intrin_x86.h"
|
||||||
>
|
>
|
||||||
|
|
|
@ -15,11 +15,13 @@
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include "FixedPointTypes.h"
|
||||||
|
#include "path.h"
|
||||||
#include <wx/config.h>
|
#include <wx/config.h>
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////////////////
|
// --------------------------------------------------------------------------------------
|
||||||
// IniInterface class (abstract base class)
|
// IniInterface (abstract base class)
|
||||||
//
|
// --------------------------------------------------------------------------------------
|
||||||
// This is used as an interchangable interface for both loading and saving options from an
|
// This is used as an interchangable interface for both loading and saving options from an
|
||||||
// ini/configuration file. The LoadSave code takes an IniInterface, and the interface
|
// ini/configuration file. The LoadSave code takes an IniInterface, and the interface
|
||||||
// implementation defines whether the options are read or written.
|
// implementation defines whether the options are read or written.
|
||||||
|
@ -29,17 +31,19 @@
|
||||||
class IniInterface
|
class IniInterface
|
||||||
{
|
{
|
||||||
protected:
|
protected:
|
||||||
wxConfigBase& m_Config;
|
wxConfigBase* m_Config;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual ~IniInterface();
|
virtual ~IniInterface();
|
||||||
explicit IniInterface();
|
explicit IniInterface();
|
||||||
explicit IniInterface( wxConfigBase& config );
|
explicit IniInterface( wxConfigBase& config );
|
||||||
|
explicit IniInterface( wxConfigBase* config );
|
||||||
|
|
||||||
void SetPath( const wxString& path );
|
void SetPath( const wxString& path );
|
||||||
void Flush();
|
void Flush();
|
||||||
|
|
||||||
wxConfigBase& GetConfig() { return m_Config; }
|
wxConfigBase& GetConfig() { pxAssume( m_Config ); return *m_Config; }
|
||||||
|
bool IsOk() const { return m_Config != NULL; }
|
||||||
|
|
||||||
virtual bool IsLoading() const=0;
|
virtual bool IsLoading() const=0;
|
||||||
bool IsSaving() const { return !IsLoading(); }
|
bool IsSaving() const { return !IsLoading(); }
|
||||||
|
@ -76,8 +80,9 @@ protected:
|
||||||
virtual void _EnumEntry( const wxString& var, int& value, const wxChar* const* enumArray, int defvalue )=0;
|
virtual void _EnumEntry( const wxString& var, int& value, const wxChar* const* enumArray, int defvalue )=0;
|
||||||
};
|
};
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////////////////
|
// --------------------------------------------------------------------------------------
|
||||||
//
|
// IniScopedGroup
|
||||||
|
// --------------------------------------------------------------------------------------
|
||||||
class IniScopedGroup
|
class IniScopedGroup
|
||||||
{
|
{
|
||||||
protected:
|
protected:
|
||||||
|
@ -88,9 +93,9 @@ public:
|
||||||
virtual ~IniScopedGroup();
|
virtual ~IniScopedGroup();
|
||||||
};
|
};
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////////////////
|
// --------------------------------------------------------------------------------------
|
||||||
// IniLoader class
|
// IniLoader
|
||||||
//
|
// --------------------------------------------------------------------------------------
|
||||||
// Implementation of the IniInterface base class, which maps ini actions to loading from
|
// Implementation of the IniInterface base class, which maps ini actions to loading from
|
||||||
// an ini source file.
|
// an ini source file.
|
||||||
//
|
//
|
||||||
|
@ -102,6 +107,7 @@ public:
|
||||||
virtual ~IniLoader() throw();
|
virtual ~IniLoader() throw();
|
||||||
explicit IniLoader();
|
explicit IniLoader();
|
||||||
explicit IniLoader( wxConfigBase& config );
|
explicit IniLoader( wxConfigBase& config );
|
||||||
|
explicit IniLoader( wxConfigBase* config );
|
||||||
|
|
||||||
bool IsLoading() const { return true; }
|
bool IsLoading() const { return true; }
|
||||||
|
|
||||||
|
@ -125,9 +131,9 @@ protected:
|
||||||
void _EnumEntry( const wxString& var, int& value, const wxChar* const* enumArray, int defvalue );
|
void _EnumEntry( const wxString& var, int& value, const wxChar* const* enumArray, int defvalue );
|
||||||
};
|
};
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////////////////
|
// --------------------------------------------------------------------------------------
|
||||||
// IniSaver class
|
// IniSaver
|
||||||
//
|
// --------------------------------------------------------------------------------------
|
||||||
// Implementation of the IniInterface base class, which maps ini actions to saving to
|
// Implementation of the IniInterface base class, which maps ini actions to saving to
|
||||||
// an ini dest file.
|
// an ini dest file.
|
||||||
//
|
//
|
||||||
|
@ -139,6 +145,7 @@ public:
|
||||||
virtual ~IniSaver();
|
virtual ~IniSaver();
|
||||||
explicit IniSaver();
|
explicit IniSaver();
|
||||||
explicit IniSaver( wxConfigBase& config );
|
explicit IniSaver( wxConfigBase& config );
|
||||||
|
explicit IniSaver( wxConfigBase* config );
|
||||||
|
|
||||||
bool IsLoading() const { return false; }
|
bool IsLoading() const { return false; }
|
||||||
|
|
|
@ -129,7 +129,7 @@ namespace Path
|
||||||
extern s64 GetFileSize( const wxString& path );
|
extern s64 GetFileSize( const wxString& path );
|
||||||
|
|
||||||
extern wxString Normalize( const wxString& srcpath );
|
extern wxString Normalize( const wxString& srcpath );
|
||||||
extern wxString Normalize( wxDirName srcpath );
|
extern wxString Normalize( const wxDirName& srcpath );
|
||||||
|
|
||||||
extern wxString Combine( const wxString& srcPath, const wxString& srcFile );
|
extern wxString Combine( const wxString& srcPath, const wxString& srcFile );
|
||||||
extern wxString Combine( const wxDirName& srcPath, const wxFileName& srcFile );
|
extern wxString Combine( const wxDirName& srcPath, const wxFileName& srcFile );
|
||||||
|
|
|
@ -26,19 +26,21 @@
|
||||||
// * An inability to wrap text to conform to a fitted window (a limitation imposed by
|
// * An inability to wrap text to conform to a fitted window (a limitation imposed by
|
||||||
// wxWidgets inability to fit individual directions, ie fit widths and then fit heights,
|
// wxWidgets inability to fit individual directions, ie fit widths and then fit heights,
|
||||||
// which would allow a textbox to wrap text to a sizer-determined width, and then grow
|
// which would allow a textbox to wrap text to a sizer-determined width, and then grow
|
||||||
// the sizers vertically to fit the calcuated text-wrapped height).
|
// the sizers vertically to fit the calculated text-wrapped height).
|
||||||
//
|
//
|
||||||
// * Textbox alignment requires aligning both the textbox contents, and aligning the text
|
// * Textbox alignment requires aligning both the textbox contents, and aligning the text
|
||||||
// control within it's containing sizer. If both alignment flags do not match the result
|
// control within it's containing sizer. If both alignment flags do not match the result
|
||||||
// is typically undesirable.
|
// is typically undesirable.
|
||||||
//
|
//
|
||||||
class pxStaticText : public wxPanel
|
class pxStaticText : public wxWindow
|
||||||
{
|
{
|
||||||
typedef wxPanel _parent;
|
typedef wxWindow _parent;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
wxAlignment m_align;
|
wxString m_label;
|
||||||
wxString m_wrappedLabel;
|
wxString m_wrappedLabel;
|
||||||
|
|
||||||
|
wxAlignment m_align;
|
||||||
bool m_autowrap;
|
bool m_autowrap;
|
||||||
int m_wrappedWidth;
|
int m_wrappedWidth;
|
||||||
int m_heightInLines;
|
int m_heightInLines;
|
||||||
|
@ -51,6 +53,11 @@ protected:
|
||||||
protected:
|
protected:
|
||||||
explicit pxStaticText( wxWindow* parent=NULL );
|
explicit pxStaticText( wxWindow* parent=NULL );
|
||||||
|
|
||||||
|
// wxWindow overloads!
|
||||||
|
bool AcceptsFocus() const { return false; }
|
||||||
|
bool HasTransparentBackground() { return true; }
|
||||||
|
void DoSetSize(int x, int y, int w, int h, int sizeFlags = wxSIZE_AUTO);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
pxStaticText( wxWindow* parent, const wxString& label, wxAlignment align=wxALIGN_CENTRE_HORIZONTAL );
|
pxStaticText( wxWindow* parent, const wxString& label, wxAlignment align=wxALIGN_CENTRE_HORIZONTAL );
|
||||||
pxStaticText( wxWindow* parent, int heightInLines, const wxString& label, wxAlignment align=wxALIGN_CENTRE_HORIZONTAL );
|
pxStaticText( wxWindow* parent, int heightInLines, const wxString& label, wxAlignment align=wxALIGN_CENTRE_HORIZONTAL );
|
||||||
|
@ -61,6 +68,11 @@ public:
|
||||||
|
|
||||||
|
|
||||||
virtual void SetLabel(const wxString& label);
|
virtual void SetLabel(const wxString& label);
|
||||||
|
virtual wxString GetLabel() const { return m_label; }
|
||||||
|
|
||||||
|
pxStaticText& SetMinWidth( int width );
|
||||||
|
pxStaticText& SetMinHeight( int height );
|
||||||
|
|
||||||
pxStaticText& SetHeight( int lines );
|
pxStaticText& SetHeight( int lines );
|
||||||
pxStaticText& Bold();
|
pxStaticText& Bold();
|
||||||
pxStaticText& WrapAt( int width );
|
pxStaticText& WrapAt( int width );
|
||||||
|
|
|
@ -310,7 +310,7 @@ END_DECLARE_EVENT_TYPES()
|
||||||
class pxDialogCreationFlags
|
class pxDialogCreationFlags
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
int MinimumWidth;
|
wxSize MinimumSize;
|
||||||
wxOrientation BoxSizerOrient;
|
wxOrientation BoxSizerOrient;
|
||||||
|
|
||||||
bool isResizable;
|
bool isResizable;
|
||||||
|
@ -326,7 +326,7 @@ public:
|
||||||
|
|
||||||
pxDialogCreationFlags()
|
pxDialogCreationFlags()
|
||||||
{
|
{
|
||||||
MinimumWidth = wxDefaultCoord;
|
MinimumSize = wxDefaultSize;
|
||||||
BoxSizerOrient = wxVERTICAL;
|
BoxSizerOrient = wxVERTICAL;
|
||||||
isResizable = false;
|
isResizable = false;
|
||||||
hasContextHelp = false;
|
hasContextHelp = false;
|
||||||
|
@ -362,6 +362,8 @@ public:
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// NOTE: Enabling system menu on dialogs usually doesn't work, and might cause
|
||||||
|
// other unwanted behavior, such as a missing close button.
|
||||||
pxDialogCreationFlags& SetSystemMenu( bool enable=true )
|
pxDialogCreationFlags& SetSystemMenu( bool enable=true )
|
||||||
{
|
{
|
||||||
hasSystemMenu = enable;
|
hasSystemMenu = enable;
|
||||||
|
@ -388,10 +390,20 @@ public:
|
||||||
|
|
||||||
pxDialogCreationFlags& SetMinWidth( int width )
|
pxDialogCreationFlags& SetMinWidth( int width )
|
||||||
{
|
{
|
||||||
if( width > MinimumWidth ) MinimumWidth = width;
|
if( width > MinimumSize.x ) MinimumSize.SetWidth( width );
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pxDialogCreationFlags& SetMinHeight( int height )
|
||||||
|
{
|
||||||
|
if( height > MinimumSize.y ) MinimumSize.SetHeight( height );
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
pxDialogCreationFlags& SetMinSize( const wxSize& size )
|
||||||
|
{
|
||||||
|
return SetMinWidth(size.x).SetMinHeight(size.y);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
pxDialogCreationFlags Horizontal() const
|
pxDialogCreationFlags Horizontal() const
|
||||||
|
@ -424,6 +436,8 @@ public:
|
||||||
return pxDialogCreationFlags(*this).SetMaximize( enable );
|
return pxDialogCreationFlags(*this).SetMaximize( enable );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// NOTE: Enabling system menu on dialogs usually doesn't work, and might cause
|
||||||
|
// other unwanted behavior, such as a missing close button.
|
||||||
pxDialogCreationFlags SystemMenu( bool enable=true ) const
|
pxDialogCreationFlags SystemMenu( bool enable=true ) const
|
||||||
{
|
{
|
||||||
return pxDialogCreationFlags(*this).SetSystemMenu( false );
|
return pxDialogCreationFlags(*this).SetSystemMenu( false );
|
||||||
|
@ -474,6 +488,21 @@ public:
|
||||||
return pxDialogCreationFlags(*this).SetMinWidth( width );
|
return pxDialogCreationFlags(*this).SetMinWidth( width );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pxDialogCreationFlags MinHeight( int height ) const
|
||||||
|
{
|
||||||
|
return pxDialogCreationFlags(*this).SetMinHeight( height );
|
||||||
|
}
|
||||||
|
|
||||||
|
pxDialogCreationFlags MinSize( const wxSize& size ) const
|
||||||
|
{
|
||||||
|
return pxDialogCreationFlags(*this).SetMinSize( size );
|
||||||
|
}
|
||||||
|
|
||||||
|
pxDialogCreationFlags MinSize( int width, int height ) const
|
||||||
|
{
|
||||||
|
return pxDialogCreationFlags(*this).SetMinWidth( width ).SetMinHeight( height );
|
||||||
|
}
|
||||||
|
|
||||||
int GetWxWindowFlags() const
|
int GetWxWindowFlags() const
|
||||||
{
|
{
|
||||||
int retval = 0;
|
int retval = 0;
|
||||||
|
@ -498,13 +527,14 @@ class wxDialogWithHelpers : public wxDialog
|
||||||
protected:
|
protected:
|
||||||
bool m_hasContextHelp;
|
bool m_hasContextHelp;
|
||||||
wxBoxSizer* m_extraButtonSizer;
|
wxBoxSizer* m_extraButtonSizer;
|
||||||
|
wxRect m_CreatedRect;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
wxDialogWithHelpers();
|
wxDialogWithHelpers();
|
||||||
wxDialogWithHelpers(wxWindow* parent, const wxString& title, const pxDialogCreationFlags& cflags = pxDialogCreationFlags() );
|
wxDialogWithHelpers(wxWindow* parent, const wxString& title, const pxDialogCreationFlags& cflags = pxDialogCreationFlags() );
|
||||||
virtual ~wxDialogWithHelpers() throw();
|
virtual ~wxDialogWithHelpers() throw();
|
||||||
|
|
||||||
void Init();
|
void Init( const pxDialogCreationFlags& cflags );
|
||||||
void AddOkCancel( wxSizer& sizer, bool hasApply=false );
|
void AddOkCancel( wxSizer& sizer, bool hasApply=false );
|
||||||
void AddOkCancel( wxSizer* sizer=NULL, bool hasApply=false );
|
void AddOkCancel( wxSizer* sizer=NULL, bool hasApply=false );
|
||||||
|
|
||||||
|
@ -522,12 +552,15 @@ public:
|
||||||
virtual pxStaticText& Text( const wxString& label );
|
virtual pxStaticText& Text( const wxString& label );
|
||||||
virtual pxStaticText& Heading( const wxString& label );
|
virtual pxStaticText& Heading( const wxString& label );
|
||||||
|
|
||||||
virtual wxDialogWithHelpers& SetMinWidth( int newWidth );
|
wxDialogWithHelpers& SetMinWidth( int newWidth );
|
||||||
|
wxDialogWithHelpers& SetMinHeight( int newHeight );
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void OnDialogCreated( wxCommandEvent& evt );
|
void OnDialogCreated( wxCommandEvent& evt );
|
||||||
void OnOkCancel(wxCommandEvent& evt);
|
void OnOkCancel(wxCommandEvent& evt);
|
||||||
void OnCloseWindow(wxCloseEvent& event);
|
void OnCloseWindow(wxCloseEvent& event);
|
||||||
|
|
||||||
|
void DoAutoCenter();
|
||||||
};
|
};
|
||||||
|
|
||||||
// --------------------------------------------------------------------------------------
|
// --------------------------------------------------------------------------------------
|
||||||
|
|
|
@ -14,7 +14,6 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "PrecompiledHeader.h"
|
#include "PrecompiledHeader.h"
|
||||||
#include "System.h"
|
|
||||||
#include "IniInterface.h"
|
#include "IniInterface.h"
|
||||||
|
|
||||||
static int _calcEnumLength( const wxChar* const* enumArray )
|
static int _calcEnumLength( const wxChar* const* enumArray )
|
||||||
|
@ -29,37 +28,8 @@ static int _calcEnumLength( const wxChar* const* enumArray )
|
||||||
return cnt;
|
return cnt;
|
||||||
}
|
}
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////////////////
|
IniScopedGroup::IniScopedGroup( IniInterface& mommy, const wxString& group )
|
||||||
//
|
: m_mom( mommy )
|
||||||
IniInterface::IniInterface( wxConfigBase& config ) :
|
|
||||||
m_Config( config )
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
IniInterface::IniInterface() :
|
|
||||||
m_Config( *wxConfigBase::Get() )
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
IniInterface::~IniInterface()
|
|
||||||
{
|
|
||||||
Flush();
|
|
||||||
}
|
|
||||||
|
|
||||||
void IniInterface::SetPath( const wxString& path )
|
|
||||||
{
|
|
||||||
m_Config.SetPath( path );
|
|
||||||
}
|
|
||||||
|
|
||||||
void IniInterface::Flush()
|
|
||||||
{
|
|
||||||
m_Config.Flush();
|
|
||||||
}
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////////////////
|
|
||||||
//
|
|
||||||
IniScopedGroup::IniScopedGroup( IniInterface& mommy, const wxString& group ) :
|
|
||||||
m_mom( mommy )
|
|
||||||
{
|
{
|
||||||
pxAssertDev( wxStringTokenize( group, L"/" ).Count() <= 1, L"Cannot nest more than one group deep per instance of IniScopedGroup." );
|
pxAssertDev( wxStringTokenize( group, L"/" ).Count() <= 1, L"Cannot nest more than one group deep per instance of IniScopedGroup." );
|
||||||
m_mom.SetPath( group );
|
m_mom.SetPath( group );
|
||||||
|
@ -70,26 +40,62 @@ IniScopedGroup::~IniScopedGroup()
|
||||||
m_mom.SetPath( L".." );
|
m_mom.SetPath( L".." );
|
||||||
}
|
}
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////////////////
|
// --------------------------------------------------------------------------------------
|
||||||
//
|
// IniInterface (implementations)
|
||||||
|
// --------------------------------------------------------------------------------------
|
||||||
IniLoader::IniLoader( wxConfigBase& config ) : IniInterface( config )
|
IniInterface::IniInterface( wxConfigBase& config )
|
||||||
{
|
{
|
||||||
|
m_Config = &config;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
IniInterface::IniInterface( wxConfigBase* config )
|
||||||
|
{
|
||||||
|
m_Config = config;
|
||||||
|
}
|
||||||
|
|
||||||
|
IniInterface::IniInterface()
|
||||||
|
{
|
||||||
|
m_Config = wxConfigBase::Get( false );
|
||||||
|
}
|
||||||
|
|
||||||
|
IniInterface::~IniInterface()
|
||||||
|
{
|
||||||
|
Flush();
|
||||||
|
}
|
||||||
|
|
||||||
|
void IniInterface::SetPath( const wxString& path )
|
||||||
|
{
|
||||||
|
if( m_Config ) m_Config->SetPath( path );
|
||||||
|
}
|
||||||
|
|
||||||
|
void IniInterface::Flush()
|
||||||
|
{
|
||||||
|
if( m_Config ) m_Config->Flush();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// --------------------------------------------------------------------------------------
|
||||||
|
// IniLoader (implementations)
|
||||||
|
// --------------------------------------------------------------------------------------
|
||||||
|
IniLoader::IniLoader( wxConfigBase& config ) : IniInterface( config ) { }
|
||||||
|
IniLoader::IniLoader( wxConfigBase* config ) : IniInterface( config ) { }
|
||||||
|
|
||||||
IniLoader::IniLoader() : IniInterface() {}
|
IniLoader::IniLoader() : IniInterface() {}
|
||||||
IniLoader::~IniLoader() throw() {}
|
IniLoader::~IniLoader() throw() {}
|
||||||
|
|
||||||
|
|
||||||
void IniLoader::Entry( const wxString& var, wxString& value, const wxString& defvalue )
|
void IniLoader::Entry( const wxString& var, wxString& value, const wxString& defvalue )
|
||||||
{
|
{
|
||||||
m_Config.Read( var, &value, defvalue );
|
if( m_Config )
|
||||||
|
m_Config->Read( var, &value, defvalue );
|
||||||
|
else
|
||||||
|
value = defvalue;
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniLoader::Entry( const wxString& var, wxDirName& value, const wxDirName& defvalue )
|
void IniLoader::Entry( const wxString& var, wxDirName& value, const wxDirName& defvalue )
|
||||||
{
|
{
|
||||||
wxString dest;
|
wxString dest;
|
||||||
m_Config.Read( var, &dest, wxEmptyString );
|
if( m_Config ) m_Config->Read( var, &dest, wxEmptyString );
|
||||||
|
|
||||||
if( dest.IsEmpty() )
|
if( dest.IsEmpty() )
|
||||||
value = defvalue;
|
value = defvalue;
|
||||||
|
@ -99,26 +105,32 @@ void IniLoader::Entry( const wxString& var, wxDirName& value, const wxDirName& d
|
||||||
|
|
||||||
void IniLoader::Entry( const wxString& var, wxFileName& value, const wxFileName& defvalue )
|
void IniLoader::Entry( const wxString& var, wxFileName& value, const wxFileName& defvalue )
|
||||||
{
|
{
|
||||||
wxString dest;
|
wxString dest( defvalue.GetFullPath() );
|
||||||
m_Config.Read( var, &dest, defvalue.GetFullPath() );
|
if( m_Config ) m_Config->Read( var, &dest, defvalue.GetFullPath() );
|
||||||
value = dest;
|
value = dest;
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniLoader::Entry( const wxString& var, int& value, const int defvalue )
|
void IniLoader::Entry( const wxString& var, int& value, const int defvalue )
|
||||||
{
|
{
|
||||||
m_Config.Read( var, &value, defvalue );
|
if( m_Config )
|
||||||
|
m_Config->Read( var, &value, defvalue );
|
||||||
|
else
|
||||||
|
value = defvalue;
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniLoader::Entry( const wxString& var, uint& value, const uint defvalue )
|
void IniLoader::Entry( const wxString& var, uint& value, const uint defvalue )
|
||||||
{
|
{
|
||||||
m_Config.Read( var, (int*)&value, (int)defvalue );
|
if( m_Config )
|
||||||
|
m_Config->Read( var, (int*)&value, (int)defvalue );
|
||||||
|
else
|
||||||
|
value = defvalue;
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniLoader::Entry( const wxString& var, bool& value, const bool defvalue )
|
void IniLoader::Entry( const wxString& var, bool& value, const bool defvalue )
|
||||||
{
|
{
|
||||||
// TODO : Stricter value checking on enabled/disabled?
|
// TODO : Stricter value checking on enabled/disabled?
|
||||||
wxString dest;
|
wxString dest(defvalue ? L"enabled" : L"disabled");
|
||||||
m_Config.Read( var, &dest, defvalue ? L"enabled" : L"disabled" );
|
if( m_Config ) m_Config->Read( var, &dest, dest );
|
||||||
value = (dest == L"enabled") || (dest == L"1");
|
value = (dest == L"enabled") || (dest == L"1");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -143,23 +155,35 @@ void IniLoader::Entry( const wxString& var, Fixed100& value, const Fixed100& def
|
||||||
// has way too much rounding error so we really need to do things out manually.. >_<
|
// has way too much rounding error so we really need to do things out manually.. >_<
|
||||||
|
|
||||||
wxString readval( value.ToString() );
|
wxString readval( value.ToString() );
|
||||||
m_Config.Read( var, &readval );
|
if( m_Config ) m_Config->Read( var, &readval );
|
||||||
value = Fixed100::FromString( readval, value );
|
value = Fixed100::FromString( readval, value );
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniLoader::Entry( const wxString& var, wxPoint& value, const wxPoint& defvalue )
|
void IniLoader::Entry( const wxString& var, wxPoint& value, const wxPoint& defvalue )
|
||||||
{
|
{
|
||||||
TryParse( value, m_Config.Read( var, ToString( defvalue ) ), defvalue );
|
if( !m_Config )
|
||||||
|
{
|
||||||
|
value = defvalue; return;
|
||||||
|
}
|
||||||
|
TryParse( value, m_Config->Read( var, ToString( defvalue ) ), defvalue );
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniLoader::Entry( const wxString& var, wxSize& value, const wxSize& defvalue )
|
void IniLoader::Entry( const wxString& var, wxSize& value, const wxSize& defvalue )
|
||||||
{
|
{
|
||||||
TryParse( value, m_Config.Read( var, ToString( defvalue ) ), defvalue );
|
if( !m_Config )
|
||||||
|
{
|
||||||
|
value = defvalue; return;
|
||||||
|
}
|
||||||
|
TryParse( value, m_Config->Read( var, ToString( defvalue ) ), defvalue );
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniLoader::Entry( const wxString& var, wxRect& value, const wxRect& defvalue )
|
void IniLoader::Entry( const wxString& var, wxRect& value, const wxRect& defvalue )
|
||||||
{
|
{
|
||||||
TryParse( value, m_Config.Read( var, ToString( defvalue ) ), defvalue );
|
if( !m_Config )
|
||||||
|
{
|
||||||
|
value = defvalue; return;
|
||||||
|
}
|
||||||
|
TryParse( value, m_Config->Read( var, ToString( defvalue ) ), defvalue );
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniLoader::_EnumEntry( const wxString& var, int& value, const wxChar* const* enumArray, int defvalue )
|
void IniLoader::_EnumEntry( const wxString& var, int& value, const wxChar* const* enumArray, int defvalue )
|
||||||
|
@ -175,8 +199,14 @@ void IniLoader::_EnumEntry( const wxString& var, int& value, const wxChar* const
|
||||||
|
|
||||||
// Sanity confirmed, proceed with craziness!
|
// Sanity confirmed, proceed with craziness!
|
||||||
|
|
||||||
|
if( !m_Config )
|
||||||
|
{
|
||||||
|
value = defvalue;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
wxString retval;
|
wxString retval;
|
||||||
m_Config.Read( var, &retval, enumArray[defvalue] );
|
m_Config->Read( var, &retval, enumArray[defvalue] );
|
||||||
|
|
||||||
int i=0;
|
int i=0;
|
||||||
while( enumArray[i] != NULL && ( retval != enumArray[i] ) ) i++;
|
while( enumArray[i] != NULL && ( retval != enumArray[i] ) ) i++;
|
||||||
|
@ -192,82 +222,95 @@ void IniLoader::_EnumEntry( const wxString& var, int& value, const wxChar* const
|
||||||
value = i;
|
value = i;
|
||||||
}
|
}
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////////////////
|
// --------------------------------------------------------------------------------------
|
||||||
//
|
// IniSaver (implementations)
|
||||||
|
// --------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
IniSaver::IniSaver( wxConfigBase& config ) : IniInterface( config ) { }
|
||||||
|
IniSaver::IniSaver( wxConfigBase* config ) : IniInterface( config ) { }
|
||||||
|
|
||||||
IniSaver::IniSaver( wxConfigBase& config ) : IniInterface( config )
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
IniSaver::IniSaver() : IniInterface() {}
|
IniSaver::IniSaver() : IniInterface() {}
|
||||||
IniSaver::~IniSaver() {}
|
IniSaver::~IniSaver() {}
|
||||||
|
|
||||||
void IniSaver::Entry( const wxString& var, wxString& value, const wxString& defvalue )
|
void IniSaver::Entry( const wxString& var, wxString& value, const wxString& defvalue )
|
||||||
{
|
{
|
||||||
m_Config.Write( var, value );
|
if( !m_Config ) return;
|
||||||
|
m_Config->Write( var, value );
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniSaver::Entry( const wxString& var, wxDirName& value, const wxDirName& defvalue )
|
void IniSaver::Entry( const wxString& var, wxDirName& value, const wxDirName& defvalue )
|
||||||
{
|
{
|
||||||
|
if( !m_Config ) return;
|
||||||
|
|
||||||
/*if( value == defvalue )
|
/*if( value == defvalue )
|
||||||
m_Config.Write( var, wxString() );
|
m_Config->Write( var, wxString() );
|
||||||
else*/
|
else*/
|
||||||
m_Config.Write( var, value.ToString() );
|
m_Config->Write( var, value.ToString() );
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniSaver::Entry( const wxString& var, wxFileName& value, const wxFileName& defvalue )
|
void IniSaver::Entry( const wxString& var, wxFileName& value, const wxFileName& defvalue )
|
||||||
{
|
{
|
||||||
m_Config.Write( var, value.GetFullPath() );
|
if( !m_Config ) return;
|
||||||
|
m_Config->Write( var, value.GetFullPath() );
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniSaver::Entry( const wxString& var, int& value, const int defvalue )
|
void IniSaver::Entry( const wxString& var, int& value, const int defvalue )
|
||||||
{
|
{
|
||||||
m_Config.Write( var, value );
|
if( !m_Config ) return;
|
||||||
|
m_Config->Write( var, value );
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniSaver::Entry( const wxString& var, uint& value, const uint defvalue )
|
void IniSaver::Entry( const wxString& var, uint& value, const uint defvalue )
|
||||||
{
|
{
|
||||||
m_Config.Write( var, (int)value );
|
if( !m_Config ) return;
|
||||||
|
m_Config->Write( var, (int)value );
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniSaver::Entry( const wxString& var, bool& value, const bool defvalue )
|
void IniSaver::Entry( const wxString& var, bool& value, const bool defvalue )
|
||||||
{
|
{
|
||||||
m_Config.Write( var, value ? L"enabled" : L"disabled" );
|
if( !m_Config ) return;
|
||||||
|
m_Config->Write( var, value ? L"enabled" : L"disabled" );
|
||||||
}
|
}
|
||||||
|
|
||||||
bool IniSaver::EntryBitBool( const wxString& var, bool value, const bool defvalue )
|
bool IniSaver::EntryBitBool( const wxString& var, bool value, const bool defvalue )
|
||||||
{
|
{
|
||||||
m_Config.Write( var, value ? L"enabled" : L"disabled" );
|
if( m_Config ) m_Config->Write( var, value ? L"enabled" : L"disabled" );
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
int IniSaver::EntryBitfield( const wxString& var, int value, const int defvalue )
|
int IniSaver::EntryBitfield( const wxString& var, int value, const int defvalue )
|
||||||
{
|
{
|
||||||
m_Config.Write( var, value );
|
if( m_Config ) m_Config->Write( var, value );
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniSaver::Entry( const wxString& var, Fixed100& value, const Fixed100& defvalue )
|
void IniSaver::Entry( const wxString& var, Fixed100& value, const Fixed100& defvalue )
|
||||||
{
|
{
|
||||||
|
if( !m_Config ) return;
|
||||||
|
|
||||||
// Note: the "easy" way would be to convert to double and load/save that, but floating point
|
// Note: the "easy" way would be to convert to double and load/save that, but floating point
|
||||||
// has way too much rounding error so we really need to do things out manually, using strings.
|
// has way too much rounding error so we really need to do things out manually, using strings.
|
||||||
|
|
||||||
m_Config.Write( var, value.ToString() );
|
m_Config->Write( var, value.ToString() );
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniSaver::Entry( const wxString& var, wxPoint& value, const wxPoint& defvalue )
|
void IniSaver::Entry( const wxString& var, wxPoint& value, const wxPoint& defvalue )
|
||||||
{
|
{
|
||||||
m_Config.Write( var, ToString( value ) );
|
if( !m_Config ) return;
|
||||||
|
m_Config->Write( var, ToString( value ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniSaver::Entry( const wxString& var, wxSize& value, const wxSize& defvalue )
|
void IniSaver::Entry( const wxString& var, wxSize& value, const wxSize& defvalue )
|
||||||
{
|
{
|
||||||
m_Config.Write( var, ToString( value ) );
|
if( !m_Config ) return;
|
||||||
|
m_Config->Write( var, ToString( value ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniSaver::Entry( const wxString& var, wxRect& value, const wxRect& defvalue )
|
void IniSaver::Entry( const wxString& var, wxRect& value, const wxRect& defvalue )
|
||||||
{
|
{
|
||||||
m_Config.Write( var, ToString( value ) );
|
if( !m_Config ) return;
|
||||||
|
m_Config->Write( var, ToString( value ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
void IniSaver::_EnumEntry( const wxString& var, int& value, const wxChar* const* enumArray, int defvalue )
|
void IniSaver::_EnumEntry( const wxString& var, int& value, const wxChar* const* enumArray, int defvalue )
|
||||||
|
@ -282,6 +325,8 @@ void IniSaver::_EnumEntry( const wxString& var, int& value, const wxChar* const*
|
||||||
defvalue = cnt-1;
|
defvalue = cnt-1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if( !m_Config ) return;
|
||||||
|
|
||||||
if( value >= cnt )
|
if( value >= cnt )
|
||||||
{
|
{
|
||||||
Console.Warning( L"(SaveSettings) An illegal enumerated index was detected when saving '%s'", var.c_str() );
|
Console.Warning( L"(SaveSettings) An illegal enumerated index was detected when saving '%s'", var.c_str() );
|
||||||
|
@ -297,6 +342,6 @@ void IniSaver::_EnumEntry( const wxString& var, int& value, const wxChar* const*
|
||||||
value = defvalue;
|
value = defvalue;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_Config.Write( var, enumArray[value] );
|
m_Config->Write( var, enumArray[value] );
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
#include <wx/utils.h>
|
#include <wx/utils.h>
|
||||||
|
|
||||||
// ---------------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------------
|
||||||
// wxDirName Implementations
|
// wxDirName (implementations)
|
||||||
// ---------------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------------
|
||||||
|
|
||||||
wxFileName wxDirName::Combine( const wxFileName& right ) const
|
wxFileName wxDirName::Combine( const wxFileName& right ) const
|
||||||
|
@ -116,10 +116,9 @@ wxString Path::Normalize( const wxString& src )
|
||||||
return normalize.GetFullPath();
|
return normalize.GetFullPath();
|
||||||
}
|
}
|
||||||
|
|
||||||
wxString Path::Normalize( wxDirName src )
|
wxString Path::Normalize( const wxDirName& src )
|
||||||
{
|
{
|
||||||
src.Normalize();
|
return wxDirName(src).Normalize().ToString();
|
||||||
return src.ToString();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Concatenates two pathnames together, inserting delimiters (backslash on win32)
|
// Concatenates two pathnames together, inserting delimiters (backslash on win32)
|
||||||
|
|
|
@ -21,13 +21,13 @@
|
||||||
// pxStaticText (implementations)
|
// pxStaticText (implementations)
|
||||||
// --------------------------------------------------------------------------------------
|
// --------------------------------------------------------------------------------------
|
||||||
pxStaticText::pxStaticText( wxWindow* parent )
|
pxStaticText::pxStaticText( wxWindow* parent )
|
||||||
: _parent( parent )
|
: _parent( parent, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxNO_BORDER )
|
||||||
{
|
{
|
||||||
m_heightInLines = 1;
|
m_heightInLines = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
pxStaticText::pxStaticText( wxWindow* parent, const wxString& label, wxAlignment align )
|
pxStaticText::pxStaticText( wxWindow* parent, const wxString& label, wxAlignment align )
|
||||||
: _parent( parent )
|
: _parent( parent, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxNO_BORDER )
|
||||||
{
|
{
|
||||||
m_heightInLines = 1;
|
m_heightInLines = 1;
|
||||||
m_align = align;
|
m_align = align;
|
||||||
|
@ -40,12 +40,19 @@ void pxStaticText::Init( const wxString& label )
|
||||||
{
|
{
|
||||||
m_autowrap = true;
|
m_autowrap = true;
|
||||||
m_wrappedWidth = -1;
|
m_wrappedWidth = -1;
|
||||||
|
m_label = label;
|
||||||
//SetHeight( 1 );
|
|
||||||
SetLabel( label );
|
|
||||||
Connect( wxEVT_PAINT, wxPaintEventHandler(pxStaticText::paintEvent) );
|
Connect( wxEVT_PAINT, wxPaintEventHandler(pxStaticText::paintEvent) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// we need to refresh the window after changing its size as the standard
|
||||||
|
// control doesn't always update itself properly (fials typically on window resizes where
|
||||||
|
// the control is expanded to fit -- ie the control's size changes but the position does not)
|
||||||
|
void pxStaticText::DoSetSize(int x, int y, int w, int h, int sizeFlags)
|
||||||
|
{
|
||||||
|
_parent::DoSetSize(x, y, w, h, sizeFlags);
|
||||||
|
Refresh();
|
||||||
|
}
|
||||||
|
|
||||||
void pxStaticText::SetPaddingDefaults()
|
void pxStaticText::SetPaddingDefaults()
|
||||||
{
|
{
|
||||||
m_paddingPix_horiz = 7;
|
m_paddingPix_horiz = 7;
|
||||||
|
@ -55,6 +62,18 @@ void pxStaticText::SetPaddingDefaults()
|
||||||
m_paddingPct_vert = 0.0f;
|
m_paddingPct_vert = 0.0f;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pxStaticText& pxStaticText::SetMinWidth( int width )
|
||||||
|
{
|
||||||
|
SetMinSize( wxSize( width, GetMinHeight() ) );
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
pxStaticText& pxStaticText::SetMinHeight( int height )
|
||||||
|
{
|
||||||
|
SetMinSize( wxSize( GetMinWidth(), height) );
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
pxStaticText& pxStaticText::SetHeight( int lines )
|
pxStaticText& pxStaticText::SetHeight( int lines )
|
||||||
{
|
{
|
||||||
if( !pxAssert(lines > 0) ) lines = 2;
|
if( !pxAssert(lines > 0) ) lines = 2;
|
||||||
|
@ -165,8 +184,7 @@ wxSize pxStaticText::GetBestWrappedSize( const wxClientDC& dc ) const
|
||||||
idealWidth = (int)(wxGetDisplaySize().GetWidth() * 0.66) - (parentalAdjust*2);
|
idealWidth = (int)(wxGetDisplaySize().GetWidth() * 0.66) - (parentalAdjust*2);
|
||||||
}
|
}
|
||||||
|
|
||||||
wxString label(GetLabel());
|
return dc.GetMultiLineTextExtent(pxTextWrapper().Wrap( this, m_label, idealWidth - calcPaddingWidth(idealWidth) ).GetResult());
|
||||||
return dc.GetMultiLineTextExtent(pxTextWrapper().Wrap( this, label, idealWidth - calcPaddingWidth(idealWidth) ).GetResult());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pxStaticText& pxStaticText::WrapAt( int width )
|
pxStaticText& pxStaticText::WrapAt( int width )
|
||||||
|
@ -179,10 +197,7 @@ pxStaticText& pxStaticText::WrapAt( int width )
|
||||||
m_wrappedWidth = width;
|
m_wrappedWidth = width;
|
||||||
|
|
||||||
if( width > 1 )
|
if( width > 1 )
|
||||||
{
|
wrappedLabel = pxTextWrapper().Wrap( this, m_label, width ).GetResult();
|
||||||
wxString label( GetLabel() );
|
|
||||||
wrappedLabel = pxTextWrapper().Wrap( this, label, width ).GetResult();
|
|
||||||
}
|
|
||||||
|
|
||||||
if(m_wrappedLabel != wrappedLabel )
|
if(m_wrappedLabel != wrappedLabel )
|
||||||
{
|
{
|
||||||
|
@ -218,10 +233,7 @@ bool pxStaticText::_updateWrapping( bool textChanged )
|
||||||
|
|
||||||
m_wrappedWidth = newWidth;
|
m_wrappedWidth = newWidth;
|
||||||
if( m_wrappedWidth > 1 )
|
if( m_wrappedWidth > 1 )
|
||||||
{
|
wrappedLabel = pxTextWrapper().Wrap( this, m_label, m_wrappedWidth ).GetResult();
|
||||||
wxString label( GetLabel() );
|
|
||||||
wrappedLabel = pxTextWrapper().Wrap( this, label, m_wrappedWidth ).GetResult();
|
|
||||||
}
|
|
||||||
|
|
||||||
if( m_wrappedLabel == wrappedLabel ) return false;
|
if( m_wrappedLabel == wrappedLabel ) return false;
|
||||||
m_wrappedLabel = wrappedLabel;
|
m_wrappedLabel = wrappedLabel;
|
||||||
|
@ -236,10 +248,10 @@ void pxStaticText::UpdateWrapping( bool textChanged )
|
||||||
|
|
||||||
void pxStaticText::SetLabel(const wxString& label)
|
void pxStaticText::SetLabel(const wxString& label)
|
||||||
{
|
{
|
||||||
const bool labelChanged( label != GetLabel() );
|
const bool labelChanged( label != m_label );
|
||||||
if( labelChanged )
|
if( labelChanged )
|
||||||
{
|
{
|
||||||
_parent::SetLabel( label );
|
m_label = label;
|
||||||
Refresh();
|
Refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -280,17 +292,8 @@ void pxStaticText::paintEvent(wxPaintEvent& evt)
|
||||||
pxWindowTextWriter writer( dc );
|
pxWindowTextWriter writer( dc );
|
||||||
writer.Align( m_align );
|
writer.Align( m_align );
|
||||||
|
|
||||||
wxString label;
|
const wxString& label( m_autowrap ? m_wrappedLabel : m_label );
|
||||||
|
if( m_autowrap ) _updateWrapping( false );
|
||||||
if( m_autowrap )
|
|
||||||
{
|
|
||||||
_updateWrapping( false );
|
|
||||||
label = m_wrappedLabel;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
label = GetLabel();
|
|
||||||
}
|
|
||||||
|
|
||||||
int tWidth, tHeight;
|
int tWidth, tHeight;
|
||||||
dc.GetMultiLineTextExtent( label, &tWidth, &tHeight );
|
dc.GetMultiLineTextExtent( label, &tWidth, &tHeight );
|
||||||
|
|
|
@ -87,8 +87,9 @@ pxWindowTextWriter& pxWindowTextWriter::MoveY( int ydelta )
|
||||||
void pxWindowTextWriter::_DoWriteLn( const wxChar* msg )
|
void pxWindowTextWriter::_DoWriteLn( const wxChar* msg )
|
||||||
{
|
{
|
||||||
pxAssume( msg );
|
pxAssume( msg );
|
||||||
|
|
||||||
int tWidth, tHeight;
|
int tWidth, tHeight;
|
||||||
m_dc.GetTextExtent( msg, &tWidth, &tHeight );
|
m_dc.GetMultiLineTextExtent( msg, &tWidth, &tHeight );
|
||||||
|
|
||||||
wxPoint dispos( m_curpos );
|
wxPoint dispos( m_curpos );
|
||||||
|
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
#include "wxGuiTools.h"
|
#include "wxGuiTools.h"
|
||||||
#include "pxStaticText.h"
|
#include "pxStaticText.h"
|
||||||
#include "Threading.h"
|
#include "Threading.h"
|
||||||
|
#include "IniInterface.h"
|
||||||
|
|
||||||
#include <wx/cshelp.h>
|
#include <wx/cshelp.h>
|
||||||
#include <wx/tooltip.h>
|
#include <wx/tooltip.h>
|
||||||
|
@ -27,7 +28,7 @@ using namespace pxSizerFlags;
|
||||||
|
|
||||||
pxDialogCreationFlags pxDialogFlags()
|
pxDialogCreationFlags pxDialogFlags()
|
||||||
{
|
{
|
||||||
return pxDialogCreationFlags().CloseBox().SystemMenu().Caption().Vertical();
|
return pxDialogCreationFlags().CloseBox().Caption().Vertical();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -116,7 +117,7 @@ wxDialogWithHelpers::wxDialogWithHelpers()
|
||||||
m_hasContextHelp = false;
|
m_hasContextHelp = false;
|
||||||
m_extraButtonSizer = NULL;
|
m_extraButtonSizer = NULL;
|
||||||
|
|
||||||
Init();
|
Init( pxDialogFlags() );
|
||||||
}
|
}
|
||||||
|
|
||||||
wxDialogWithHelpers::wxDialogWithHelpers( wxWindow* parent, const wxString& title, const pxDialogCreationFlags& cflags )
|
wxDialogWithHelpers::wxDialogWithHelpers( wxWindow* parent, const wxString& title, const pxDialogCreationFlags& cflags )
|
||||||
|
@ -129,16 +130,21 @@ wxDialogWithHelpers::wxDialogWithHelpers( wxWindow* parent, const wxString& titl
|
||||||
*this += StdPadding;
|
*this += StdPadding;
|
||||||
}
|
}
|
||||||
|
|
||||||
Init();
|
Init( cflags );
|
||||||
SetMinWidth( cflags.MinimumWidth );
|
SetMinSize( cflags.MinimumSize );
|
||||||
}
|
}
|
||||||
|
|
||||||
wxDialogWithHelpers::~wxDialogWithHelpers() throw()
|
wxDialogWithHelpers::~wxDialogWithHelpers() throw()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxDialogWithHelpers::Init()
|
void wxDialogWithHelpers::Init( const pxDialogCreationFlags& cflags )
|
||||||
{
|
{
|
||||||
|
// 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);
|
||||||
|
|
||||||
m_extraButtonSizer = NULL;
|
m_extraButtonSizer = NULL;
|
||||||
|
|
||||||
if( m_hasContextHelp )
|
if( m_hasContextHelp )
|
||||||
|
@ -172,10 +178,8 @@ wxString wxDialogWithHelpers::GetDialogName() const
|
||||||
return wxEmptyString;
|
return wxEmptyString;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxDialogWithHelpers::SmartCenterFit()
|
void wxDialogWithHelpers::DoAutoCenter()
|
||||||
{
|
{
|
||||||
Fit();
|
|
||||||
|
|
||||||
// Smart positioning logic! If our parent window is larger than our window by some
|
// 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
|
// 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
|
// avoids the popup automatically eclipsing the parent window (which happens in PCSX2
|
||||||
|
@ -196,12 +200,50 @@ void wxDialogWithHelpers::SmartCenterFit()
|
||||||
if( centerfail ) CenterOnScreen();
|
if( centerfail ) CenterOnScreen();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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 );
|
||||||
|
IniScopedGroup group( loader, L"DialogPositions" );
|
||||||
|
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 );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Overrides wxDialog behavior to include automatic Fit() and CenterOnParent/Screen. The centering
|
// 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
|
// is based on a heuristic the centers against the parent window if the parent window is at least
|
||||||
// 75% larger than the fitted dialog.
|
// 75% larger than the fitted dialog.
|
||||||
int wxDialogWithHelpers::ShowModal()
|
int wxDialogWithHelpers::ShowModal()
|
||||||
{
|
{
|
||||||
SmartCenterFit();
|
SmartCenterFit();
|
||||||
|
m_CreatedRect = GetScreenRect();
|
||||||
return wxDialog::ShowModal();
|
return wxDialog::ShowModal();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -210,7 +252,11 @@ int wxDialogWithHelpers::ShowModal()
|
||||||
// 75% larger than the fitted dialog.
|
// 75% larger than the fitted dialog.
|
||||||
bool wxDialogWithHelpers::Show( bool show )
|
bool wxDialogWithHelpers::Show( bool show )
|
||||||
{
|
{
|
||||||
if( show ) SmartCenterFit();
|
if( show )
|
||||||
|
{
|
||||||
|
SmartCenterFit();
|
||||||
|
m_CreatedRect = GetScreenRect();
|
||||||
|
}
|
||||||
return wxDialog::Show( show );
|
return wxDialog::Show( show );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -231,6 +277,30 @@ pxStaticText& wxDialogWithHelpers::Heading( const wxString& label )
|
||||||
|
|
||||||
void wxDialogWithHelpers::OnCloseWindow( wxCloseEvent& evt )
|
void wxDialogWithHelpers::OnCloseWindow( wxCloseEvent& evt )
|
||||||
{
|
{
|
||||||
|
// 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
|
||||||
|
|
||||||
|
if( wxConfigBase* cfg = wxConfigBase::Get( false ) )
|
||||||
|
{
|
||||||
|
const wxString dlgName( GetDialogName() );
|
||||||
|
const wxRect screenRect( GetScreenRect() );
|
||||||
|
if( !dlgName.IsEmpty() && ( m_CreatedRect != screenRect) )
|
||||||
|
{
|
||||||
|
wxPoint pos( screenRect.GetPosition() );
|
||||||
|
IniSaver saver( cfg );
|
||||||
|
IniScopedGroup group( saver, L"DialogPositions" );
|
||||||
|
|
||||||
|
if( GetWindowStyle() & wxRESIZE_BORDER )
|
||||||
|
{
|
||||||
|
wxSize size( screenRect.GetSize() );
|
||||||
|
saver.Entry( dlgName + L"_Size", size, screenRect.GetSize() );
|
||||||
|
}
|
||||||
|
saver.Entry( dlgName + L"_Pos", pos, screenRect.GetPosition() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if( !IsModal() ) Destroy();
|
if( !IsModal() ) Destroy();
|
||||||
evt.Skip();
|
evt.Skip();
|
||||||
}
|
}
|
||||||
|
@ -292,6 +362,14 @@ wxDialogWithHelpers& wxDialogWithHelpers::SetMinWidth( int newWidth )
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wxDialogWithHelpers& wxDialogWithHelpers::SetMinHeight( int newHeight )
|
||||||
|
{
|
||||||
|
SetMinSize( wxSize( GetMinWidth(), newHeight ) );
|
||||||
|
if( wxSizer* sizer = GetSizer() )
|
||||||
|
sizer->SetMinSize( wxSize( sizer->GetMinSize().GetWidth(), newHeight ) );
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
// --------------------------------------------------------------------------------------
|
// --------------------------------------------------------------------------------------
|
||||||
// wxPanelWithHelpers Implementations
|
// wxPanelWithHelpers Implementations
|
||||||
// --------------------------------------------------------------------------------------
|
// --------------------------------------------------------------------------------------
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
|
|
||||||
#include <wx/fileconf.h>
|
#include <wx/fileconf.h>
|
||||||
|
|
||||||
#include "IniInterface.h"
|
#include "Utilities/IniInterface.h"
|
||||||
#include "Config.h"
|
#include "Config.h"
|
||||||
#include "GS.h"
|
#include "GS.h"
|
||||||
|
|
||||||
|
|
|
@ -16,11 +16,12 @@
|
||||||
#include "PrecompiledHeader.h"
|
#include "PrecompiledHeader.h"
|
||||||
#include "App.h"
|
#include "App.h"
|
||||||
#include "MainFrame.h"
|
#include "MainFrame.h"
|
||||||
#include "IniInterface.h"
|
|
||||||
#include "Plugins.h"
|
#include "Plugins.h"
|
||||||
|
|
||||||
#include "MemoryCardFile.h"
|
#include "MemoryCardFile.h"
|
||||||
|
|
||||||
|
#include "Utilities/IniInterface.h"
|
||||||
|
|
||||||
#include <wx/stdpaths.h>
|
#include <wx/stdpaths.h>
|
||||||
#include "DebugTools/Debug.h"
|
#include "DebugTools/Debug.h"
|
||||||
|
|
||||||
|
@ -317,13 +318,10 @@ wxString AppConfig::FullpathTo( PluginsEnum_t pluginidx ) const
|
||||||
// rather than any other type of more direct string comparison!
|
// rather than any other type of more direct string comparison!
|
||||||
bool AppConfig::FullpathMatchTest( PluginsEnum_t pluginId, const wxString& cmpto ) const
|
bool AppConfig::FullpathMatchTest( PluginsEnum_t pluginId, const wxString& cmpto ) const
|
||||||
{
|
{
|
||||||
wxFileName right( cmpto );
|
// Implementation note: wxFileName automatically normalizes things as needed in it's
|
||||||
wxFileName left( FullpathTo(pluginId) );
|
// equality comparison implementations, so we can do a simple comparison as follows:
|
||||||
|
|
||||||
left.MakeAbsolute();
|
return wxFileName(cmpto).SameAs( FullpathTo(pluginId) );
|
||||||
right.MakeAbsolute();
|
|
||||||
|
|
||||||
return left == right;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
wxDirName GetLogFolder()
|
wxDirName GetLogFolder()
|
||||||
|
@ -352,7 +350,7 @@ AppConfig::AppConfig()
|
||||||
: MainGuiPosition( wxDefaultPosition )
|
: MainGuiPosition( wxDefaultPosition )
|
||||||
, SysSettingsTabName( L"Cpu" )
|
, SysSettingsTabName( L"Cpu" )
|
||||||
, McdSettingsTabName( L"Standard" )
|
, McdSettingsTabName( L"Standard" )
|
||||||
, AppSettingsTabName( L"GS Window" )
|
, AppSettingsTabName( L"Plugins" )
|
||||||
, DeskTheme( L"default" )
|
, DeskTheme( L"default" )
|
||||||
{
|
{
|
||||||
LanguageId = wxLANGUAGE_DEFAULT;
|
LanguageId = wxLANGUAGE_DEFAULT;
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
|
|
||||||
#include "PrecompiledHeader.h"
|
#include "PrecompiledHeader.h"
|
||||||
#include "App.h"
|
#include "App.h"
|
||||||
#include "IniInterface.h"
|
#include "Utilities/IniInterface.h"
|
||||||
#include "Utilities/EventSource.inl"
|
#include "Utilities/EventSource.inl"
|
||||||
|
|
||||||
template class EventSource< IEventListener_CoreThread >;
|
template class EventSource< IEventListener_CoreThread >;
|
||||||
|
|
|
@ -14,11 +14,11 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "PrecompiledHeader.h"
|
#include "PrecompiledHeader.h"
|
||||||
#include "IniInterface.h"
|
|
||||||
#include "MainFrame.h"
|
#include "MainFrame.h"
|
||||||
#include "ConsoleLogger.h"
|
#include "ConsoleLogger.h"
|
||||||
#include "MSWstuff.h"
|
#include "MSWstuff.h"
|
||||||
|
|
||||||
|
#include "Utilities/IniInterface.h"
|
||||||
#include "DebugTools/Debug.h"
|
#include "DebugTools/Debug.h"
|
||||||
#include "Dialogs/ModalPopups.h"
|
#include "Dialogs/ModalPopups.h"
|
||||||
|
|
||||||
|
@ -61,6 +61,9 @@ void Pcsx2App::WipeUserModeSettings()
|
||||||
if( !usrlocaldir.Exists() ) return;
|
if( !usrlocaldir.Exists() ) return;
|
||||||
|
|
||||||
wxString cwd( Path::Normalize( wxGetCwd() ) );
|
wxString cwd( Path::Normalize( wxGetCwd() ) );
|
||||||
|
#ifdef __WXMSW__
|
||||||
|
cwd.MakeLower();
|
||||||
|
#endif
|
||||||
u32 hashres = HashTools::Hash( (char*)cwd.c_str(), cwd.Length()*sizeof(wxChar) );
|
u32 hashres = HashTools::Hash( (char*)cwd.c_str(), cwd.Length()*sizeof(wxChar) );
|
||||||
|
|
||||||
wxFileName usermodefile( FilenameDefs::GetUsermodeConfig() );
|
wxFileName usermodefile( FilenameDefs::GetUsermodeConfig() );
|
||||||
|
@ -91,6 +94,10 @@ void Pcsx2App::ReadUserModeSettings()
|
||||||
}
|
}
|
||||||
|
|
||||||
wxString cwd( Path::Normalize( wxGetCwd() ) );
|
wxString cwd( Path::Normalize( wxGetCwd() ) );
|
||||||
|
#ifdef __WXMSW__
|
||||||
|
cwd.MakeLower();
|
||||||
|
#endif
|
||||||
|
|
||||||
u32 hashres = HashTools::Hash( (char*)cwd.c_str(), cwd.Length()*sizeof(wxChar) );
|
u32 hashres = HashTools::Hash( (char*)cwd.c_str(), cwd.Length()*sizeof(wxChar) );
|
||||||
|
|
||||||
wxFileName usermodefile( FilenameDefs::GetUsermodeConfig() );
|
wxFileName usermodefile( FilenameDefs::GetUsermodeConfig() );
|
||||||
|
|
|
@ -14,7 +14,6 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "PrecompiledHeader.h"
|
#include "PrecompiledHeader.h"
|
||||||
#include "IniInterface.h"
|
|
||||||
#include "MainFrame.h"
|
#include "MainFrame.h"
|
||||||
#include "GSFrame.h"
|
#include "GSFrame.h"
|
||||||
|
|
||||||
|
@ -26,6 +25,7 @@
|
||||||
#include "Dialogs/ConfigurationDialog.h"
|
#include "Dialogs/ConfigurationDialog.h"
|
||||||
#include "Dialogs/LogOptionsDialog.h"
|
#include "Dialogs/LogOptionsDialog.h"
|
||||||
|
|
||||||
|
#include "Utilities/IniInterface.h"
|
||||||
#include "Utilities/HashMap.h"
|
#include "Utilities/HashMap.h"
|
||||||
|
|
||||||
#ifdef __WXMSW__
|
#ifdef __WXMSW__
|
||||||
|
|
|
@ -32,16 +32,13 @@ using namespace pxSizerFlags;
|
||||||
// --------------------------------------------------------------------------------------
|
// --------------------------------------------------------------------------------------
|
||||||
|
|
||||||
Dialogs::AboutBoxDialog::AboutBoxDialog( wxWindow* parent )
|
Dialogs::AboutBoxDialog::AboutBoxDialog( wxWindow* parent )
|
||||||
: wxDialogWithHelpers( parent, _("About PCSX2") )
|
: wxDialogWithHelpers( parent, _("About PCSX2"), pxDialogFlags().Resize().MinWidth( 460 ) )
|
||||||
, m_bitmap_dualshock( this, wxID_ANY, wxBitmap( EmbeddedImage<res_Dualshock>().Get() ),
|
, m_bitmap_dualshock( this, wxID_ANY, wxBitmap( EmbeddedImage<res_Dualshock>().Get() ),
|
||||||
wxDefaultPosition, wxDefaultSize, wxBORDER_SUNKEN
|
wxDefaultPosition, wxDefaultSize, wxBORDER_SUNKEN
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
static const wxString LabelAuthors = fromUTF8(
|
static const wxString LabelAuthors = fromUTF8(
|
||||||
"Developers"
|
"Arcum42, Refraction, drk||raziel, cottonvibes, gigaherz, "
|
||||||
"\n\n"
|
|
||||||
"v0.9.6+: Arcum42, Refraction, "
|
|
||||||
"drk||raziel, cottonvibes, gigaherz, "
|
|
||||||
"rama, Jake.Stine, saqib, Tmkk, pseudonym"
|
"rama, Jake.Stine, saqib, Tmkk, pseudonym"
|
||||||
"\n\n"
|
"\n\n"
|
||||||
"Previous versions: Alexey silinov, Aumatt, "
|
"Previous versions: Alexey silinov, Aumatt, "
|
||||||
|
@ -56,38 +53,36 @@ Dialogs::AboutBoxDialog::AboutBoxDialog( wxWindow* parent )
|
||||||
);
|
);
|
||||||
|
|
||||||
static const wxString LabelGreets = fromUTF8(
|
static const wxString LabelGreets = fromUTF8(
|
||||||
"Contributors"
|
"Hiryu and Sjeep (libcdvd / iso filesystem), nneeve (fpu and vu), gregory (linux distros)"
|
||||||
"\n\n"
|
|
||||||
"Hiryu and Sjeep (libcdvd / iso filesystem), nneeve (fpu and vu)"
|
|
||||||
"\n\n"
|
"\n\n"
|
||||||
"Plugin Specialists: ChickenLiver (Lilypad), Efp (efp), "
|
"Plugin Specialists: ChickenLiver (Lilypad), Efp (efp), "
|
||||||
"Gabest (Gsdx, Cdvdolio, Xpad), Zeydlitz (ZZogl)"
|
"Gabest (Gsdx, Cdvdolio, Xpad), Zeydlitz (ZZogl)"
|
||||||
"\n\n"
|
"\n\n"
|
||||||
"Special thanks to: black_wd, Belmont, BGome, _Demo_, Dreamtime, "
|
"Special thanks to: black_wd, Belmont, BGome, _Demo_, Dreamtime, "
|
||||||
"F|RES, MrBrown, razorblade, Seta-san, Skarmeth, feal87, Athos, gregory"
|
"F|RES, MrBrown, razorblade, Seta-san, Skarmeth, feal87, Athos"
|
||||||
);
|
);
|
||||||
|
|
||||||
// This sizer holds text of the authors and a logo!
|
// This sizer holds text of the authors and a logo!
|
||||||
wxBoxSizer& AuthLogoSizer = *new wxBoxSizer( wxHORIZONTAL );
|
wxFlexGridSizer& AuthLogoSizer = *new wxFlexGridSizer( 2, 0, StdPadding );
|
||||||
|
AuthLogoSizer.AddGrowableCol(0, 4);
|
||||||
|
AuthLogoSizer.AddGrowableCol(1, 3);
|
||||||
|
|
||||||
// this sizer holds text of the contributors/testers, and a ps2 image!
|
// this sizer holds text of the contributors/testers, and a ps2 image!
|
||||||
wxBoxSizer& ContribSizer = *new wxBoxSizer( wxHORIZONTAL );
|
wxBoxSizer& ContribSizer = *new wxBoxSizer( wxHORIZONTAL );
|
||||||
|
|
||||||
wxStaticBoxSizer& aboutUs = *new wxStaticBoxSizer( wxVERTICAL, this );
|
wxStaticBoxSizer& aboutUs = *new wxStaticBoxSizer( wxVERTICAL, this );
|
||||||
wxStaticBoxSizer& contribs = *new wxStaticBoxSizer( wxVERTICAL, this );
|
wxStaticBoxSizer& contribs = *new wxStaticBoxSizer( wxVERTICAL, this );
|
||||||
|
|
||||||
pxStaticText& label_auth = Text( LabelAuthors );
|
pxStaticText& label_auth = Text( LabelAuthors ).SetMinWidth(240);
|
||||||
pxStaticText& label_greets = Text( LabelGreets );
|
pxStaticText& label_greets = Text( LabelGreets ).SetMinWidth(200);
|
||||||
|
|
||||||
//label_auth->Wrap( 340 );
|
aboutUs += Heading(L"Developers").Bold() | StdExpand();
|
||||||
//label_greets->Wrap( 200 );
|
aboutUs += label_auth | StdExpand();
|
||||||
|
contribs += Heading(L"Contributors").Bold() | StdExpand();
|
||||||
|
contribs += label_greets | StdExpand();
|
||||||
|
|
||||||
aboutUs += label_auth | StdExpand();
|
AuthLogoSizer += aboutUs | StdExpand();
|
||||||
contribs += label_greets | StdExpand();
|
AuthLogoSizer += contribs | StdExpand();
|
||||||
|
|
||||||
AuthLogoSizer += aboutUs;
|
|
||||||
AuthLogoSizer += 7;
|
|
||||||
AuthLogoSizer += contribs;
|
|
||||||
|
|
||||||
ContribSizer += pxStretchSpacer( 1 );
|
ContribSizer += pxStretchSpacer( 1 );
|
||||||
ContribSizer += m_bitmap_dualshock | StdSpace();
|
ContribSizer += m_bitmap_dualshock | StdSpace();
|
||||||
|
@ -95,17 +90,23 @@ Dialogs::AboutBoxDialog::AboutBoxDialog( wxWindow* parent )
|
||||||
|
|
||||||
// Main (top-level) layout
|
// Main (top-level) layout
|
||||||
|
|
||||||
*this += Text(_("PCSX2 - Playstation 2 Emulator")) | StdCenter();
|
*this += StdPadding;
|
||||||
*this += AuthLogoSizer | StdSpace();
|
*this += Text(_("PCSX2")).Bold() | pxExpand;
|
||||||
|
*this += Text(_("A Playstation 2 Emulator")) | pxExpand;
|
||||||
|
*this += AuthLogoSizer | StdExpand();
|
||||||
|
|
||||||
*this += new wxHyperlinkCtrl( this, wxID_ANY,
|
*this += new wxHyperlinkCtrl( this, wxID_ANY,
|
||||||
_("Pcsx2 Official Website and Forums"), L"http://www.pcsx2.net"
|
_("PCSX2 Official Website and Forums"), L"http://www.pcsx2.net"
|
||||||
) | wxSizerFlags(1).Center().Border( wxALL, 3 );
|
) | pxProportion(1).Center().Border( wxALL, 3 );
|
||||||
|
|
||||||
*this += new wxHyperlinkCtrl( this, wxID_ANY,
|
*this += new wxHyperlinkCtrl( this, wxID_ANY,
|
||||||
_("Pcsx2 Official Svn Repository at Googlecode"), L"http://code.google.com/p/pcsx2"
|
_("PCSX2 Official Svn Repository at Googlecode"), L"http://code.google.com/p/pcsx2"
|
||||||
) | wxSizerFlags(1).Center().Border( wxALL, 3 );
|
) | pxProportion(1).Center().Border( wxALL, 3 );
|
||||||
|
|
||||||
*this += ContribSizer | StdExpand();
|
*this += ContribSizer | StdExpand();
|
||||||
*this += new wxButton( this, wxID_OK, L"I've seen enough") | StdCenter();
|
*this += new wxButton( this, wxID_OK, L"I've seen enough") | StdCenter();
|
||||||
|
|
||||||
|
int bestHeight = GetBestSize().GetHeight();
|
||||||
|
if( bestHeight < 400 ) bestHeight = 400;
|
||||||
|
SetMinHeight( bestHeight );
|
||||||
}
|
}
|
||||||
|
|
|
@ -64,10 +64,6 @@ wxString BaseApplicableDialog::GetDialogName() const
|
||||||
|
|
||||||
void BaseApplicableDialog::Init()
|
void BaseApplicableDialog::Init()
|
||||||
{
|
{
|
||||||
// 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)
|
|
||||||
SetExtraStyle(GetExtraStyle() & ~wxTOPLEVEL_EX_DIALOG);
|
|
||||||
|
|
||||||
Connect( pxEvt_ApplySettings, wxCommandEventHandler (BaseApplicableDialog::OnSettingsApplied) );
|
Connect( pxEvt_ApplySettings, wxCommandEventHandler (BaseApplicableDialog::OnSettingsApplied) );
|
||||||
|
|
||||||
wxCommandEvent applyEvent( pxEvt_ApplySettings );
|
wxCommandEvent applyEvent( pxEvt_ApplySettings );
|
||||||
|
|
|
@ -132,7 +132,7 @@ void MainEmuFrame::OnMoveAround( wxMoveEvent& evt )
|
||||||
proglog->SetPosition( g_Conf->ProgLogBox.DisplayPosition );
|
proglog->SetPosition( g_Conf->ProgLogBox.DisplayPosition );
|
||||||
}
|
}
|
||||||
|
|
||||||
//evt.Skip();
|
evt.Skip();
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainEmuFrame::OnLogBoxHidden()
|
void MainEmuFrame::OnLogBoxHidden()
|
||||||
|
|
|
@ -20,12 +20,13 @@
|
||||||
#include "GS.h"
|
#include "GS.h"
|
||||||
|
|
||||||
#include "MainFrame.h"
|
#include "MainFrame.h"
|
||||||
|
#include "IsoDropTarget.h"
|
||||||
|
|
||||||
#include "Dialogs/ModalPopups.h"
|
#include "Dialogs/ModalPopups.h"
|
||||||
#include "Dialogs/ConfigurationDialog.h"
|
#include "Dialogs/ConfigurationDialog.h"
|
||||||
#include "Dialogs/LogOptionsDialog.h"
|
#include "Dialogs/LogOptionsDialog.h"
|
||||||
|
|
||||||
#include "IniInterface.h"
|
#include "Utilities/IniInterface.h"
|
||||||
#include "IsoDropTarget.h"
|
|
||||||
|
|
||||||
using namespace Dialogs;
|
using namespace Dialogs;
|
||||||
|
|
||||||
|
@ -51,7 +52,7 @@ void MainEmuFrame::Menu_McdSettings_Click(wxCommandEvent &event)
|
||||||
void MainEmuFrame::Menu_WindowSettings_Click(wxCommandEvent &event)
|
void MainEmuFrame::Menu_WindowSettings_Click(wxCommandEvent &event)
|
||||||
{
|
{
|
||||||
wxCommandEvent evt( pxEvt_SetSettingsPage );
|
wxCommandEvent evt( pxEvt_SetSettingsPage );
|
||||||
evt.SetString( L"Window" );
|
evt.SetString( L"GS Window" );
|
||||||
AppOpenDialog<SysConfigDialog>( this )->GetEventHandler()->ProcessEvent( evt );
|
AppOpenDialog<SysConfigDialog>( this )->GetEventHandler()->ProcessEvent( evt );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -64,7 +65,6 @@ void MainEmuFrame::Menu_GSSettings_Click(wxCommandEvent &event)
|
||||||
|
|
||||||
void MainEmuFrame::Menu_SelectPluginsBios_Click(wxCommandEvent &event)
|
void MainEmuFrame::Menu_SelectPluginsBios_Click(wxCommandEvent &event)
|
||||||
{
|
{
|
||||||
//AppOpenDialog<BiosSelectorDialog>( this );
|
|
||||||
AppOpenDialog<ComponentsConfigDialog>( this );
|
AppOpenDialog<ComponentsConfigDialog>( this );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -165,8 +165,7 @@ void Panels::BiosSelectorPanel::DoRefresh()
|
||||||
|
|
||||||
m_ComboBox->Clear();
|
m_ComboBox->Clear();
|
||||||
|
|
||||||
wxFileName right( g_Conf->FullpathToBios() );
|
const wxFileName right( g_Conf->FullpathToBios() );
|
||||||
right.MakeAbsolute();
|
|
||||||
|
|
||||||
for( size_t i=0; i<m_BiosList->GetCount(); ++i )
|
for( size_t i=0; i<m_BiosList->GetCount(); ++i )
|
||||||
{
|
{
|
||||||
|
@ -174,10 +173,7 @@ void Panels::BiosSelectorPanel::DoRefresh()
|
||||||
if( !IsBIOS((*m_BiosList)[i], description) ) continue;
|
if( !IsBIOS((*m_BiosList)[i], description) ) continue;
|
||||||
int sel = m_ComboBox->Append( description, (void*)i );
|
int sel = m_ComboBox->Append( description, (void*)i );
|
||||||
|
|
||||||
wxFileName left( (*m_BiosList)[i] );
|
if( wxFileName((*m_BiosList)[i] ) == right )
|
||||||
left.MakeAbsolute();
|
|
||||||
|
|
||||||
if( left == right )
|
|
||||||
m_ComboBox->SetSelection( sel );
|
m_ComboBox->SetSelection( sel );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
#include "PrecompiledHeader.h"
|
#include "PrecompiledHeader.h"
|
||||||
#include "MainFrame.h"
|
#include "MainFrame.h"
|
||||||
#include "IsoDropTarget.h"
|
#include "IsoDropTarget.h"
|
||||||
#include "IniInterface.h"
|
#include "Utilities/IniInterface.h"
|
||||||
|
|
||||||
extern wxString GetMsg_IsoImageChanged();
|
extern wxString GetMsg_IsoImageChanged();
|
||||||
|
|
||||||
|
|
|
@ -1964,10 +1964,6 @@
|
||||||
RelativePath="..\..\gui\i18n.cpp"
|
RelativePath="..\..\gui\i18n.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\gui\IniInterface.cpp"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\gui\IsoDropTarget.cpp"
|
RelativePath="..\..\gui\IsoDropTarget.cpp"
|
||||||
>
|
>
|
||||||
|
@ -2689,10 +2685,6 @@
|
||||||
RelativePath="..\..\HostGui.h"
|
RelativePath="..\..\HostGui.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\gui\IniInterface.h"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\gui\IsoDropTarget.h"
|
RelativePath="..\..\gui\IsoDropTarget.h"
|
||||||
>
|
>
|
||||||
|
|
Loading…
Reference in New Issue