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.
146 lines
4.2 KiB
C++
146 lines
4.2 KiB
C++
///////////////////////////////////////////////////////////////////////////////
|
|
// Name: wx/preferences.h
|
|
// Purpose: Declaration of wxPreferencesEditor class.
|
|
// Author: Vaclav Slavik
|
|
// Created: 2013-02-19
|
|
// Copyright: (c) 2013 Vaclav Slavik <vslavik@fastmail.fm>
|
|
// Licence: wxWindows licence
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
#ifndef _WX_PREFERENCES_H_
|
|
#define _WX_PREFERENCES_H_
|
|
|
|
#include "wx/defs.h"
|
|
|
|
#if wxUSE_PREFERENCES_EDITOR
|
|
|
|
#include "wx/bitmap.h"
|
|
#include "wx/vector.h"
|
|
|
|
class WXDLLIMPEXP_FWD_CORE wxWindow;
|
|
|
|
class wxPreferencesEditorImpl;
|
|
|
|
#if defined(__WXOSX_COCOA__)
|
|
// GetLargeIcon() is used
|
|
#define wxHAS_PREF_EDITOR_ICONS
|
|
// Changes should be applied immediately
|
|
#define wxHAS_PREF_EDITOR_APPLY_IMMEDIATELY
|
|
// The dialog is shown non-modally.
|
|
#define wxHAS_PREF_EDITOR_MODELESS
|
|
#elif defined(__WXGTK__)
|
|
// Changes should be applied immediately
|
|
#define wxHAS_PREF_EDITOR_APPLY_IMMEDIATELY
|
|
// The dialog is shown non-modally.
|
|
#define wxHAS_PREF_EDITOR_MODELESS
|
|
#endif
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// wxPreferencesEditor: Native preferences editing
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// One page of a preferences window
|
|
class WXDLLIMPEXP_CORE wxPreferencesPage
|
|
{
|
|
public:
|
|
wxPreferencesPage() {}
|
|
virtual ~wxPreferencesPage() {}
|
|
|
|
// Name of the page, used e.g. for tabs
|
|
virtual wxString GetName() const = 0;
|
|
|
|
// Return 32x32 icon used for the page. Currently only used on OS X, where
|
|
// implementation is required; unused on other platforms. Because of this,
|
|
// the method is only pure virtual on platforms that use it.
|
|
#ifdef wxHAS_PREF_EDITOR_ICONS
|
|
virtual wxBitmap GetLargeIcon() const = 0;
|
|
#else
|
|
virtual wxBitmap GetLargeIcon() const { return wxBitmap(); }
|
|
#endif
|
|
|
|
// Create a window (usually a wxPanel) for this page. The caller takes
|
|
// ownership of the returned window.
|
|
virtual wxWindow *CreateWindow(wxWindow *parent) = 0;
|
|
|
|
wxDECLARE_NO_COPY_CLASS(wxPreferencesPage);
|
|
};
|
|
|
|
|
|
// Helper for implementing some common pages (General, Advanced)
|
|
class WXDLLIMPEXP_CORE wxStockPreferencesPage : public wxPreferencesPage
|
|
{
|
|
public:
|
|
enum Kind
|
|
{
|
|
Kind_General,
|
|
Kind_Advanced
|
|
};
|
|
|
|
wxStockPreferencesPage(Kind kind) : m_kind(kind) {}
|
|
Kind GetKind() const { return m_kind; }
|
|
|
|
virtual wxString GetName() const wxOVERRIDE;
|
|
#ifdef __WXOSX_COCOA__
|
|
virtual wxBitmap GetLargeIcon() const wxOVERRIDE;
|
|
#endif
|
|
|
|
private:
|
|
Kind m_kind;
|
|
};
|
|
|
|
|
|
// Notice that this class does not inherit from wxWindow.
|
|
class WXDLLIMPEXP_CORE wxPreferencesEditor
|
|
{
|
|
public:
|
|
// Ctor creates an empty editor, use AddPage() to add controls to it.
|
|
wxPreferencesEditor(const wxString& title = wxString());
|
|
|
|
// Dtor destroys the dialog if still shown.
|
|
virtual ~wxPreferencesEditor();
|
|
|
|
// Add a new page to the editor. The editor takes ownership of the page
|
|
// and won't delete it until it is destroyed itself.
|
|
void AddPage(wxPreferencesPage *page);
|
|
|
|
// Show the preferences dialog or bring it to the top if it's already
|
|
// shown. Notice that this method may or may not block depending on the
|
|
// platform, i.e. depending on whether the dialog is modal or not.
|
|
virtual void Show(wxWindow* parent);
|
|
|
|
// Hide the currently shown dialog, if any. This is typically used to
|
|
// dismiss the dialog if the object whose preferences it is editing was
|
|
// closed.
|
|
void Dismiss();
|
|
|
|
// Whether changes to values in the pages should be applied immediately
|
|
// (OS X, GTK+) or only when the user clicks OK/Apply (Windows)
|
|
static bool ShouldApplyChangesImmediately()
|
|
{
|
|
#ifdef wxHAS_PREF_EDITOR_APPLY_IMMEDIATELY
|
|
return true;
|
|
#else
|
|
return false;
|
|
#endif
|
|
}
|
|
|
|
// Whether the dialog is shown modally, i.e. Show() blocks, or not.
|
|
static bool ShownModally()
|
|
{
|
|
#ifdef wxHAS_PREF_EDITOR_MODELESS
|
|
return false;
|
|
#else
|
|
return true;
|
|
#endif
|
|
}
|
|
|
|
private:
|
|
wxPreferencesEditorImpl* m_impl;
|
|
|
|
wxDECLARE_NO_COPY_CLASS(wxPreferencesEditor);
|
|
};
|
|
|
|
#endif // wxUSE_PREFERENCES_EDITOR
|
|
|
|
#endif // _WX_PREFERENCES_H_
|