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:
Jonathan Li 2019-12-02 20:40:48 +00:00
parent 230c1ece35
commit aa03c83126
2 changed files with 4 additions and 4 deletions

View File

@ -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

View File

@ -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;