HostDisplay: Add integer upscaling option
This commit is contained in:
parent
98bb1de31f
commit
b4c31e55e2
|
@ -41,8 +41,16 @@ void HostDisplay::CalculateDrawRect(s32 window_width, s32 window_height, s32* ou
|
||||||
{
|
{
|
||||||
// align in middle vertically
|
// align in middle vertically
|
||||||
scale = static_cast<float>(window_width) / display_width;
|
scale = static_cast<float>(window_width) / display_width;
|
||||||
|
if (m_display_integer_scaling)
|
||||||
|
scale = std::max(std::floor(scale), 1.0f);
|
||||||
|
|
||||||
if (out_left_padding)
|
if (out_left_padding)
|
||||||
|
{
|
||||||
|
if (m_display_integer_scaling)
|
||||||
|
*out_left_padding = std::max<s32>((window_width - static_cast<s32>(display_width * scale)) / 2, 0);
|
||||||
|
else
|
||||||
*out_left_padding = 0;
|
*out_left_padding = 0;
|
||||||
|
}
|
||||||
if (out_top_padding)
|
if (out_top_padding)
|
||||||
*out_top_padding = std::max<s32>((window_height - static_cast<s32>(display_height * scale)) / 2, 0);
|
*out_top_padding = std::max<s32>((window_height - static_cast<s32>(display_height * scale)) / 2, 0);
|
||||||
}
|
}
|
||||||
|
@ -50,11 +58,19 @@ void HostDisplay::CalculateDrawRect(s32 window_width, s32 window_height, s32* ou
|
||||||
{
|
{
|
||||||
// align in middle horizontally
|
// align in middle horizontally
|
||||||
scale = static_cast<float>(window_height) / display_height;
|
scale = static_cast<float>(window_height) / display_height;
|
||||||
|
if (m_display_integer_scaling)
|
||||||
|
scale = std::max(std::floor(scale), 1.0f);
|
||||||
|
|
||||||
if (out_left_padding)
|
if (out_left_padding)
|
||||||
*out_left_padding = std::max<s32>((window_width - static_cast<s32>(display_width * scale)) / 2, 0);
|
*out_left_padding = std::max<s32>((window_width - static_cast<s32>(display_width * scale)) / 2, 0);
|
||||||
if (out_top_padding)
|
if (out_top_padding)
|
||||||
|
{
|
||||||
|
if (m_display_integer_scaling)
|
||||||
|
*out_top_padding = std::max<s32>((window_height - static_cast<s32>(display_height * scale)) / 2, 0);
|
||||||
|
else
|
||||||
*out_top_padding = 0;
|
*out_top_padding = 0;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
*out_width = static_cast<s32>(active_width * scale);
|
*out_width = static_cast<s32>(active_width * scale);
|
||||||
*out_height = static_cast<s32>(active_height * scale);
|
*out_height = static_cast<s32>(active_height * scale);
|
||||||
|
|
|
@ -104,6 +104,7 @@ public:
|
||||||
|
|
||||||
void SetDisplayLinearFiltering(bool enabled) { m_display_linear_filtering = enabled; }
|
void SetDisplayLinearFiltering(bool enabled) { m_display_linear_filtering = enabled; }
|
||||||
void SetDisplayTopMargin(s32 height) { m_display_top_margin = height; }
|
void SetDisplayTopMargin(s32 height) { m_display_top_margin = height; }
|
||||||
|
void SetDisplayIntegerScaling(bool enabled) { m_display_integer_scaling = enabled; }
|
||||||
|
|
||||||
/// Helper function for computing the draw rectangle in a larger window.
|
/// Helper function for computing the draw rectangle in a larger window.
|
||||||
std::tuple<s32, s32, s32, s32> CalculateDrawRect(s32 window_width, s32 window_height, s32 top_margin) const;
|
std::tuple<s32, s32, s32, s32> CalculateDrawRect(s32 window_width, s32 window_height, s32 top_margin) const;
|
||||||
|
@ -154,4 +155,5 @@ protected:
|
||||||
|
|
||||||
bool m_display_linear_filtering = false;
|
bool m_display_linear_filtering = false;
|
||||||
bool m_display_changed = false;
|
bool m_display_changed = false;
|
||||||
|
bool m_display_integer_scaling = false;
|
||||||
};
|
};
|
||||||
|
|
|
@ -81,6 +81,7 @@ bool HostInterface::BootSystem(const SystemBootParameters& parameters)
|
||||||
|
|
||||||
// set host display settings
|
// set host display settings
|
||||||
m_display->SetDisplayLinearFiltering(m_settings.display_linear_filtering);
|
m_display->SetDisplayLinearFiltering(m_settings.display_linear_filtering);
|
||||||
|
m_display->SetDisplayIntegerScaling(m_settings.display_integer_scaling);
|
||||||
|
|
||||||
// create the audio stream. this will never fail, since we'll just fall back to null
|
// create the audio stream. this will never fail, since we'll just fall back to null
|
||||||
CreateAudioStream();
|
CreateAudioStream();
|
||||||
|
@ -958,6 +959,7 @@ void HostInterface::SetDefaultSettings(SettingsInterface& si)
|
||||||
si.SetStringValue("Display", "CropMode", "Overscan");
|
si.SetStringValue("Display", "CropMode", "Overscan");
|
||||||
si.SetStringValue("Display", "PixelAspectRatio", "4:3");
|
si.SetStringValue("Display", "PixelAspectRatio", "4:3");
|
||||||
si.SetBoolValue("Display", "LinearFiltering", true);
|
si.SetBoolValue("Display", "LinearFiltering", true);
|
||||||
|
si.SetBoolValue("Display", "IntegerScaling", false);
|
||||||
si.SetBoolValue("Display", "ShowOSDMessages", true);
|
si.SetBoolValue("Display", "ShowOSDMessages", true);
|
||||||
si.SetBoolValue("Display", "ShowFPS", false);
|
si.SetBoolValue("Display", "ShowFPS", false);
|
||||||
si.SetBoolValue("Display", "ShowVPS", false);
|
si.SetBoolValue("Display", "ShowVPS", false);
|
||||||
|
@ -1023,6 +1025,7 @@ void HostInterface::UpdateSettings(const std::function<void()>& apply_callback)
|
||||||
const DisplayCropMode old_display_crop_mode = m_settings.display_crop_mode;
|
const DisplayCropMode old_display_crop_mode = m_settings.display_crop_mode;
|
||||||
const DisplayAspectRatio old_display_aspect_ratio = m_settings.display_aspect_ratio;
|
const DisplayAspectRatio old_display_aspect_ratio = m_settings.display_aspect_ratio;
|
||||||
const bool old_display_linear_filtering = m_settings.display_linear_filtering;
|
const bool old_display_linear_filtering = m_settings.display_linear_filtering;
|
||||||
|
const bool old_display_integer_scaling = m_settings.display_integer_scaling;
|
||||||
const bool old_cdrom_read_thread = m_settings.cdrom_read_thread;
|
const bool old_cdrom_read_thread = m_settings.cdrom_read_thread;
|
||||||
std::array<ControllerType, NUM_CONTROLLER_AND_CARD_PORTS> old_controller_types = m_settings.controller_types;
|
std::array<ControllerType, NUM_CONTROLLER_AND_CARD_PORTS> old_controller_types = m_settings.controller_types;
|
||||||
std::array<MemoryCardType, NUM_CONTROLLER_AND_CARD_PORTS> old_memory_card_types = m_settings.memory_card_types;
|
std::array<MemoryCardType, NUM_CONTROLLER_AND_CARD_PORTS> old_memory_card_types = m_settings.memory_card_types;
|
||||||
|
@ -1114,6 +1117,9 @@ void HostInterface::UpdateSettings(const std::function<void()>& apply_callback)
|
||||||
if (m_display && m_settings.display_linear_filtering != old_display_linear_filtering)
|
if (m_display && m_settings.display_linear_filtering != old_display_linear_filtering)
|
||||||
m_display->SetDisplayLinearFiltering(m_settings.display_linear_filtering);
|
m_display->SetDisplayLinearFiltering(m_settings.display_linear_filtering);
|
||||||
|
|
||||||
|
if (m_display && m_settings.display_integer_scaling != old_display_integer_scaling)
|
||||||
|
m_display->SetDisplayIntegerScaling(m_settings.display_integer_scaling);
|
||||||
|
|
||||||
if (m_settings.log_level != old_log_level || m_settings.log_filter != old_log_filter ||
|
if (m_settings.log_level != old_log_level || m_settings.log_filter != old_log_filter ||
|
||||||
m_settings.log_to_console != old_log_to_console || m_settings.log_to_window != old_log_to_window ||
|
m_settings.log_to_console != old_log_to_console || m_settings.log_to_window != old_log_to_window ||
|
||||||
m_settings.log_to_file != old_log_to_file)
|
m_settings.log_to_file != old_log_to_file)
|
||||||
|
|
|
@ -38,6 +38,7 @@ void Settings::Load(SettingsInterface& si)
|
||||||
si.GetStringValue("Display", "AspectRatio", GetDisplayAspectRatioName(DisplayAspectRatio::R4_3)).c_str())
|
si.GetStringValue("Display", "AspectRatio", GetDisplayAspectRatioName(DisplayAspectRatio::R4_3)).c_str())
|
||||||
.value_or(DisplayAspectRatio::R4_3);
|
.value_or(DisplayAspectRatio::R4_3);
|
||||||
display_linear_filtering = si.GetBoolValue("Display", "LinearFiltering", true);
|
display_linear_filtering = si.GetBoolValue("Display", "LinearFiltering", true);
|
||||||
|
display_integer_scaling = si.GetBoolValue("Display", "IntegerScaling", false);
|
||||||
display_show_osd_messages = si.GetBoolValue("Display", "ShowOSDMessages", true);
|
display_show_osd_messages = si.GetBoolValue("Display", "ShowOSDMessages", true);
|
||||||
display_show_fps = si.GetBoolValue("Display", "ShowFPS", false);
|
display_show_fps = si.GetBoolValue("Display", "ShowFPS", false);
|
||||||
display_show_vps = si.GetBoolValue("Display", "ShowVPS", false);
|
display_show_vps = si.GetBoolValue("Display", "ShowVPS", false);
|
||||||
|
@ -123,6 +124,7 @@ void Settings::Save(SettingsInterface& si) const
|
||||||
si.SetStringValue("Display", "CropMode", GetDisplayCropModeName(display_crop_mode));
|
si.SetStringValue("Display", "CropMode", GetDisplayCropModeName(display_crop_mode));
|
||||||
si.SetStringValue("Display", "AspectRatio", GetDisplayAspectRatioName(display_aspect_ratio));
|
si.SetStringValue("Display", "AspectRatio", GetDisplayAspectRatioName(display_aspect_ratio));
|
||||||
si.SetBoolValue("Display", "LinearFiltering", display_linear_filtering);
|
si.SetBoolValue("Display", "LinearFiltering", display_linear_filtering);
|
||||||
|
si.SetBoolValue("Display", "IntegerScaling", display_integer_scaling);
|
||||||
si.SetBoolValue("Display", "ShowOSDMessages", display_show_osd_messages);
|
si.SetBoolValue("Display", "ShowOSDMessages", display_show_osd_messages);
|
||||||
si.SetBoolValue("Display", "ShowFPS", display_show_fps);
|
si.SetBoolValue("Display", "ShowFPS", display_show_fps);
|
||||||
si.SetBoolValue("Display", "ShowVPS", display_show_vps);
|
si.SetBoolValue("Display", "ShowVPS", display_show_vps);
|
||||||
|
|
|
@ -57,6 +57,7 @@ struct Settings
|
||||||
DisplayCropMode display_crop_mode = DisplayCropMode::None;
|
DisplayCropMode display_crop_mode = DisplayCropMode::None;
|
||||||
DisplayAspectRatio display_aspect_ratio = DisplayAspectRatio::R4_3;
|
DisplayAspectRatio display_aspect_ratio = DisplayAspectRatio::R4_3;
|
||||||
bool display_linear_filtering = true;
|
bool display_linear_filtering = true;
|
||||||
|
bool display_integer_scaling = false;
|
||||||
bool display_show_osd_messages = false;
|
bool display_show_osd_messages = false;
|
||||||
bool display_show_fps = false;
|
bool display_show_fps = false;
|
||||||
bool display_show_vps = false;
|
bool display_show_vps = false;
|
||||||
|
|
Loading…
Reference in New Issue