mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-18 03:59:14 +01:00
822326eea9
From wxWidgets master 81570ae070b35c9d52de47b1f14897f3ff1a66c7. include/wx/defs.h -- __w64 warning disable patch by comex brought forward. include/wx/msw/window.h -- added GetContentScaleFactor() which was not implemented on Windows but is necessary for wxBitmap scaling on Mac OS X so it needs to work to avoid #ifdef-ing the code. src/gtk/window.cpp -- Modified DoSetClientSize() to direct call wxWindowGTK::DoSetSize() instead of using public wxWindowBase::SetSize() which now prevents derived classes (like wxAuiToolbar) intercepting the call and breaking it. This matches Windows which does NOT need to call DoSetSize internally. End result is this fixes Dolphin's debug tools toolbars on Linux. src/osx/window_osx.cpp -- Same fix as for GTK since it has the same issue. src/msw/radiobox.cpp -- Hacked to fix display in HiDPI (was clipping off end of text). Updated CMakeLists for Linux and Mac OS X. Small code changes to Dolphin to fix debug error boxes, deprecation warnings, and retain previous UI behavior on Windows.
154 lines
4.7 KiB
C++
154 lines
4.7 KiB
C++
/////////////////////////////////////////////////////////////////////////////
|
|
// Name: wx/gtk/mdi.h
|
|
// Purpose: TDI-based MDI implementation for wxGTK
|
|
// Author: Robert Roebling
|
|
// Modified by: 2008-10-31 Vadim Zeitlin: derive from the base classes
|
|
// Copyright: (c) 1998 Robert Roebling
|
|
// (c) 2008 Vadim Zeitlin
|
|
// Licence: wxWindows licence
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
#ifndef _WX_GTK_MDI_H_
|
|
#define _WX_GTK_MDI_H_
|
|
|
|
#include "wx/frame.h"
|
|
|
|
class WXDLLIMPEXP_FWD_CORE wxMDIChildFrame;
|
|
class WXDLLIMPEXP_FWD_CORE wxMDIClientWindow;
|
|
|
|
typedef struct _GtkNotebook GtkNotebook;
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// wxMDIParentFrame
|
|
//-----------------------------------------------------------------------------
|
|
|
|
class WXDLLIMPEXP_CORE wxMDIParentFrame : public wxMDIParentFrameBase
|
|
{
|
|
public:
|
|
wxMDIParentFrame() { Init(); }
|
|
wxMDIParentFrame(wxWindow *parent,
|
|
wxWindowID id,
|
|
const wxString& title,
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
const wxSize& size = wxDefaultSize,
|
|
long style = wxDEFAULT_FRAME_STYLE | wxVSCROLL | wxHSCROLL,
|
|
const wxString& name = wxFrameNameStr)
|
|
{
|
|
Init();
|
|
|
|
(void)Create(parent, id, title, pos, size, style, name);
|
|
}
|
|
|
|
bool Create(wxWindow *parent,
|
|
wxWindowID id,
|
|
const wxString& title,
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
const wxSize& size = wxDefaultSize,
|
|
long style = wxDEFAULT_FRAME_STYLE | wxVSCROLL | wxHSCROLL,
|
|
const wxString& name = wxFrameNameStr);
|
|
|
|
// we don't store the active child in m_currentChild unlike the base class
|
|
// version so override this method to find it dynamically
|
|
virtual wxMDIChildFrame *GetActiveChild() const wxOVERRIDE;
|
|
|
|
// implement base class pure virtuals
|
|
// ----------------------------------
|
|
|
|
virtual void ActivateNext() wxOVERRIDE;
|
|
virtual void ActivatePrevious() wxOVERRIDE;
|
|
|
|
static bool IsTDI() { return true; }
|
|
|
|
// implementation
|
|
|
|
bool m_justInserted;
|
|
|
|
virtual void OnInternalIdle() wxOVERRIDE;
|
|
|
|
protected:
|
|
virtual void DoGetClientSize(int* width, int* height) const wxOVERRIDE;
|
|
|
|
private:
|
|
friend class wxMDIChildFrame;
|
|
void Init();
|
|
|
|
wxDECLARE_DYNAMIC_CLASS(wxMDIParentFrame);
|
|
};
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// wxMDIChildFrame
|
|
//-----------------------------------------------------------------------------
|
|
|
|
class WXDLLIMPEXP_CORE wxMDIChildFrame : public wxTDIChildFrame
|
|
{
|
|
public:
|
|
wxMDIChildFrame() { Init(); }
|
|
wxMDIChildFrame(wxMDIParentFrame *parent,
|
|
wxWindowID id,
|
|
const wxString& title,
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
const wxSize& size = wxDefaultSize,
|
|
long style = wxDEFAULT_FRAME_STYLE,
|
|
const wxString& name = wxFrameNameStr)
|
|
{
|
|
Init();
|
|
|
|
Create(parent, id, title, pos, size, style, name);
|
|
}
|
|
|
|
bool Create(wxMDIParentFrame *parent,
|
|
wxWindowID id,
|
|
const wxString& title,
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
const wxSize& size = wxDefaultSize,
|
|
long style = wxDEFAULT_FRAME_STYLE,
|
|
const wxString& name = wxFrameNameStr);
|
|
|
|
virtual ~wxMDIChildFrame();
|
|
|
|
virtual void SetMenuBar( wxMenuBar *menu_bar ) wxOVERRIDE;
|
|
virtual wxMenuBar *GetMenuBar() const wxOVERRIDE;
|
|
|
|
virtual void Activate() wxOVERRIDE;
|
|
|
|
virtual void SetTitle(const wxString& title) wxOVERRIDE;
|
|
|
|
// implementation
|
|
|
|
void OnActivate( wxActivateEvent& event );
|
|
void OnMenuHighlight( wxMenuEvent& event );
|
|
virtual void GTKHandleRealized() wxOVERRIDE;
|
|
|
|
wxMenuBar *m_menuBar;
|
|
bool m_justInserted;
|
|
|
|
private:
|
|
void Init();
|
|
|
|
GtkNotebook *GTKGetNotebook() const;
|
|
|
|
wxDECLARE_EVENT_TABLE();
|
|
wxDECLARE_DYNAMIC_CLASS(wxMDIChildFrame);
|
|
};
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// wxMDIClientWindow
|
|
//-----------------------------------------------------------------------------
|
|
|
|
class WXDLLIMPEXP_CORE wxMDIClientWindow : public wxMDIClientWindowBase
|
|
{
|
|
public:
|
|
wxMDIClientWindow() { }
|
|
~wxMDIClientWindow();
|
|
|
|
virtual bool CreateClient(wxMDIParentFrame *parent,
|
|
long style = wxVSCROLL | wxHSCROLL) wxOVERRIDE;
|
|
|
|
private:
|
|
virtual void AddChildGTK(wxWindowGTK* child) wxOVERRIDE;
|
|
|
|
wxDECLARE_DYNAMIC_CLASS(wxMDIClientWindow);
|
|
};
|
|
|
|
#endif // _WX_GTK_MDI_H_
|