mirror of https://github.com/PCSX2/pcsx2.git
pcsx2: Fix mainframe wxStaticBitmap delete issue
wxWindow classes will delete their children when destroyed, so the wxStaticBitmap control must be allocated with new to avoid undefined behaviour.
This commit is contained in:
parent
230c1ece35
commit
aa03c83126
|
@ -327,7 +327,7 @@ MainEmuFrame::MainEmuFrame(wxWindow* parent, const wxString& title)
|
||||||
: wxFrame(parent, wxID_ANY, title, wxDefaultPosition, wxDefaultSize, wxDEFAULT_FRAME_STYLE & ~(wxMAXIMIZE_BOX | wxRESIZE_BORDER) )
|
: wxFrame(parent, wxID_ANY, title, wxDefaultPosition, wxDefaultSize, wxDEFAULT_FRAME_STYLE & ~(wxMAXIMIZE_BOX | wxRESIZE_BORDER) )
|
||||||
|
|
||||||
, m_statusbar( *CreateStatusBar(2, 0) )
|
, m_statusbar( *CreateStatusBar(2, 0) )
|
||||||
, m_background( this, wxID_ANY, wxGetApp().GetLogoBitmap() )
|
, m_background( new wxStaticBitmap(this, wxID_ANY, wxGetApp().GetLogoBitmap()) )
|
||||||
|
|
||||||
// All menu components must be created on the heap!
|
// All menu components must be created on the heap!
|
||||||
|
|
||||||
|
@ -382,7 +382,7 @@ MainEmuFrame::MainEmuFrame(wxWindow* parent, const wxString& title)
|
||||||
|
|
||||||
// The background logo and its window size are different on Windows. Use the
|
// The background logo and its window size are different on Windows. Use the
|
||||||
// background logo size, which is what it'll eventually be resized to.
|
// background logo size, which is what it'll eventually be resized to.
|
||||||
wxSize backsize(m_background.GetBitmap().GetWidth(), m_background.GetBitmap().GetHeight());
|
wxSize backsize(m_background->GetBitmap().GetWidth(), m_background->GetBitmap().GetHeight());
|
||||||
|
|
||||||
wxString wintitle;
|
wxString wintitle;
|
||||||
if( PCSX2_isReleaseVersion )
|
if( PCSX2_isReleaseVersion )
|
||||||
|
@ -416,7 +416,7 @@ MainEmuFrame::MainEmuFrame(wxWindow* parent, const wxString& title)
|
||||||
m_statusbar.SetStatusText( wxEmptyString, 0);
|
m_statusbar.SetStatusText( wxEmptyString, 0);
|
||||||
|
|
||||||
wxBoxSizer& joe( *new wxBoxSizer( wxVERTICAL ) );
|
wxBoxSizer& joe( *new wxBoxSizer( wxVERTICAL ) );
|
||||||
joe.Add( &m_background );
|
joe.Add( m_background );
|
||||||
SetSizerAndFit( &joe );
|
SetSizerAndFit( &joe );
|
||||||
// Makes no sense, but this is needed for the window size to be correct for
|
// Makes no sense, but this is needed for the window size to be correct for
|
||||||
// 200% DPI on Windows. The SetSizerAndFit is supposed to be doing the exact
|
// 200% DPI on Windows. The SetSizerAndFit is supposed to be doing the exact
|
||||||
|
|
|
@ -102,7 +102,7 @@ protected:
|
||||||
bool m_RestartEmuOnDelete;
|
bool m_RestartEmuOnDelete;
|
||||||
|
|
||||||
wxStatusBar& m_statusbar;
|
wxStatusBar& m_statusbar;
|
||||||
wxStaticBitmap m_background;
|
wxStaticBitmap* m_background;
|
||||||
|
|
||||||
wxMenuBar& m_menubar;
|
wxMenuBar& m_menubar;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue