Revert "Improve Integer Scaling behavior" and instead offer as a setting

This commit is contained in:
Superstarxalien 2023-01-23 13:44:44 -04:00
parent 51d1587b21
commit afaedfedc9
5 changed files with 29 additions and 67 deletions

View File

@ -227,39 +227,18 @@ void HostDisplay::CalculateDrawRect(s32 window_width, s32 window_height, float*
apply_aspect_ratio ? apply_aspect_ratio ?
(display_aspect_ratio / (static_cast<float>(m_display_width) / static_cast<float>(m_display_height))) : (display_aspect_ratio / (static_cast<float>(m_display_width) / static_cast<float>(m_display_height))) :
1.0f; 1.0f;
const float display_width_stretched = static_cast<float>(m_display_width) * x_scale; const float display_width = g_settings.display_stretch_vertically ?
const float display_width_pre = static_cast<float>(m_display_width) : static_cast<float>(m_display_width) * x_scale;
(display_width_stretched > static_cast<float>(m_display_width)) ? const float display_height = g_settings.display_stretch_vertically ?
display_width_stretched : static_cast<float>(m_display_width); static_cast<float>(m_display_height) / x_scale : static_cast<float>(m_display_height);
const float display_width = g_settings.display_always_stretch_horizontally ? display_width_stretched : const float active_left = g_settings.display_stretch_vertically ?
display_width_pre; static_cast<float>(m_display_active_left) : static_cast<float>(m_display_active_left) * x_scale;
const float active_left_stretched = static_cast<float>(m_display_active_left) * x_scale; const float active_top = g_settings.display_stretch_vertically ?
const float active_left_pre = static_cast<float>(m_display_active_top) / x_scale : static_cast<float>(m_display_active_top);
(display_width_stretched > static_cast<float>(m_display_width)) ? const float active_width = g_settings.display_stretch_vertically ?
active_left_stretched : static_cast<float>(m_display_active_left); static_cast<float>(m_display_active_width) : static_cast<float>(m_display_active_width) * x_scale;
const float active_left = g_settings.display_always_stretch_horizontally ? active_left_stretched : const float active_height = g_settings.display_stretch_vertically ?
active_left_pre; static_cast<float>(m_display_active_height) / x_scale : static_cast<float>(m_display_active_height);
const float active_width_stretched = static_cast<float>(m_display_active_width) * x_scale;
const float active_width_pre =
(display_width_stretched > static_cast<float>(m_display_width)) ?
active_width_stretched : static_cast<float>(m_display_active_width);
const float active_width = g_settings.display_always_stretch_horizontally ? active_width_stretched :
active_width_pre;
const float display_height_pre =
(display_width_stretched < static_cast<float>(m_display_width)) ?
static_cast<float>(m_display_height) / x_scale : static_cast<float>(m_display_height);
const float display_height = g_settings.display_always_stretch_horizontally ?
static_cast<float>(m_display_height) : display_height_pre;
const float active_top_pre =
(display_width_stretched < static_cast<float>(m_display_width)) ?
static_cast<float>(m_display_active_top) / x_scale : static_cast<float>(m_display_active_top);
const float active_top = g_settings.display_always_stretch_horizontally ?
static_cast<float>(m_display_active_top) : active_top_pre;
const float active_height_pre =
(display_width_stretched < static_cast<float>(m_display_width)) ?
static_cast<float>(m_display_active_height) / x_scale : static_cast<float>(m_display_active_height);
const float active_height = g_settings.display_always_stretch_horizontally ?
static_cast<float>(m_display_active_height) : active_height_pre;
if (out_x_scale) if (out_x_scale)
*out_x_scale = x_scale; *out_x_scale = x_scale;
@ -387,17 +366,8 @@ std::tuple<float, float> HostDisplay::ConvertWindowCoordinatesToDisplayCoordinat
const float scaled_display_y = static_cast<float>(window_y) - top_padding; const float scaled_display_y = static_cast<float>(window_y) - top_padding;
// scale back to internal resolution // scale back to internal resolution
const float display_x_stretched = scaled_display_x / scale / x_scale; const float display_x = scaled_display_x / scale / x_scale;
const float display_x_pre = const float display_y = scaled_display_y / scale;
(display_x_stretched > (scaled_display_x / scale)) ?
display_x_stretched : (scaled_display_x / scale);
const float display_x = g_settings.display_always_stretch_horizontally ?
display_x_stretched : display_x_pre;
const float display_y_pre =
(display_x_stretched < (scaled_display_x / scale)) ?
scaled_display_y / scale * x_scale : scaled_display_y / scale;
const float display_y = g_settings.display_always_stretch_horizontally ?
scaled_display_y / scale : display_y_pre;
return std::make_tuple(display_x, display_y); return std::make_tuple(display_x, display_y);
} }
@ -524,20 +494,12 @@ bool HostDisplay::WriteDisplayTextureToFile(std::string filename, bool full_reso
const float ss_width_scale = static_cast<float>(m_display_active_width) / static_cast<float>(m_display_width); const float ss_width_scale = static_cast<float>(m_display_active_width) / static_cast<float>(m_display_width);
const float ss_height_scale = static_cast<float>(m_display_active_height) / static_cast<float>(m_display_height); const float ss_height_scale = static_cast<float>(m_display_active_height) / static_cast<float>(m_display_height);
const float ss_aspect_ratio = m_display_aspect_ratio * ss_width_scale / ss_height_scale; const float ss_aspect_ratio = m_display_aspect_ratio * ss_width_scale / ss_height_scale;
const float resize_width_stretched = static_cast<float>(resize_height) * ss_aspect_ratio; resize_width = g_settings.display_stretch_vertically ?
const float resize_width_pre = m_display_texture_view_width : static_cast<s32>(static_cast<float>(resize_height) * ss_aspect_ratio);
(static_cast<s32>(resize_width_stretched) > m_display_texture_view_width) ? resize_height = g_settings.display_stretch_vertically ?
resize_width_stretched : static_cast<float>(m_display_texture_view_width); static_cast<s32>(static_cast<float>(resize_height) /
resize_width = g_settings.display_always_stretch_horizontally ? (m_display_aspect_ratio / (static_cast<float>(m_display_width) / static_cast<float>(m_display_height)))) :
static_cast<s32>(resize_width_stretched) : static_cast<s32>(resize_width_pre); resize_height;
if (!g_settings.display_always_stretch_horizontally)
{
resize_height =
(static_cast<s32>(resize_width_stretched) < m_display_texture_view_width) ?
static_cast<s32>(static_cast<float>(resize_height) /
(m_display_aspect_ratio / (static_cast<float>(m_display_width) / static_cast<float>(m_display_height)))) :
resize_height;
}
} }
else else
{ {

View File

@ -270,7 +270,7 @@ void Settings::Load(SettingsInterface& si)
display_show_enhancements = si.GetBoolValue("Display", "ShowEnhancements", false); display_show_enhancements = si.GetBoolValue("Display", "ShowEnhancements", false);
display_all_frames = si.GetBoolValue("Display", "DisplayAllFrames", false); display_all_frames = si.GetBoolValue("Display", "DisplayAllFrames", false);
display_internal_resolution_screenshots = si.GetBoolValue("Display", "InternalResolutionScreenshots", false); display_internal_resolution_screenshots = si.GetBoolValue("Display", "InternalResolutionScreenshots", false);
display_always_stretch_horizontally = si.GetBoolValue("Display", "AlwaysStretchHorizontally", false); display_stretch_vertically = si.GetBoolValue("Display", "StretchVertically", false);
video_sync_enabled = si.GetBoolValue("Display", "VSync", DEFAULT_VSYNC_VALUE); video_sync_enabled = si.GetBoolValue("Display", "VSync", DEFAULT_VSYNC_VALUE);
display_post_process_chain = si.GetStringValue("Display", "PostProcessChain", ""); display_post_process_chain = si.GetStringValue("Display", "PostProcessChain", "");
display_max_fps = si.GetFloatValue("Display", "MaxFPS", DEFAULT_DISPLAY_MAX_FPS); display_max_fps = si.GetFloatValue("Display", "MaxFPS", DEFAULT_DISPLAY_MAX_FPS);
@ -488,7 +488,7 @@ void Settings::Save(SettingsInterface& si) const
si.SetBoolValue("Display", "ShowEnhancements", display_show_enhancements); si.SetBoolValue("Display", "ShowEnhancements", display_show_enhancements);
si.SetBoolValue("Display", "DisplayAllFrames", display_all_frames); si.SetBoolValue("Display", "DisplayAllFrames", display_all_frames);
si.SetBoolValue("Display", "InternalResolutionScreenshots", display_internal_resolution_screenshots); si.SetBoolValue("Display", "InternalResolutionScreenshots", display_internal_resolution_screenshots);
si.SetBoolValue("Display", "AlwaysStretchHorizontally", display_always_stretch_horizontally); si.SetBoolValue("Display", "StretchVertically", display_stretch_vertically);
si.SetBoolValue("Display", "VSync", video_sync_enabled); si.SetBoolValue("Display", "VSync", video_sync_enabled);
if (display_post_process_chain.empty()) if (display_post_process_chain.empty())
si.DeleteValue("Display", "PostProcessChain"); si.DeleteValue("Display", "PostProcessChain");

View File

@ -143,7 +143,7 @@ struct Settings
bool display_show_enhancements = false; bool display_show_enhancements = false;
bool display_all_frames = false; bool display_all_frames = false;
bool display_internal_resolution_screenshots = false; bool display_internal_resolution_screenshots = false;
bool display_always_stretch_horizontally = false; bool display_stretch_vertically = false;
bool video_sync_enabled = DEFAULT_VSYNC_VALUE; bool video_sync_enabled = DEFAULT_VSYNC_VALUE;
float display_osd_scale = 100.0f; float display_osd_scale = 100.0f;
float display_max_fps = DEFAULT_DISPLAY_MAX_FPS; float display_max_fps = DEFAULT_DISPLAY_MAX_FPS;

View File

@ -288,8 +288,8 @@ void AdvancedSettingsWidget::addTweakOptions()
addBooleanTweakOption(m_dialog, m_ui.tweakOptionTable, tr("Use Debug Host GPU Device"), "GPU", "UseDebugDevice", addBooleanTweakOption(m_dialog, m_ui.tweakOptionTable, tr("Use Debug Host GPU Device"), "GPU", "UseDebugDevice",
false); false);
addBooleanTweakOption(m_dialog, m_ui.tweakOptionTable, tr("Always Stretch Display Horizontally"), "Display", addBooleanTweakOption(m_dialog, m_ui.tweakOptionTable, tr("Stretch Display Vertically"), "Display",
"AlwaysStretchHorizontally", false); "StretchVertically", false);
addBooleanTweakOption(m_dialog, m_ui.tweakOptionTable, tr("Increase Timer Resolution"), "Main", addBooleanTweakOption(m_dialog, m_ui.tweakOptionTable, tr("Increase Timer Resolution"), "Main",
"IncreaseTimerResolution", true); "IncreaseTimerResolution", true);
@ -357,7 +357,7 @@ void AdvancedSettingsWidget::onResetToDefaultClicked()
sif->DeleteValue("Display", "ActiveEndOffset"); sif->DeleteValue("Display", "ActiveEndOffset");
sif->DeleteValue("Display", "LineStartOffset"); sif->DeleteValue("Display", "LineStartOffset");
sif->DeleteValue("Display", "LineEndOffset"); sif->DeleteValue("Display", "LineEndOffset");
sif->DeleteValue("Display", "AlwaysStretchHorizontally"); sif->DeleteValue("Display", "StretchVertically");
sif->DeleteValue("GPU", "Multisamples"); sif->DeleteValue("GPU", "Multisamples");
sif->DeleteValue("GPU", "PerSampleShading"); sif->DeleteValue("GPU", "PerSampleShading");
sif->DeleteValue("GPU", "PGXPVertexCache"); sif->DeleteValue("GPU", "PGXPVertexCache");

View File

@ -4506,9 +4506,9 @@ void FullscreenUI::DrawAdvancedSettingsPage()
DrawFloatRangeSetting(bsi, "Display FPS Limit", DrawFloatRangeSetting(bsi, "Display FPS Limit",
"Limits how many frames are displayed to the screen. These frames are still rendered.", "Limits how many frames are displayed to the screen. These frames are still rendered.",
"Display", "MaxFPS", Settings::DEFAULT_DISPLAY_MAX_FPS, 0.0f, 500.0f, "%.2f FPS"); "Display", "MaxFPS", Settings::DEFAULT_DISPLAY_MAX_FPS, 0.0f, 500.0f, "%.2f FPS");
DrawToggleSetting(bsi, "Always Stretch Display Horizontally", DrawToggleSetting(bsi, "Stretch Display Vertically",
"Enables old DuckStation behavior for Integer Scaling, where the display is always stretched horizontally.", "Stretches the display to match the aspect ratio by multiplying vertically instead of horizontally.",
"Display", "AlwaysStretchHorizontally", false); "Display", "StretchVertically", false);
MenuHeading("PGXP Settings"); MenuHeading("PGXP Settings");