HostInterface: Add "Sync To Host Refresh Rate" option
This commit is contained in:
parent
bb572741ae
commit
43d01776dc
|
@ -473,6 +473,7 @@ void HostInterface::SetDefaultSettings(SettingsInterface& si)
|
||||||
si.SetFloatValue("Main", "EmulationSpeed", 1.0f);
|
si.SetFloatValue("Main", "EmulationSpeed", 1.0f);
|
||||||
si.SetFloatValue("Main", "FastForwardSpeed", 0.0f);
|
si.SetFloatValue("Main", "FastForwardSpeed", 0.0f);
|
||||||
si.SetFloatValue("Main", "TurboSpeed", 0.0f);
|
si.SetFloatValue("Main", "TurboSpeed", 0.0f);
|
||||||
|
si.SetBoolValue("Main", "SyncToHostRefreshRate", true);
|
||||||
si.SetBoolValue("Main", "IncreaseTimerResolution", true);
|
si.SetBoolValue("Main", "IncreaseTimerResolution", true);
|
||||||
si.SetBoolValue("Main", "StartPaused", false);
|
si.SetBoolValue("Main", "StartPaused", false);
|
||||||
si.SetBoolValue("Main", "StartFullscreen", false);
|
si.SetBoolValue("Main", "StartFullscreen", false);
|
||||||
|
|
|
@ -112,6 +112,7 @@ void Settings::Load(SettingsInterface& si)
|
||||||
emulation_speed = si.GetFloatValue("Main", "EmulationSpeed", 1.0f);
|
emulation_speed = si.GetFloatValue("Main", "EmulationSpeed", 1.0f);
|
||||||
fast_forward_speed = si.GetFloatValue("Main", "FastForwardSpeed", 0.0f);
|
fast_forward_speed = si.GetFloatValue("Main", "FastForwardSpeed", 0.0f);
|
||||||
turbo_speed = si.GetFloatValue("Main", "TurboSpeed", 0.0f);
|
turbo_speed = si.GetFloatValue("Main", "TurboSpeed", 0.0f);
|
||||||
|
sync_to_host_refresh_rate = si.GetBoolValue("Main", "SyncToHostRefreshRate", true);
|
||||||
increase_timer_resolution = si.GetBoolValue("Main", "IncreaseTimerResolution", true);
|
increase_timer_resolution = si.GetBoolValue("Main", "IncreaseTimerResolution", true);
|
||||||
start_paused = si.GetBoolValue("Main", "StartPaused", false);
|
start_paused = si.GetBoolValue("Main", "StartPaused", false);
|
||||||
start_fullscreen = si.GetBoolValue("Main", "StartFullscreen", false);
|
start_fullscreen = si.GetBoolValue("Main", "StartFullscreen", false);
|
||||||
|
@ -283,6 +284,7 @@ void Settings::Save(SettingsInterface& si) const
|
||||||
si.SetFloatValue("Main", "EmulationSpeed", emulation_speed);
|
si.SetFloatValue("Main", "EmulationSpeed", emulation_speed);
|
||||||
si.SetFloatValue("Main", "FastForwardSpeed", fast_forward_speed);
|
si.SetFloatValue("Main", "FastForwardSpeed", fast_forward_speed);
|
||||||
si.SetFloatValue("Main", "TurboSpeed", turbo_speed);
|
si.SetFloatValue("Main", "TurboSpeed", turbo_speed);
|
||||||
|
si.SetBoolValue("Main", "SyncToHostRefreshRate", sync_to_host_refresh_rate);
|
||||||
si.SetBoolValue("Main", "IncreaseTimerResolution", increase_timer_resolution);
|
si.SetBoolValue("Main", "IncreaseTimerResolution", increase_timer_resolution);
|
||||||
si.SetBoolValue("Main", "StartPaused", start_paused);
|
si.SetBoolValue("Main", "StartPaused", start_paused);
|
||||||
si.SetBoolValue("Main", "StartFullscreen", start_fullscreen);
|
si.SetBoolValue("Main", "StartFullscreen", start_fullscreen);
|
||||||
|
|
|
@ -82,6 +82,7 @@ struct Settings
|
||||||
float emulation_speed = 1.0f;
|
float emulation_speed = 1.0f;
|
||||||
float fast_forward_speed = 0.0f;
|
float fast_forward_speed = 0.0f;
|
||||||
float turbo_speed = 0.0f;
|
float turbo_speed = 0.0f;
|
||||||
|
bool sync_to_host_refresh_rate = true;
|
||||||
bool increase_timer_resolution = true;
|
bool increase_timer_resolution = true;
|
||||||
bool start_paused = false;
|
bool start_paused = false;
|
||||||
bool start_fullscreen = false;
|
bool start_fullscreen = false;
|
||||||
|
|
|
@ -25,6 +25,8 @@ ConsoleSettingsWidget::ConsoleSettingsWidget(QtHostInterface* host_interface, QW
|
||||||
SettingWidgetBinder::BindWidgetToEnumSetting(m_host_interface, m_ui.region, "Console", "Region",
|
SettingWidgetBinder::BindWidgetToEnumSetting(m_host_interface, m_ui.region, "Console", "Region",
|
||||||
&Settings::ParseConsoleRegionName, &Settings::GetConsoleRegionName,
|
&Settings::ParseConsoleRegionName, &Settings::GetConsoleRegionName,
|
||||||
Settings::DEFAULT_CONSOLE_REGION);
|
Settings::DEFAULT_CONSOLE_REGION);
|
||||||
|
SettingWidgetBinder::BindWidgetToBoolSetting(m_host_interface, m_ui.syncToHostRefreshRate, "Main",
|
||||||
|
"SyncToHostRefreshRate", true);
|
||||||
SettingWidgetBinder::BindWidgetToEnumSetting(m_host_interface, m_ui.cpuExecutionMode, "CPU", "ExecutionMode",
|
SettingWidgetBinder::BindWidgetToEnumSetting(m_host_interface, m_ui.cpuExecutionMode, "CPU", "ExecutionMode",
|
||||||
&Settings::ParseCPUExecutionMode, &Settings::GetCPUExecutionModeName,
|
&Settings::ParseCPUExecutionMode, &Settings::GetCPUExecutionModeName,
|
||||||
Settings::DEFAULT_CPU_EXECUTION_MODE);
|
Settings::DEFAULT_CPU_EXECUTION_MODE);
|
||||||
|
@ -75,6 +77,10 @@ ConsoleSettingsWidget::ConsoleSettingsWidget(QtHostInterface* host_interface, QW
|
||||||
dialog->registerWidgetHelp(
|
dialog->registerWidgetHelp(
|
||||||
m_ui.turboSpeed, tr("Turbo Speed"), "100%",
|
m_ui.turboSpeed, tr("Turbo Speed"), "100%",
|
||||||
tr("Sets the turbo speed. This speed will be used when the turbo hotkey is pressed/toggled."));
|
tr("Sets the turbo speed. This speed will be used when the turbo hotkey is pressed/toggled."));
|
||||||
|
dialog->registerWidgetHelp(m_ui.syncToHostRefreshRate, tr("Sync To Host Refresh Rate"), "100%",
|
||||||
|
tr("Adjusts the emulation speed so the console's refresh rate matches the host's refresh "
|
||||||
|
"rate, when VSync is enabled. This results in the smoothest animations possible, at "
|
||||||
|
"the cost of potentially increasing the emulation speed by less than 1%."));
|
||||||
|
|
||||||
m_ui.cpuClockSpeed->setEnabled(m_ui.enableCPUClockSpeedControl->checkState() == Qt::Checked);
|
m_ui.cpuClockSpeed->setEnabled(m_ui.enableCPUClockSpeedControl->checkState() == Qt::Checked);
|
||||||
m_ui.cdromReadSpeedup->setCurrentIndex(m_host_interface->GetIntSettingValue("CDROM", "ReadSpeedup", 1) - 1);
|
m_ui.cdromReadSpeedup->setCurrentIndex(m_host_interface->GetIntSettingValue("CDROM", "ReadSpeedup", 1) - 1);
|
||||||
|
|
|
@ -81,6 +81,13 @@
|
||||||
<item row="2" column="1">
|
<item row="2" column="1">
|
||||||
<widget class="QComboBox" name="turboSpeed"/>
|
<widget class="QComboBox" name="turboSpeed"/>
|
||||||
</item>
|
</item>
|
||||||
|
<item row="3" column="0" colspan="2">
|
||||||
|
<widget class="QCheckBox" name="syncToHostRefreshRate">
|
||||||
|
<property name="text">
|
||||||
|
<string>Sync To Host Refresh Rate</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
|
|
@ -604,26 +604,44 @@ bool CommonHostInterface::ResumeSystemFromMostRecentState()
|
||||||
|
|
||||||
void CommonHostInterface::UpdateSpeedLimiterState()
|
void CommonHostInterface::UpdateSpeedLimiterState()
|
||||||
{
|
{
|
||||||
const float target_speed = m_turbo_enabled ?
|
float target_speed = m_turbo_enabled ?
|
||||||
g_settings.turbo_speed :
|
g_settings.turbo_speed :
|
||||||
(m_fast_forward_enabled ? g_settings.fast_forward_speed : g_settings.emulation_speed);
|
(m_fast_forward_enabled ? g_settings.fast_forward_speed : g_settings.emulation_speed);
|
||||||
m_speed_limiter_enabled = (target_speed != 0.0f);
|
m_speed_limiter_enabled = (target_speed != 0.0f);
|
||||||
|
|
||||||
|
if (g_settings.sync_to_host_refresh_rate && target_speed == 1.0f && g_settings.video_sync_enabled && m_display &&
|
||||||
|
System::IsRunning())
|
||||||
|
{
|
||||||
|
float host_refresh_rate;
|
||||||
|
if (m_display->GetHostRefreshRate(&host_refresh_rate))
|
||||||
|
{
|
||||||
|
const float ratio = host_refresh_rate / System::GetThrottleFrequency();
|
||||||
|
const bool can_sync = (ratio >= 0.95f && ratio <= 1.05f);
|
||||||
|
Log_InfoPrintf("Refresh rate: Host=%fhz Guest=%fhz Ratio=%f - %s", host_refresh_rate,
|
||||||
|
System::GetThrottleFrequency(), ratio, can_sync ? "can sync" : "can't sync");
|
||||||
|
if (can_sync)
|
||||||
|
target_speed *= ratio;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const bool is_non_standard_speed = (std::abs(target_speed - 1.0f) > 0.05f);
|
const bool is_non_standard_speed = (std::abs(target_speed - 1.0f) > 0.05f);
|
||||||
const bool audio_sync_enabled =
|
const bool audio_sync_enabled =
|
||||||
!System::IsRunning() || (m_speed_limiter_enabled && g_settings.audio_sync_enabled && !is_non_standard_speed);
|
!System::IsRunning() || (m_speed_limiter_enabled && g_settings.audio_sync_enabled && !is_non_standard_speed);
|
||||||
const bool video_sync_enabled =
|
const bool video_sync_enabled =
|
||||||
!System::IsRunning() || (m_speed_limiter_enabled && g_settings.video_sync_enabled && !is_non_standard_speed);
|
!System::IsRunning() || (m_speed_limiter_enabled && g_settings.video_sync_enabled && !is_non_standard_speed);
|
||||||
const float max_display_fps = m_speed_limiter_enabled ? 0.0f : g_settings.display_max_fps;
|
const float max_display_fps = m_speed_limiter_enabled ? 0.0f : g_settings.display_max_fps;
|
||||||
|
Log_InfoPrintf("Target speed: %f%%", target_speed * 100.0f);
|
||||||
Log_InfoPrintf("Syncing to %s%s", audio_sync_enabled ? "audio" : "",
|
Log_InfoPrintf("Syncing to %s%s", audio_sync_enabled ? "audio" : "",
|
||||||
(audio_sync_enabled && video_sync_enabled) ? " and video" : (video_sync_enabled ? "video" : ""));
|
(audio_sync_enabled && video_sync_enabled) ? " and video" : (video_sync_enabled ? "video" : ""));
|
||||||
Log_InfoPrintf("Max display fps: %f", max_display_fps);
|
Log_InfoPrintf("Max display fps: %f", max_display_fps);
|
||||||
|
|
||||||
if (m_audio_stream)
|
if (m_audio_stream)
|
||||||
{
|
{
|
||||||
const u32 input_sample_rate = (!is_non_standard_speed || target_speed == 0.0f || !g_settings.audio_resampling) ?
|
const u32 input_sample_rate = (target_speed == 0.0f || !g_settings.audio_resampling) ?
|
||||||
AUDIO_SAMPLE_RATE :
|
AUDIO_SAMPLE_RATE :
|
||||||
static_cast<u32>(static_cast<float>(AUDIO_SAMPLE_RATE) * target_speed);
|
static_cast<u32>(static_cast<float>(AUDIO_SAMPLE_RATE) * target_speed);
|
||||||
|
Log_InfoPrintf("Audio input sample rate: %u hz", input_sample_rate);
|
||||||
|
|
||||||
m_audio_stream->SetInputSampleRate(input_sample_rate);
|
m_audio_stream->SetInputSampleRate(input_sample_rate);
|
||||||
m_audio_stream->SetOutputVolume(GetAudioOutputVolume());
|
m_audio_stream->SetOutputVolume(GetAudioOutputVolume());
|
||||||
m_audio_stream->SetSync(audio_sync_enabled);
|
m_audio_stream->SetSync(audio_sync_enabled);
|
||||||
|
@ -2221,7 +2239,8 @@ void CommonHostInterface::CheckForSettingsChanges(const Settings& old_settings)
|
||||||
g_settings.emulation_speed != old_settings.emulation_speed ||
|
g_settings.emulation_speed != old_settings.emulation_speed ||
|
||||||
g_settings.fast_forward_speed != old_settings.fast_forward_speed ||
|
g_settings.fast_forward_speed != old_settings.fast_forward_speed ||
|
||||||
g_settings.display_max_fps != old_settings.display_max_fps ||
|
g_settings.display_max_fps != old_settings.display_max_fps ||
|
||||||
g_settings.audio_resampling != old_settings.audio_resampling)
|
g_settings.audio_resampling != old_settings.audio_resampling ||
|
||||||
|
g_settings.sync_to_host_refresh_rate != old_settings.sync_to_host_refresh_rate)
|
||||||
{
|
{
|
||||||
UpdateSpeedLimiterState();
|
UpdateSpeedLimiterState();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue