Viewport improvements (#3765)
This commit is contained in:
committed by
GitHub
parent
8e2fc49357
commit
147a54c642
@@ -1,14 +1,10 @@
|
||||
using System;
|
||||
using Content.Client.GameObjects.Components.HUD.Inventory;
|
||||
using Content.Shared;
|
||||
using Content.Shared.Prototypes.HUD;
|
||||
using Robust.Client.Graphics;
|
||||
using Robust.Client.ResourceManagement;
|
||||
using Robust.Client.UserInterface;
|
||||
using Robust.Client.UserInterface.Controls;
|
||||
using Robust.Shared;
|
||||
using Robust.Shared.Configuration;
|
||||
using Robust.Shared.IoC;
|
||||
using Robust.Shared.Localization;
|
||||
using Robust.Shared.Maths;
|
||||
using Robust.Shared.Prototypes;
|
||||
@@ -39,6 +35,11 @@ namespace Content.Client.UserInterface
|
||||
private readonly OptionButton LightingPresetOption;
|
||||
private readonly OptionButton _uiScaleOption;
|
||||
private readonly OptionButton _hudThemeOption;
|
||||
private readonly CheckBox _viewportStretchCheckBox;
|
||||
private readonly CheckBox _viewportLowResCheckBox;
|
||||
private readonly Slider _viewportScaleSlider;
|
||||
private readonly Control _viewportScaleBox;
|
||||
private readonly Label _viewportScaleText;
|
||||
|
||||
public GraphicsControl(IConfigurationManager cfg, IPrototypeManager proMan)
|
||||
{
|
||||
@@ -121,12 +122,55 @@ namespace Content.Client.UserInterface
|
||||
}
|
||||
});
|
||||
|
||||
contents.AddChild(new Placeholder()
|
||||
_viewportStretchCheckBox = new CheckBox
|
||||
{
|
||||
VerticalExpand = true,
|
||||
PlaceholderText = Loc.GetString("ui-options-placeholder-viewport")
|
||||
Text = Loc.GetString("ui-options-vp-stretch")
|
||||
};
|
||||
|
||||
_viewportStretchCheckBox.OnToggled += _ =>
|
||||
{
|
||||
UpdateViewportScale();
|
||||
UpdateApplyButton();
|
||||
};
|
||||
|
||||
_viewportScaleSlider = new Slider
|
||||
{
|
||||
MinValue = 1,
|
||||
MaxValue = 5,
|
||||
Rounded = true,
|
||||
MinWidth = 200
|
||||
};
|
||||
|
||||
_viewportScaleSlider.OnValueChanged += _ =>
|
||||
{
|
||||
UpdateApplyButton();
|
||||
UpdateViewportScale();
|
||||
};
|
||||
|
||||
_viewportLowResCheckBox = new CheckBox { Text = Loc.GetString("ui-options-vp-low-res")};
|
||||
_viewportLowResCheckBox.OnToggled += OnCheckBoxToggled;
|
||||
|
||||
contents.AddChild(new HBoxContainer
|
||||
{
|
||||
Children =
|
||||
{
|
||||
_viewportStretchCheckBox,
|
||||
(_viewportScaleBox = new HBoxContainer
|
||||
{
|
||||
Children =
|
||||
{
|
||||
(_viewportScaleText = new Label
|
||||
{
|
||||
Margin = new Thickness(8, 0)
|
||||
}),
|
||||
_viewportScaleSlider,
|
||||
}
|
||||
})
|
||||
}
|
||||
});
|
||||
|
||||
contents.AddChild(_viewportLowResCheckBox);
|
||||
|
||||
vBox.AddChild(contents);
|
||||
|
||||
vBox.AddChild(new StripeBack
|
||||
@@ -145,6 +189,12 @@ namespace Content.Client.UserInterface
|
||||
LightingPresetOption.SelectId(GetConfigLightingQuality());
|
||||
_uiScaleOption.SelectId(GetConfigUIScalePreset(ConfigUIScale));
|
||||
_hudThemeOption.SelectId(_cfg.GetCVar(CCVars.HudTheme));
|
||||
_viewportScaleSlider.Value = _cfg.GetCVar(CCVars.ViewportFixedScaleFactor);
|
||||
_viewportStretchCheckBox.Pressed = _cfg.GetCVar(CCVars.ViewportStretch);
|
||||
_viewportLowResCheckBox.Pressed = !_cfg.GetCVar(CCVars.ViewportScaleRender);
|
||||
|
||||
UpdateViewportScale();
|
||||
UpdateApplyButton();
|
||||
|
||||
AddChild(vBox);
|
||||
}
|
||||
@@ -173,6 +223,9 @@ namespace Content.Client.UserInterface
|
||||
_cfg.SetCVar(CVars.DisplayWindowMode,
|
||||
(int) (FullscreenCheckBox.Pressed ? WindowMode.Fullscreen : WindowMode.Windowed));
|
||||
_cfg.SetCVar(CVars.DisplayUIScale, UIScaleOptions[_uiScaleOption.SelectedId]);
|
||||
_cfg.SetCVar(CCVars.ViewportStretch, _viewportStretchCheckBox.Pressed);
|
||||
_cfg.SetCVar(CCVars.ViewportFixedScaleFactor, (int) _viewportScaleSlider.Value);
|
||||
_cfg.SetCVar(CCVars.ViewportScaleRender, !_viewportLowResCheckBox.Pressed);
|
||||
_cfg.SaveToFile();
|
||||
UpdateApplyButton();
|
||||
}
|
||||
@@ -195,8 +248,18 @@ namespace Content.Client.UserInterface
|
||||
var isLightingQualitySame = LightingPresetOption.SelectedId == GetConfigLightingQuality();
|
||||
var isHudThemeSame = _hudThemeOption.SelectedId == _cfg.GetCVar(CCVars.HudTheme);
|
||||
var isUIScaleSame = MathHelper.CloseTo(UIScaleOptions[_uiScaleOption.SelectedId], ConfigUIScale);
|
||||
ApplyButton.Disabled = isVSyncSame && isFullscreenSame && isLightingQualitySame && isHudThemeSame &&
|
||||
isUIScaleSame;
|
||||
var isVPStretchSame = _viewportStretchCheckBox.Pressed == _cfg.GetCVar(CCVars.ViewportStretch);
|
||||
var isVPScaleSame = (int) _viewportScaleSlider.Value == _cfg.GetCVar(CCVars.ViewportFixedScaleFactor);
|
||||
var isVPResSame = _viewportLowResCheckBox.Pressed == !_cfg.GetCVar(CCVars.ViewportScaleRender);
|
||||
|
||||
ApplyButton.Disabled = isVSyncSame &&
|
||||
isFullscreenSame &&
|
||||
isLightingQualitySame &&
|
||||
isUIScaleSame &&
|
||||
isVPStretchSame &&
|
||||
isVPScaleSame &&
|
||||
isVPResSame &&
|
||||
isHudThemeSame;
|
||||
}
|
||||
|
||||
private bool ConfigIsFullscreen =>
|
||||
@@ -261,6 +324,12 @@ namespace Content.Client.UserInterface
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
private void UpdateViewportScale()
|
||||
{
|
||||
_viewportScaleBox.Visible = !_viewportStretchCheckBox.Pressed;
|
||||
_viewportScaleText.Text = Loc.GetString("ui-options-vp-scale", ("scale", _viewportScaleSlider.Value));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user