mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-11 08:39:13 +01:00
bd9953d97e
The hack was needed because the Nvidia 3D Vision heuristics are documented to only support surfaces that are the same size as the backbuffer. This would be the case if you enabled the hack and selected the "Auto (Window Size)" internal resolution. However, on recent drivers the same effect is achieved by selecting the "Auto (Multiple)" internal resolution. Therefore the hack is no longer required.
206 lines
5.9 KiB
C++
206 lines
5.9 KiB
C++
#pragma once
|
|
|
|
#include <cstddef>
|
|
#include <map>
|
|
#include <string>
|
|
#include <vector>
|
|
#include <wx/checkbox.h>
|
|
#include <wx/choice.h>
|
|
#include <wx/defs.h>
|
|
#include <wx/dialog.h>
|
|
#include <wx/event.h>
|
|
#include <wx/msgdlg.h>
|
|
#include <wx/radiobut.h>
|
|
#include <wx/spinctrl.h>
|
|
#include <wx/stattext.h>
|
|
#include <wx/string.h>
|
|
#include <wx/translation.h>
|
|
#include <wx/window.h>
|
|
|
|
#include "Common/CommonTypes.h"
|
|
#include "Common/SysConf.h"
|
|
#include "Core/ConfigManager.h"
|
|
#include "Core/Core.h"
|
|
#include "Core/CoreParameter.h"
|
|
#include "DolphinWX/WxUtils.h"
|
|
#include "VideoCommon/VideoBackendBase.h"
|
|
#include "VideoCommon/VideoConfig.h"
|
|
|
|
class wxBoxSizer;
|
|
class wxControl;
|
|
class wxPanel;
|
|
|
|
template <typename W>
|
|
class BoolSetting : public W
|
|
{
|
|
public:
|
|
BoolSetting(wxWindow* parent, const wxString& label, const wxString& tooltip, bool &setting, bool reverse = false, long style = 0);
|
|
|
|
void UpdateValue(wxCommandEvent& ev)
|
|
{
|
|
m_setting = (ev.GetInt() != 0) ^ m_reverse;
|
|
ev.Skip();
|
|
}
|
|
private:
|
|
bool &m_setting;
|
|
const bool m_reverse;
|
|
};
|
|
|
|
typedef BoolSetting<wxCheckBox> SettingCheckBox;
|
|
typedef BoolSetting<wxRadioButton> SettingRadioButton;
|
|
|
|
template <typename T>
|
|
class IntegerSetting : public wxSpinCtrl
|
|
{
|
|
public:
|
|
IntegerSetting(wxWindow* parent, const wxString& label, T& setting, int minVal, int maxVal, long style = 0);
|
|
|
|
void UpdateValue(wxCommandEvent& ev)
|
|
{
|
|
m_setting = ev.GetInt();
|
|
ev.Skip();
|
|
}
|
|
private:
|
|
T& m_setting;
|
|
};
|
|
|
|
typedef IntegerSetting<u32> U32Setting;
|
|
|
|
class SettingChoice : public wxChoice
|
|
{
|
|
public:
|
|
SettingChoice(wxWindow* parent, int &setting, const wxString& tooltip, int num = 0, const wxString choices[] = nullptr, long style = 0);
|
|
void UpdateValue(wxCommandEvent& ev);
|
|
private:
|
|
int &m_setting;
|
|
};
|
|
|
|
class VideoConfigDiag : public wxDialog
|
|
{
|
|
public:
|
|
VideoConfigDiag(wxWindow* parent, const std::string &title, const std::string& ininame);
|
|
|
|
protected:
|
|
void Event_Backend(wxCommandEvent &ev)
|
|
{
|
|
VideoBackend* new_backend = g_available_video_backends[ev.GetInt()];
|
|
if (g_video_backend != new_backend)
|
|
{
|
|
bool do_switch = !Core::IsRunning();
|
|
if (new_backend->GetName() == "Software Renderer")
|
|
{
|
|
do_switch = (wxYES == wxMessageBox(_("Software rendering is an order of magnitude slower than using the other backends.\nIt's only useful for debugging purposes.\nDo you really want to enable software rendering? If unsure, select 'No'."),
|
|
_("Warning"), wxYES_NO | wxNO_DEFAULT | wxICON_EXCLAMATION, wxGetActiveWindow()));
|
|
}
|
|
|
|
if (do_switch)
|
|
{
|
|
// TODO: Only reopen the dialog if the software backend is
|
|
// selected (make sure to reinitialize backend info)
|
|
// reopen the dialog
|
|
Close();
|
|
|
|
g_video_backend = new_backend;
|
|
SConfig::GetInstance().m_LocalCoreStartupParameter.m_strVideoBackend = g_video_backend->GetName();
|
|
|
|
g_video_backend->ShowConfig(GetParent());
|
|
}
|
|
else
|
|
{
|
|
// Select current backend again
|
|
choice_backend->SetStringSelection(StrToWxStr(g_video_backend->GetName()));
|
|
}
|
|
}
|
|
|
|
ev.Skip();
|
|
}
|
|
void Event_Adapter(wxCommandEvent &ev) { ev.Skip(); } // TODO
|
|
|
|
void Event_DisplayResolution(wxCommandEvent &ev);
|
|
|
|
void Event_ProgressiveScan(wxCommandEvent &ev)
|
|
{
|
|
SConfig::GetInstance().m_SYSCONF->SetData("IPL.PGS", ev.GetInt());
|
|
SConfig::GetInstance().m_LocalCoreStartupParameter.bProgressive = ev.IsChecked();
|
|
|
|
ev.Skip();
|
|
}
|
|
|
|
void Event_Stc(wxCommandEvent &ev)
|
|
{
|
|
int samples[] = { 0, 512, 128 };
|
|
vconfig.iSafeTextureCache_ColorSamples = samples[ev.GetInt()];
|
|
|
|
ev.Skip();
|
|
}
|
|
|
|
void Event_PPShader(wxCommandEvent &ev)
|
|
{
|
|
const int sel = ev.GetInt();
|
|
if (sel)
|
|
vconfig.sPostProcessingShader = WxStrToStr(ev.GetString());
|
|
else
|
|
vconfig.sPostProcessingShader.clear();
|
|
|
|
ev.Skip();
|
|
}
|
|
|
|
void Event_ClickClose(wxCommandEvent&);
|
|
void Event_Close(wxCloseEvent&);
|
|
|
|
// Enables/disables UI elements depending on current config
|
|
void OnUpdateUI(wxUpdateUIEvent& ev)
|
|
{
|
|
// Anti-aliasing
|
|
choice_aamode->Enable(vconfig.backend_info.AAModes.size() > 1);
|
|
text_aamode->Enable(vconfig.backend_info.AAModes.size() > 1);
|
|
|
|
// Borderless Fullscreen
|
|
borderless_fullscreen->Enable(vconfig.backend_info.bSupportsExclusiveFullscreen);
|
|
borderless_fullscreen->Show(vconfig.backend_info.bSupportsExclusiveFullscreen);
|
|
|
|
// EFB copy
|
|
efbcopy_texture->Enable(vconfig.bEFBCopyEnable);
|
|
efbcopy_ram->Enable(vconfig.bEFBCopyEnable);
|
|
cache_efb_copies->Enable(vconfig.bEFBCopyEnable && !vconfig.bCopyEFBToTexture);
|
|
|
|
// XFB
|
|
virtual_xfb->Enable(vconfig.bUseXFB);
|
|
real_xfb->Enable(vconfig.bUseXFB);
|
|
|
|
ev.Skip();
|
|
}
|
|
|
|
// Creates controls and connects their enter/leave window events to Evt_Enter/LeaveControl
|
|
SettingCheckBox* CreateCheckBox(wxWindow* parent, const wxString& label, const wxString& description, bool &setting, bool reverse = false, long style = 0);
|
|
SettingChoice* CreateChoice(wxWindow* parent, int& setting, const wxString& description, int num = 0, const wxString choices[] = nullptr, long style = 0);
|
|
SettingRadioButton* CreateRadioButton(wxWindow* parent, const wxString& label, const wxString& description, bool &setting, bool reverse = false, long style = 0);
|
|
|
|
// Same as above but only connects enter/leave window events
|
|
wxControl* RegisterControl(wxControl* const control, const wxString& description);
|
|
|
|
void Evt_EnterControl(wxMouseEvent& ev);
|
|
void Evt_LeaveControl(wxMouseEvent& ev);
|
|
void CreateDescriptionArea(wxPanel* const page, wxBoxSizer* const sizer);
|
|
|
|
wxChoice* choice_backend;
|
|
wxChoice* choice_display_resolution;
|
|
wxStaticText* text_aamode;
|
|
SettingChoice* choice_aamode;
|
|
|
|
SettingCheckBox* borderless_fullscreen;
|
|
|
|
SettingRadioButton* efbcopy_texture;
|
|
SettingRadioButton* efbcopy_ram;
|
|
SettingCheckBox* cache_efb_copies;
|
|
|
|
SettingRadioButton* virtual_xfb;
|
|
SettingRadioButton* real_xfb;
|
|
|
|
std::map<wxWindow*, wxString> ctrl_descs; // maps setting controls to their descriptions
|
|
std::map<wxWindow*, wxStaticText*> desc_texts; // maps dialog tabs (which are the parents of the setting controls) to their description text objects
|
|
|
|
VideoConfig &vconfig;
|
|
std::string ininame;
|
|
};
|