3
0
Fork 0
forked from suyu/suyu

settings: Add AspectRatio enum, split res scale function

This commit is contained in:
lat9nq 2023-08-15 22:41:50 -04:00
parent d5adaeafdf
commit 3e28e85468
3 changed files with 10 additions and 3 deletions

View file

@ -207,9 +207,7 @@ const char* TranslateCategory(Category category) {
return "Miscellaneous"; return "Miscellaneous";
} }
void UpdateRescalingInfo() { void TranslateResolutionInfo(ResolutionSetup setup, ResolutionScalingInfo& info) {
const auto setup = values.resolution_setup.GetValue();
auto& info = values.resolution_info;
info.downscale = false; info.downscale = false;
switch (setup) { switch (setup) {
case ResolutionSetup::Res1_2X: case ResolutionSetup::Res1_2X:
@ -269,6 +267,12 @@ void UpdateRescalingInfo() {
info.active = info.up_scale != 1 || info.down_shift != 0; info.active = info.up_scale != 1 || info.down_shift != 0;
} }
void UpdateRescalingInfo() {
const auto setup = values.resolution_setup.GetValue();
auto& info = values.resolution_info;
TranslateResolutionInfo(setup, info);
}
void RestoreGlobalState(bool is_powered_on) { void RestoreGlobalState(bool is_powered_on) {
// If a game is running, DO NOT restore the global settings state // If a game is running, DO NOT restore the global settings state
if (is_powered_on) { if (is_powered_on) {

View file

@ -525,6 +525,7 @@ std::string GetTimeZoneString(TimeZone time_zone);
void LogSettings(); void LogSettings();
void TranslateResolutionInfo(ResolutionSetup setup, ResolutionScalingInfo& info);
void UpdateRescalingInfo(); void UpdateRescalingInfo();
// Restore the global state of all applicable settings in the Values struct // Restore the global state of all applicable settings in the Values struct

View file

@ -146,6 +146,8 @@ ENUM(AntiAliasing, None, Fxaa, Smaa, MaxEnum);
ENUM(AspectRatio, R16_9, R4_3, R21_9, R16_10, Stretch); ENUM(AspectRatio, R16_9, R4_3, R21_9, R16_10, Stretch);
ENUM(ScreenshotAspectRatio, Auto, R16_9, R4_3, R21_9, R16_10);
template <typename Type> template <typename Type>
inline std::string CanonicalizeEnum(Type id) { inline std::string CanonicalizeEnum(Type id) {
const auto group = EnumMetadata<Type>::Canonicalizations(); const auto group = EnumMetadata<Type>::Canonicalizations();