Menu #8
@ -1,5 +1,4 @@
|
||||
[/Script/Lost_Edge.CustomGameSettings]
|
||||
bUseMotionBlur=False
|
||||
bShowFps=False
|
||||
bMouseInverted=False
|
||||
fMouseSensetivity=1.000000
|
||||
@ -9,13 +8,13 @@ fEffectsVolume=1.000000
|
||||
fVoicesVolume=1.000000
|
||||
fMenuVolume=1.000000
|
||||
bUseVSync=False
|
||||
bUseDynamicResolution=False
|
||||
bUseDynamicResolution=True
|
||||
ResolutionSizeX=1920
|
||||
ResolutionSizeY=1080
|
||||
LastUserConfirmedResolutionSizeX=1920
|
||||
LastUserConfirmedResolutionSizeY=1080
|
||||
WindowPosX=-1
|
||||
WindowPosY=-1
|
||||
WindowPosX=0
|
||||
WindowPosY=0
|
||||
FullscreenMode=1
|
||||
LastConfirmedFullscreenMode=1
|
||||
PreferredFullscreenMode=1
|
||||
@ -23,10 +22,10 @@ Version=5
|
||||
AudioQualityLevel=0
|
||||
LastConfirmedAudioQualityLevel=0
|
||||
FrameRateLimit=0.000000
|
||||
DesiredScreenWidth=1280
|
||||
DesiredScreenHeight=720
|
||||
LastUserConfirmedDesiredScreenWidth=1280
|
||||
LastUserConfirmedDesiredScreenHeight=720
|
||||
DesiredScreenWidth=1920
|
||||
DesiredScreenHeight=1080
|
||||
LastUserConfirmedDesiredScreenWidth=1920
|
||||
LastUserConfirmedDesiredScreenHeight=1080
|
||||
LastRecommendedScreenWidth=-1.000000
|
||||
LastRecommendedScreenHeight=-1.000000
|
||||
LastCPUBenchmarkResult=-1.000000
|
||||
|
BIN
UnrealProject/Lost_Edge/Content/UI/BP_MainWidgetManager.uasset
(Stored with Git LFS)
BIN
UnrealProject/Lost_Edge/Content/UI/BP_MainWidgetManager.uasset
(Stored with Git LFS)
Binary file not shown.
Binary file not shown.
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/MainMenu/Components/UIC_MainMenu_OptionsButton.uasset
(Stored with Git LFS)
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/MainMenu/Components/UIC_MainMenu_OptionsButton.uasset
(Stored with Git LFS)
Binary file not shown.
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/MainMenu/Components/UIC_MainMenu_OptionsComboBox.uasset
(Stored with Git LFS)
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/MainMenu/Components/UIC_MainMenu_OptionsComboBox.uasset
(Stored with Git LFS)
Binary file not shown.
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/MainMenu/Components/UIC_MainMenu_OptionsSlider.uasset
(Stored with Git LFS)
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/MainMenu/Components/UIC_MainMenu_OptionsSlider.uasset
(Stored with Git LFS)
Binary file not shown.
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/MainMenu/Components/UIC_MainMenu_PageButton.uasset
(Stored with Git LFS)
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/MainMenu/Components/UIC_MainMenu_PageButton.uasset
(Stored with Git LFS)
Binary file not shown.
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/MainMenu/E_MainMenuOptionsButtonName.uasset
(Stored with Git LFS)
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/MainMenu/E_MainMenuOptionsButtonName.uasset
(Stored with Git LFS)
Binary file not shown.
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/MainMenu/Pages/UI_MainMenu_Page_Options_Graphics.uasset
(Stored with Git LFS)
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/MainMenu/Pages/UI_MainMenu_Page_Options_Graphics.uasset
(Stored with Git LFS)
Binary file not shown.
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/MainMenu/UI_MainMenuCredits.uasset
(Stored with Git LFS)
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/MainMenu/UI_MainMenuCredits.uasset
(Stored with Git LFS)
Binary file not shown.
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/Overlays/UI_Crosshair.uasset
(Stored with Git LFS)
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/Overlays/UI_Crosshair.uasset
(Stored with Git LFS)
Binary file not shown.
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/Overlays/UI_DevelopBuildWarning.uasset
(Stored with Git LFS)
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/Overlays/UI_DevelopBuildWarning.uasset
(Stored with Git LFS)
Binary file not shown.
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/Overlays/UI_FpsCounter.uasset
(Stored with Git LFS)
Normal file
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/Overlays/UI_FpsCounter.uasset
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/UI_Journal.uasset
(Stored with Git LFS)
BIN
UnrealProject/Lost_Edge/Content/UI/Blueprints/UI_Journal.uasset
(Stored with Git LFS)
Binary file not shown.
BIN
UnrealProject/Lost_Edge/Content/UI/Components/UIC_ComboBox.uasset
(Stored with Git LFS)
BIN
UnrealProject/Lost_Edge/Content/UI/Components/UIC_ComboBox.uasset
(Stored with Git LFS)
Binary file not shown.
BIN
UnrealProject/Lost_Edge/Content/UI/Components/UIC_Slider.uasset
(Stored with Git LFS)
BIN
UnrealProject/Lost_Edge/Content/UI/Components/UIC_Slider.uasset
(Stored with Git LFS)
Binary file not shown.
@ -105,15 +105,33 @@ FWorldDilationChangedDelegate& UCommonFunctions::GetWorldDilationChangedDelegate
|
||||
return SlowMotion::worldDilationChangedDelegate;
|
||||
}
|
||||
|
||||
TArray<FString> UCommonFunctions::IntArrayToStringArray(const TArray<int32>& in)
|
||||
{
|
||||
TArray<FString> result;
|
||||
result.Reserve(in.Num());
|
||||
for(int32 i : in)
|
||||
result.Add(FString::FromInt(i));
|
||||
return MoveTemp(result);
|
||||
}
|
||||
|
||||
TArray<int32> UCommonFunctions::StringArrayToIntArray(const TArray<FString>& in)
|
||||
{
|
||||
TArray<int32> result;
|
||||
result.Reserve(in.Num());
|
||||
for(auto& i : in)
|
||||
result.Add(FCString::Atoi(*i));
|
||||
return MoveTemp(result);
|
||||
}
|
||||
|
||||
FString UCommonFunctions::IntPointToString(const FIntPoint& in)
|
||||
{
|
||||
FString result = FString::Printf(TEXT("%sx%s"), *FString::FromInt(in.X), *FString::FromInt(in.Y));
|
||||
FString result = FString::Printf(TEXT("%dx%d"), in.X, in.Y);
|
||||
return MoveTemp(result);
|
||||
}
|
||||
|
||||
FIntPoint UCommonFunctions::StringToIntPoint(const FString& in)
|
||||
{
|
||||
FIntPoint result;
|
||||
FIntPoint result{};
|
||||
|
||||
const FRegexPattern rgxP(FRegexPattern(TEXT("[0-9]+")));
|
||||
FRegexMatcher rgx = FRegexMatcher(rgxP, in);
|
||||
@ -125,6 +143,41 @@ FIntPoint UCommonFunctions::StringToIntPoint(const FString& in)
|
||||
return MoveTemp(result);
|
||||
}
|
||||
|
||||
TArray<FString> UCommonFunctions::IntPointArrayToStringArray(const TArray<FIntPoint>& in)
|
||||
{
|
||||
TArray<FString> result;
|
||||
result.Reserve(in.Num());
|
||||
for(auto& i : in)
|
||||
result.Add(IntPointToString(i));
|
||||
return MoveTemp(result);
|
||||
}
|
||||
|
||||
TArray<FIntPoint> UCommonFunctions::StringArrayToIntPointArray(const TArray<FString>& in)
|
||||
{
|
||||
TArray<FIntPoint> result;
|
||||
result.Reserve(in.Num());
|
||||
for(auto& i : in)
|
||||
result.Add(StringToIntPoint(i));
|
||||
return MoveTemp(result);
|
||||
}
|
||||
|
||||
int32 UCommonFunctions::GetLongestCharCount(TArray<FString>& in)
|
||||
{
|
||||
int32 result = 0;
|
||||
for(auto& i : in)
|
||||
if(i.Len() > result)
|
||||
result = i.Len();
|
||||
return result;
|
||||
}
|
||||
|
||||
void UCommonFunctions::SortIntPointArray(TArray<FIntPoint>& in)
|
||||
{
|
||||
in.Sort([](const FIntPoint& a, const FIntPoint& b)
|
||||
{
|
||||
return a.X < b.X || a.Y < b.Y;
|
||||
});
|
||||
}
|
||||
|
||||
int32 UCommonFunctions::GreatestCommonDivisor(int32 a, int32 b)
|
||||
{
|
||||
int32 temp;
|
||||
|
@ -44,10 +44,26 @@ public:
|
||||
|
||||
|
||||
|
||||
UFUNCTION(BlueprintPure, Category = TypeCasts)
|
||||
static TArray<FString> IntArrayToStringArray(const TArray<int32>& in);
|
||||
UFUNCTION(BlueprintPure, Category = TypeCasts)
|
||||
static TArray<int32> StringArrayToIntArray(const TArray<FString>& in);
|
||||
|
||||
UFUNCTION(BlueprintPure, Category = TypeCasts)
|
||||
static FString IntPointToString(const FIntPoint& in);
|
||||
UFUNCTION(BlueprintPure, Category = TypeCasts)
|
||||
static FIntPoint StringToIntPoint(const FString& in);
|
||||
UFUNCTION(BlueprintPure, Category = TypeCasts)
|
||||
static TArray<FString> IntPointArrayToStringArray(const TArray<FIntPoint>& in);
|
||||
UFUNCTION(BlueprintPure, Category = TypeCasts)
|
||||
static TArray<FIntPoint> StringArrayToIntPointArray(const TArray<FString>& in);
|
||||
UFUNCTION(BlueprintPure, Category = TypeCasts)
|
||||
static void SortIntPointArray(UPARAM(ref) TArray<FIntPoint>& in);
|
||||
|
||||
|
||||
|
||||
UFUNCTION(BlueprintPure, Category = String)
|
||||
static int32 GetLongestCharCount(UPARAM(ref) TArray<FString>& in);
|
||||
|
||||
|
||||
|
||||
|
@ -0,0 +1,63 @@
|
||||
// Oleg Petruny proprietary.
|
||||
|
||||
#include "CommonInspectors.h"
|
||||
|
||||
UEnum* UEnumInspector::GetEnumByName(const FString& name)
|
||||
{
|
||||
static TMap<FString, UEnum*> map;
|
||||
if(map.Contains(name))
|
||||
return map[name];
|
||||
|
||||
UEnum* enumPtr = FindObject<UEnum>((UPackage*)-1, *name, true);
|
||||
map.Add(name, enumPtr);
|
||||
return enumPtr;
|
||||
}
|
||||
|
||||
TArray<FText> UEnumInspector::GetEnumDisplayNames(const UEnum* enumPtr)
|
||||
{
|
||||
if(!enumPtr)
|
||||
return {};
|
||||
|
||||
auto enumPtrProxy = static_cast<const UDEPRECATED_EnumInspectorProxy*>(enumPtr);
|
||||
TArray<FText> result;
|
||||
for(int32 i = 0; i < enumPtrProxy->Names.Num() - 1; ++i) // last UEnum value is Num counter
|
||||
result.Add(enumPtr->GetDisplayNameTextByIndex(enumPtrProxy->Names[i].Value));
|
||||
return MoveTemp(result);
|
||||
}
|
||||
|
||||
TArray<uint8> UEnumInspector::GetEnumValues(const UEnum* enumPtr)
|
||||
{
|
||||
if(!enumPtr)
|
||||
return {};
|
||||
|
||||
auto enumPtrProxy = static_cast<const UDEPRECATED_EnumInspectorProxy*>(enumPtr);
|
||||
TArray<uint8> result;
|
||||
for(int32 i = 0; i < enumPtrProxy->Names.Num() - 1; ++i) // last UEnum value is Num counter
|
||||
result.Add(enumPtrProxy->Names[i].Value);
|
||||
return MoveTemp(result);
|
||||
}
|
||||
|
||||
int32 UEnumInspector::GetEnumValueByValueId(const UEnum* enumPtr, const int32 id)
|
||||
{
|
||||
if(!enumPtr)
|
||||
return 0;
|
||||
|
||||
auto enumPtrProxy = static_cast<const UDEPRECATED_EnumInspectorProxy*>(enumPtr);
|
||||
if(id < enumPtrProxy->Names.Num())
|
||||
return enumPtrProxy->Names[id].Value;
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
int32 UEnumInspector::GetEnumValueIdByValue(const UEnum* enumPtr, const int32 value)
|
||||
{
|
||||
if(!enumPtr)
|
||||
return 0;
|
||||
|
||||
auto enumPtrProxy = static_cast<const UDEPRECATED_EnumInspectorProxy*>(enumPtr);
|
||||
for(int32 i = 0; i < enumPtrProxy->Names.Num(); ++i)
|
||||
if(enumPtrProxy->Names[i].Value == value)
|
||||
return i;
|
||||
|
||||
return int32();
|
||||
}
|
@ -0,0 +1,34 @@
|
||||
// Oleg Petruny proprietary.
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "CoreMinimal.h"
|
||||
|
||||
#include "CommonInspectors.generated.h"
|
||||
|
||||
|
||||
UCLASS(Deprecated)
|
||||
class UDEPRECATED_EnumInspectorProxy : public UEnum
|
||||
{
|
||||
GENERATED_BODY()
|
||||
|
||||
friend class UEnumInspector;
|
||||
};
|
||||
|
||||
UCLASS()
|
||||
class UEnumInspector : public UBlueprintFunctionLibrary
|
||||
{
|
||||
GENERATED_BODY()
|
||||
|
||||
public:
|
||||
UFUNCTION(BlueprintPure, Category = Enum)
|
||||
static UEnum* GetEnumByName(const FString& name);
|
||||
UFUNCTION(BlueprintPure, Category = Enum)
|
||||
static TArray<FText> GetEnumDisplayNames(UPARAM(meta = (DisplayName = "enum")) const UEnum* enumPtr);
|
||||
UFUNCTION(BlueprintPure, Category = Enum)
|
||||
static TArray<uint8> GetEnumValues(UPARAM(meta = (DisplayName = "enum")) const UEnum* enumPtr);
|
||||
UFUNCTION(BlueprintPure, Category = Enum)
|
||||
static int32 GetEnumValueByValueId(UPARAM(meta = (DisplayName = "enum")) const UEnum* enumPtr, const int32 id);
|
||||
UFUNCTION(BlueprintPure, Category = Enum)
|
||||
static int32 GetEnumValueIdByValue(UPARAM(meta = (DisplayName = "enum")) const UEnum* enumPtr, const int32 value);
|
||||
};
|
@ -5,6 +5,8 @@
|
||||
#include "Kismet/GameplayStatics.h"
|
||||
|
||||
#include "GraphicsSettingsHelper.h"
|
||||
#include "MainGameModeBase.h"
|
||||
#include "Widgets/WidgetsManager.h"
|
||||
|
||||
namespace
|
||||
{
|
||||
@ -46,6 +48,25 @@ UCustomGameSettings* UCustomGameSettings::Get()
|
||||
return Cast<UCustomGameSettings>(UGameUserSettings::GetGameUserSettings());
|
||||
}
|
||||
|
||||
void UCustomGameSettings::LoadSettings(bool bForceReload)
|
||||
{
|
||||
Super::LoadSettings(bForceReload);
|
||||
UpdateResolutionQuality();
|
||||
}
|
||||
|
||||
void UCustomGameSettings::ApplySettings(bool bCheckForCommandLineOverrides)
|
||||
{
|
||||
Super::ApplySettings(bCheckForCommandLineOverrides);
|
||||
UGraphicsSettingsHelper::ApplySettings(this);
|
||||
if(auto WM = AMainGameModeBase::GetWidgetsManager())
|
||||
{
|
||||
if(bShowFps)
|
||||
WM->ShowFpsCount();
|
||||
else
|
||||
WM->HideFpsCount();
|
||||
}
|
||||
}
|
||||
|
||||
LOST_EDGE_API bool UCustomGameSettings::GetDefaultShowFps() const
|
||||
{
|
||||
return bDefaultShowFps;
|
||||
|
@ -24,6 +24,9 @@ public:
|
||||
UFUNCTION(BlueprintPure, Category = "Settings", meta = (DisplayName = "Get Custom Game Settings"))
|
||||
static UCustomGameSettings* Get();
|
||||
|
||||
virtual void LoadSettings(bool bForceReload = false) override;
|
||||
virtual void ApplySettings(bool bCheckForCommandLineOverrides) override;
|
||||
|
||||
|
||||
|
||||
/** Graphics */
|
||||
@ -92,8 +95,9 @@ public:
|
||||
|
||||
|
||||
protected:
|
||||
/** Graphics */
|
||||
UPROPERTY(Config)
|
||||
float fMouseSensetivity;
|
||||
int32 eAntiAliasingMethod;
|
||||
|
||||
/** Audio */
|
||||
UPROPERTY(Config)
|
||||
@ -107,4 +111,7 @@ protected:
|
||||
UPROPERTY(Config)
|
||||
float fMenuVolume;
|
||||
|
||||
/** Game */
|
||||
UPROPERTY(Config)
|
||||
float fMouseSensetivity;
|
||||
};
|
||||
|
@ -17,10 +17,12 @@ namespace
|
||||
constexpr int32 iDefaultMonitorId = 0;
|
||||
const FIntPoint ipDefaultResolution = { 1920, 1080 };
|
||||
std::optional<FIntPoint> ipPreviousResolution;
|
||||
constexpr float fDefaultResolutionScale = 1.0f;
|
||||
constexpr float fDefaultResolutionScale = 100.0f;
|
||||
constexpr int32 iDefaultFrameRateLimit = 120;
|
||||
constexpr EDisplayMode eDefaultDisplayMode = EDisplayMode::Fullscreen;
|
||||
std::optional<EDisplayMode> ePreviousDisplayMode;
|
||||
constexpr bool bDefaultVSyncEnabled = false;
|
||||
constexpr int32 eDefaultAntiAliasingMethod = static_cast<int32>(ELostEdgeAntiAliasingMethod::FXAA);
|
||||
}
|
||||
|
||||
bool UGraphicsSettingsHelper::AreSettingsRestorable(UCustomGameSettings* settings)
|
||||
@ -30,6 +32,16 @@ bool UGraphicsSettingsHelper::AreSettingsRestorable(UCustomGameSettings* setting
|
||||
|| ePreviousDisplayMode.has_value();
|
||||
}
|
||||
|
||||
void UGraphicsSettingsHelper::RestoreGraphicsSettings(UCustomGameSettings* settings)
|
||||
{
|
||||
if(ipPreviousWindowPosition.has_value())
|
||||
SetWindowPosition(settings, ipPreviousWindowPosition.value());
|
||||
if(ipPreviousResolution.has_value())
|
||||
SetResolution(settings, ipPreviousResolution.value());
|
||||
if(ePreviousDisplayMode.has_value())
|
||||
SetDisplayMode(settings, ePreviousDisplayMode.value());
|
||||
}
|
||||
|
||||
void UGraphicsSettingsHelper::SetDefaults(UCustomGameSettings* settings)
|
||||
{
|
||||
{
|
||||
@ -42,7 +54,23 @@ void UGraphicsSettingsHelper::SetDefaults(UCustomGameSettings* settings)
|
||||
settings->ResolutionSizeX = res.X;
|
||||
settings->ResolutionSizeY = res.Y;
|
||||
}
|
||||
settings->bUseDynamicResolution = true;
|
||||
settings->FrameRateLimit = GetDefaultFrameRateLimit(settings);
|
||||
settings->SetResolutionScaleValueEx(fDefaultResolutionScale);
|
||||
settings->FullscreenMode = DisplayToWindowMode(GetDefaultDisplayMode(settings));
|
||||
settings->eAntiAliasingMethod = eDefaultAntiAliasingMethod;
|
||||
}
|
||||
|
||||
void UGraphicsSettingsHelper::ApplySettings(UCustomGameSettings* settings)
|
||||
{
|
||||
if(!settings)
|
||||
return;
|
||||
|
||||
if(GEngine && GEngine->GameViewport)
|
||||
if(auto window = GEngine->GameViewport->GetWindow())
|
||||
window->MoveWindowTo(settings->GetWindowPosition());
|
||||
|
||||
GEngine->Exec(UCustomGameSettings::Get()->GetWorld(), *FString::Printf(TEXT("r.AntiAliasingMethod %d"), settings->eAntiAliasingMethod));
|
||||
}
|
||||
|
||||
FIntPoint UGraphicsSettingsHelper::GetDefaultWindowPosition([[maybe_unused]] UCustomGameSettings* settings)
|
||||
@ -66,18 +94,14 @@ FIntPoint UGraphicsSettingsHelper::GetWindowPosition([[maybe_unused]] UCustomGam
|
||||
|
||||
void UGraphicsSettingsHelper::SetWindowPosition(UCustomGameSettings* settings, const FIntPoint& pos)
|
||||
{
|
||||
if(settings && GEngine && GEngine->GameViewport)
|
||||
if(settings)
|
||||
{
|
||||
if(auto window = GEngine->GameViewport->GetWindow())
|
||||
{
|
||||
if(ipPreviousWindowPosition == pos)
|
||||
ipPreviousWindowPosition.reset();
|
||||
else
|
||||
ipPreviousWindowPosition = GetWindowPosition(settings);
|
||||
if(ipPreviousWindowPosition == pos)
|
||||
ipPreviousWindowPosition.reset();
|
||||
else
|
||||
ipPreviousWindowPosition = GetWindowPosition(settings);
|
||||
|
||||
window->MoveWindowTo(pos);
|
||||
settings->SetWindowPosition(pos.X, pos.Y);
|
||||
}
|
||||
settings->SetWindowPosition(pos.X, pos.Y);
|
||||
}
|
||||
}
|
||||
|
||||
@ -126,10 +150,11 @@ int32 UGraphicsSettingsHelper::GetPrimaryMonitorId()
|
||||
|
||||
TArray<FString> UGraphicsSettingsHelper::GetAvailableMonitorsNames()
|
||||
{
|
||||
TArray<FString> names;
|
||||
auto monitors = GetAvailableMonitors();
|
||||
for(auto& m : monitors)
|
||||
names.Add(m.ID);
|
||||
TArray<FString> names;
|
||||
names.Reserve(monitors.Num());
|
||||
for(int32 i = 0; i < monitors.Num(); ++i)
|
||||
names.Add(FString::Printf(TEXT("%d - %s"), i + 1, *monitors[i].Name));
|
||||
|
||||
return MoveTemp(names);
|
||||
}
|
||||
@ -195,11 +220,16 @@ TArray<FResolutionAndRefreshRates> UGraphicsSettingsHelper::GetAllAvailableResol
|
||||
if(!RHIGetAvailableResolutions(buffer, false) || buffer.Num() == 0)
|
||||
return { {GetResolution(nullptr), {GetDefaultFrameRateLimit(nullptr)}} };
|
||||
|
||||
TArray<FResolutionAndRefreshRates> result = {};
|
||||
TArray<FResolutionAndRefreshRates> result;
|
||||
int32 lastWidth = 0;
|
||||
int32 lastHeight = 0;
|
||||
FIntPoint currentResolution = GetResolution(nullptr);
|
||||
bool currentInfoPresent = false;
|
||||
for(auto& i : buffer)
|
||||
{
|
||||
if(currentResolution.X == i.Width && currentResolution.Y == i.Height)
|
||||
currentInfoPresent = true;
|
||||
|
||||
if(lastWidth != i.Width || lastHeight != i.Height)
|
||||
{
|
||||
result.Add({ {static_cast<int32>(i.Width), static_cast<int32>(i.Height)}, {static_cast<int32>(i.RefreshRate)} });
|
||||
@ -212,6 +242,10 @@ TArray<FResolutionAndRefreshRates> UGraphicsSettingsHelper::GetAllAvailableResol
|
||||
}
|
||||
}
|
||||
|
||||
if(!currentInfoPresent)
|
||||
if(auto settings = UCustomGameSettings::Get())
|
||||
result.Add({ currentResolution, { static_cast<int32>(settings->GetFrameRateLimit()) } });
|
||||
|
||||
return MoveTemp(result);
|
||||
}
|
||||
|
||||
@ -222,6 +256,7 @@ TArray<FIntPoint> UGraphicsSettingsHelper::GetAllAvailableResolutions()
|
||||
return { {GetResolution(nullptr), {GetDefaultFrameRateLimit(nullptr)}} };
|
||||
|
||||
TArray<FIntPoint> result;
|
||||
result.Reserve(buffer.Num() + 1);
|
||||
int32 lastWidth = 0;
|
||||
int32 lastHeight = 0;
|
||||
for(auto& i : buffer)
|
||||
@ -233,20 +268,32 @@ TArray<FIntPoint> UGraphicsSettingsHelper::GetAllAvailableResolutions()
|
||||
lastWidth = i.Width;
|
||||
}
|
||||
}
|
||||
|
||||
FIntPoint currentResolution = GetResolution(nullptr);
|
||||
if(!result.Contains(currentResolution))
|
||||
result.Add(currentResolution);
|
||||
|
||||
return MoveTemp(result);
|
||||
}
|
||||
|
||||
TArray<FIntPoint> UGraphicsSettingsHelper::GetAvailableResolutionsByMonitorId(const int32 id)
|
||||
{
|
||||
TArray<FIntPoint> result;
|
||||
|
||||
auto resolutions = GetAllAvailableResolutions();
|
||||
FIntPoint nativeRes = GetNativeResolutionByMonitorId(id);
|
||||
for(auto& i : GetAllAvailableResolutions())
|
||||
TArray<FIntPoint> result;
|
||||
result.Reserve(resolutions.Num() + 1);
|
||||
for(auto& i : resolutions)
|
||||
{
|
||||
if(i.X > nativeRes.X && i.Y > nativeRes.Y)
|
||||
continue;
|
||||
result.Add(i);
|
||||
}
|
||||
if(id == GetMonitorId(nullptr))
|
||||
{
|
||||
FIntPoint currentResolution = GetResolution(nullptr);
|
||||
if(!result.Contains(currentResolution))
|
||||
result.Add(currentResolution);
|
||||
}
|
||||
|
||||
return MoveTemp(result);
|
||||
}
|
||||
@ -267,8 +314,6 @@ void UGraphicsSettingsHelper::SetResolution(UCustomGameSettings* settings, const
|
||||
if(!settings)
|
||||
return;
|
||||
|
||||
settings->bUseDynamicResolution = true;
|
||||
|
||||
if(ipPreviousResolution.has_value() && ipPreviousResolution == resolution)
|
||||
ipPreviousResolution.reset();
|
||||
else
|
||||
@ -285,27 +330,11 @@ void UGraphicsSettingsHelper::RestoreResolution(UCustomGameSettings* settings)
|
||||
SetResolution(settings, ipPreviousResolution.value());
|
||||
}
|
||||
|
||||
float UGraphicsSettingsHelper::GetDefaultResolutionScale([[maybe_unused]] UCustomGameSettings* settings)
|
||||
float UGraphicsSettingsHelper::GetDefaultResolutionScaleFast(UCustomGameSettings* settings)
|
||||
{
|
||||
return fDefaultResolutionScale;
|
||||
}
|
||||
|
||||
float UGraphicsSettingsHelper::GetResolutionScale([[maybe_unused]] UCustomGameSettings* settings)
|
||||
{
|
||||
if(auto settings = UCustomGameSettings::Get())
|
||||
return settings->GetResolutionScaleNormalized();
|
||||
|
||||
return 1.0f;
|
||||
}
|
||||
|
||||
void UGraphicsSettingsHelper::SetResolutionScale(UCustomGameSettings* settings, const float resolutionScale)
|
||||
{
|
||||
if(!settings)
|
||||
return;
|
||||
|
||||
settings->SetResolutionScaleNormalized(resolutionScale);
|
||||
}
|
||||
|
||||
int32 UGraphicsSettingsHelper::GetDefaultFrameRateLimit([[maybe_unused]] UCustomGameSettings* settings)
|
||||
{
|
||||
return iDefaultFrameRateLimit;
|
||||
@ -315,8 +344,24 @@ TArray<int32> UGraphicsSettingsHelper::GetAvailableFrameRateLimitsForResolution(
|
||||
{
|
||||
auto resAndRates = GetAllAvailableResolutionsAndRefreshRates();
|
||||
for(auto& i : resAndRates)
|
||||
{
|
||||
if(i.resolution == resolution)
|
||||
{
|
||||
if(resolution == GetResolution(nullptr))
|
||||
if(auto settings = UCustomGameSettings::Get())
|
||||
if(!i.refreshRates.Contains(settings->GetFrameRateLimit()))
|
||||
i.refreshRates.Add(settings->GetFrameRateLimit());
|
||||
|
||||
if(!i.refreshRates.Contains(GetDefaultFrameRateLimit(nullptr)))
|
||||
i.refreshRates.Add(GetDefaultFrameRateLimit(nullptr));
|
||||
|
||||
if(!i.refreshRates.Contains(0))
|
||||
i.refreshRates.Add(0);
|
||||
|
||||
i.refreshRates.Sort();
|
||||
return MoveTemp(i.refreshRates);
|
||||
}
|
||||
}
|
||||
|
||||
return { GetDefaultFrameRateLimit(nullptr) };
|
||||
}
|
||||
@ -350,8 +395,15 @@ TArray<FIntPoint> UGraphicsSettingsHelper::GetAvailableAspectRatiousOfMonitor(co
|
||||
|
||||
TSet<FIntPoint> aspects;
|
||||
for(auto& i : resolutions)
|
||||
{
|
||||
aspects.Add(GetAspectRatioFromResolution(i));
|
||||
return aspects.Array();
|
||||
UE_LOG(LogTemp, Log, TEXT("%dx%d = %dx%d"), i.X, i.Y, GetAspectRatioFromResolution(i).X, GetAspectRatioFromResolution(i).Y);
|
||||
}
|
||||
aspects.Add(GetAspectRatioFromResolution(GetResolution(nullptr)));
|
||||
|
||||
TArray<FIntPoint> result = aspects.Array();
|
||||
UCommonFunctions::SortIntPointArray(result);
|
||||
return MoveTemp(result);
|
||||
}
|
||||
|
||||
EDisplayMode UGraphicsSettingsHelper::GetDefaultDisplayMode([[maybe_unused]] UCustomGameSettings* settings)
|
||||
@ -406,6 +458,33 @@ void UGraphicsSettingsHelper::RestoreDisplayMode(UCustomGameSettings* settings)
|
||||
SetDisplayMode(settings, ePreviousDisplayMode.value());
|
||||
}
|
||||
|
||||
bool UGraphicsSettingsHelper::GetDefaultVSyncEnabled(UCustomGameSettings* settings)
|
||||
{
|
||||
return bDefaultVSyncEnabled;
|
||||
}
|
||||
|
||||
int32 UGraphicsSettingsHelper::GetDefaultAntiAliasingMethod(UCustomGameSettings* settings)
|
||||
{
|
||||
return eDefaultAntiAliasingMethod;
|
||||
}
|
||||
|
||||
int32 UGraphicsSettingsHelper::GetAntiAliasingMethod(UCustomGameSettings* settings)
|
||||
{
|
||||
static const auto cvar = IConsoleManager::Get().FindConsoleVariable(TEXT("r.AntiAliasingMethod"));
|
||||
if(cvar)
|
||||
return cvar->GetInt();
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
void UGraphicsSettingsHelper::SetAntiAliasingMethod(UCustomGameSettings* settings, int32 method)
|
||||
{
|
||||
if(!settings)
|
||||
return;
|
||||
|
||||
settings->eAntiAliasingMethod = FMath::Clamp(method, static_cast<int32>(ELostEdgeAntiAliasingMethod::None), static_cast<int32>(ELostEdgeAntiAliasingMethod::MSAA));
|
||||
}
|
||||
|
||||
inline constexpr EDisplayMode UGraphicsSettingsHelper::WindowToDisplayMode(const EWindowMode::Type mode)
|
||||
{
|
||||
switch(mode)
|
||||
@ -433,6 +512,3 @@ inline constexpr EWindowMode::Type UGraphicsSettingsHelper::DisplayToWindowMode(
|
||||
return EWindowMode::Type::Fullscreen;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
@ -27,6 +27,15 @@ enum class EDisplayMode : uint8
|
||||
Windowed = 2 UMETA(DisplayName = "Windowed")
|
||||
};
|
||||
|
||||
UENUM(BlueprintType)
|
||||
enum class ELostEdgeAntiAliasingMethod : uint8
|
||||
{
|
||||
None = AAM_None UMETA(DisplayName = "None"),
|
||||
FXAA = AAM_FXAA UMETA(DisplayName = "FXAA"),
|
||||
TAA = AAM_TemporalAA UMETA(DisplayName = "TAA"),
|
||||
MSAA = AAM_MSAA UMETA(DisplayName = "MSAA")
|
||||
};
|
||||
|
||||
/**
|
||||
* Helper for trivial and complex graphic settings.
|
||||
* Most of functions work without settings pointer. It is there just for Blueprint call convinience.
|
||||
@ -39,10 +48,14 @@ class UGraphicsSettingsHelper : public UBlueprintFunctionLibrary
|
||||
GENERATED_BODY()
|
||||
|
||||
public:
|
||||
UFUNCTION(BlueprintPure, Category = "Settings|Graphics", meta = (DisplayName = "AreGraphicsSettingsRestorable"))
|
||||
UFUNCTION(BlueprintPure, Category = "Settings|Graphics", meta = (DisplayName = "Are Graphics Settings Restorable"))
|
||||
static bool AreSettingsRestorable(class UCustomGameSettings* settings);
|
||||
UFUNCTION(BlueprintCallable, Category = "Settings|Graphics", meta = (DisplayName = "SetGraphicsDefaults"))
|
||||
UFUNCTION(BlueprintCallable, Category = "Settings|Graphics")
|
||||
static void RestoreGraphicsSettings(class UCustomGameSettings* settings);
|
||||
UFUNCTION(BlueprintCallable, Category = "Settings|Graphics", meta = (DisplayName = "Set Graphics Defaults"))
|
||||
static void SetDefaults(class UCustomGameSettings* settings);
|
||||
UFUNCTION(BlueprintCallable, Category = "Settings|Graphics", meta = (DisplayName = "Apply Graphics Settings"))
|
||||
static void ApplySettings(class UCustomGameSettings* settings);
|
||||
|
||||
protected: // Window position setting is on the thin edge of user safeness, therefore protected. Please use SetMonitor().
|
||||
UFUNCTION(BlueprintPure, Category = "Settings|Graphics|Window")
|
||||
@ -89,11 +102,7 @@ public:
|
||||
static void RestoreResolution(class UCustomGameSettings* settings);
|
||||
|
||||
UFUNCTION(BlueprintPure, Category = "Settings|Graphics|Resolution Scale")
|
||||
static float GetDefaultResolutionScale(class UCustomGameSettings* settings);
|
||||
UFUNCTION(BlueprintPure, Category = "Settings|Graphics|Resolution Scale")
|
||||
static float GetResolutionScale(class UCustomGameSettings* settings);
|
||||
UFUNCTION(BlueprintCallable, Category = "Settings|Graphics|Resolution Scale")
|
||||
static void SetResolutionScale(class UCustomGameSettings* settings, const float resolutionScale);
|
||||
static float GetDefaultResolutionScaleFast(class UCustomGameSettings* settings);
|
||||
|
||||
UFUNCTION(BlueprintPure, Category = "Settings|Graphics|Frame Rate Limit")
|
||||
static int32 GetDefaultFrameRateLimit(class UCustomGameSettings* settings);
|
||||
@ -124,6 +133,16 @@ public:
|
||||
UFUNCTION(BlueprintCallable, Category = "Settings|Graphics|Display Mode")
|
||||
static void RestoreDisplayMode(class UCustomGameSettings* settings);
|
||||
|
||||
UFUNCTION(BlueprintPure, Category = "Settings|Graphics|VSync")
|
||||
static bool GetDefaultVSyncEnabled(class UCustomGameSettings* settings);
|
||||
|
||||
UFUNCTION(BlueprintPure, Category = "Settings|Graphics|Anti Aliasing")
|
||||
static int32 GetDefaultAntiAliasingMethod(class UCustomGameSettings* settings);
|
||||
UFUNCTION(BlueprintPure, Category = "Settings|Graphics|Anti Aliasing")
|
||||
static int32 GetAntiAliasingMethod(class UCustomGameSettings* settings);
|
||||
UFUNCTION(BlueprintCallable, Category = "Settings|Graphics|Anti Aliasing")
|
||||
static void SetAntiAliasingMethod(class UCustomGameSettings* settings, int32 method);
|
||||
|
||||
private:
|
||||
inline constexpr static EDisplayMode WindowToDisplayMode(const EWindowMode::Type mode);
|
||||
inline constexpr static EWindowMode::Type DisplayToWindowMode(const EDisplayMode mode);
|
||||
|
@ -6,15 +6,57 @@ void UComboBoxText::PostInitProperties()
|
||||
{
|
||||
Super::PostInitProperties();
|
||||
|
||||
SetOptions(_DefaultOptions);
|
||||
SetOptionsAsText(_DefaultOptions);
|
||||
_DefaultOptions.Empty();
|
||||
OnSelectionChanged.AddDynamic(this, &UComboBoxText::UpdateButtonPadding);
|
||||
auto& style = GetWidgetStyle();
|
||||
buttonNormalLeftPadding = style.ComboButtonStyle.ButtonStyle.NormalPadding.Left;
|
||||
buttonPressedLeftPadding = style.ComboButtonStyle.ButtonStyle.PressedPadding.Left;
|
||||
}
|
||||
|
||||
void UComboBoxText::SetOptions(const TArray<FText>& options)
|
||||
void UComboBoxText::SetOptionsAsText(const TArray<FText>& options)
|
||||
{
|
||||
ClearSelection();
|
||||
Options.Empty();
|
||||
Options.Empty(options.Num());
|
||||
for(auto& o : options)
|
||||
Options.Add(MakeShareable(new FString(o.ToString())));
|
||||
RefreshOptions();
|
||||
PostOptionsSet();
|
||||
}
|
||||
|
||||
void UComboBoxText::SetOptionsAsString(const TArray<FString>& options)
|
||||
{
|
||||
ClearSelection();
|
||||
Options.Empty(options.Num());
|
||||
for(auto& o : options)
|
||||
Options.Add(MakeShareable(new FString(o)));
|
||||
RefreshOptions();
|
||||
PostOptionsSet();
|
||||
}
|
||||
|
||||
TArray<FString> UComboBoxText::GetOptions()
|
||||
{
|
||||
TArray<FString> result;
|
||||
result.Reserve(Options.Num());
|
||||
for(auto& o : Options)
|
||||
result.Add(*o);
|
||||
return MoveTemp(result);
|
||||
}
|
||||
|
||||
void UComboBoxText::PostOptionsSet()
|
||||
{
|
||||
longestCharCount = 0;
|
||||
for(auto& o : Options)
|
||||
if(o->Len() > longestCharCount)
|
||||
longestCharCount = o->Len();
|
||||
}
|
||||
|
||||
void UComboBoxText::UpdateButtonPadding(FString SelectedItem, ESelectInfo::Type SelectionType)
|
||||
{
|
||||
const int32 len = longestCharCount - SelectedItem.Len();
|
||||
auto style = GetWidgetStyle();
|
||||
float padding = GetFont().Size * (static_cast<float>(len));
|
||||
style.ComboButtonStyle.ButtonStyle.NormalPadding.Left = padding + buttonNormalLeftPadding;
|
||||
style.ComboButtonStyle.ButtonStyle.PressedPadding.Left = padding + buttonPressedLeftPadding;
|
||||
SetWidgetStyle(style);
|
||||
}
|
||||
|
@ -15,9 +15,22 @@ public:
|
||||
virtual void PostInitProperties() override;
|
||||
|
||||
UFUNCTION(BlueprintCallable)
|
||||
void SetOptions(const TArray<FText>& options);
|
||||
void SetOptionsAsText(const TArray<FText>& options);
|
||||
|
||||
UFUNCTION(BlueprintCallable)
|
||||
void SetOptionsAsString(const TArray<FString>& options);
|
||||
|
||||
UFUNCTION(BlueprintPure)
|
||||
TArray<FString> GetOptions();
|
||||
|
||||
protected:
|
||||
void PostOptionsSet();
|
||||
UFUNCTION()
|
||||
void UpdateButtonPadding(FString SelectedItem, ESelectInfo::Type SelectionType);
|
||||
|
||||
UPROPERTY(EditAnywhere, Category = ComboBoxTextDefault)
|
||||
TArray<FText> _DefaultOptions;
|
||||
|
||||
int32 longestCharCount;
|
||||
float buttonNormalLeftPadding, buttonPressedLeftPadding;
|
||||
};
|
||||
|
@ -3,6 +3,7 @@
|
||||
#include "ResolutionResponsiveWidget.h"
|
||||
|
||||
#include "Components/PanelSlot.h"
|
||||
#include "GraphicsSettingsHelper.h"
|
||||
#include "UnrealClient.h"
|
||||
|
||||
bool UResolutionResponsiveWidget::Initialize()
|
||||
|
@ -10,6 +10,7 @@
|
||||
#include "UObject/ScriptInterface.h"
|
||||
|
||||
#include "CustomGameInstance.h"
|
||||
#include "CustomGameSettings.h"
|
||||
#include "Interactable/Interactable.h"
|
||||
#include "Interactable/Modificators/InteractableModificator.h"
|
||||
#include "Interactable/Modificators/InventoryInteractableModificator.h"
|
||||
@ -98,6 +99,12 @@ void UWidgetsManager::Init()
|
||||
journalWidget->SetVisibility(ESlateVisibility::Hidden);
|
||||
journalWidget->AddToViewport();
|
||||
}
|
||||
|
||||
if(auto settings = UCustomGameSettings::Get())
|
||||
{
|
||||
if(settings->bShowFps)
|
||||
ShowFpsCount();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -156,6 +163,27 @@ void UWidgetsManager::HideMainMenu()
|
||||
|
||||
|
||||
|
||||
void UWidgetsManager::ShowFpsCount()
|
||||
{
|
||||
if(fpsCountWidget)
|
||||
return;
|
||||
|
||||
if(auto PC = UGameplayStatics::GetPlayerController(GetWorld(), 0))
|
||||
fpsCountWidget = CreateWidget<UUserWidget>(PC, fpsCountWidgetClass);
|
||||
fpsCountWidget->AddToViewport();
|
||||
}
|
||||
|
||||
void UWidgetsManager::HideFpsCount()
|
||||
{
|
||||
if(!fpsCountWidget)
|
||||
return;
|
||||
|
||||
fpsCountWidget->RemoveFromViewport();
|
||||
fpsCountWidget = nullptr;
|
||||
}
|
||||
|
||||
|
||||
|
||||
void UWidgetsManager::ShowInteractionHints(const UInteractableModificator* modificator)
|
||||
{
|
||||
if(interactableHintWidgetManager)
|
||||
|
@ -30,6 +30,9 @@ public:
|
||||
void ShowMainMenu(bool pause = true);
|
||||
void HideMainMenu();
|
||||
|
||||
void ShowFpsCount();
|
||||
void HideFpsCount();
|
||||
|
||||
UFUNCTION(BlueprintCallable, Category = WidgetsManager)
|
||||
void ShowInteractionHints(const class UInteractableModificator* modificator = nullptr);
|
||||
UFUNCTION(BlueprintCallable, Category = WidgetsManager)
|
||||
@ -70,6 +73,10 @@ protected:
|
||||
TSubclassOf<class UMainMenuWidget> mainMenuWidgetClass;
|
||||
class UMainMenuWidget* mainMenuWidget = nullptr;
|
||||
|
||||
UPROPERTY(EditDefaultsOnly)
|
||||
TSubclassOf<class UUserWidget> fpsCountWidgetClass;
|
||||
class UUserWidget* fpsCountWidget = nullptr;
|
||||
|
||||
UPROPERTY(EditDefaultsOnly)
|
||||
TSubclassOf<class UInteractableHintWidgetManager> interactableHintWidgetManagerClass; // hidden in cutscene
|
||||
class UInteractableHintWidgetManager* interactableHintWidgetManager = nullptr;
|
||||
|
Loading…
Reference in New Issue
Block a user