2019-09-22 01:10:04 +08:00
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
// See the LICENCE file in the repository root for full licence text.
2022-06-17 15:37:17 +08:00
#nullable disable
2020-03-13 14:44:13 +08:00
using System.Drawing ;
2019-09-22 03:15:02 +08:00
using osu.Framework.Allocation ;
2020-03-13 14:44:13 +08:00
using osu.Framework.Bindables ;
using osu.Framework.Configuration ;
2019-09-23 03:22:50 +08:00
using osu.Framework.Graphics ;
using osu.Framework.Graphics.Containers ;
2022-07-12 12:03:43 +08:00
using osu.Framework.Graphics.Shapes ;
using osu.Game.Graphics ;
2019-09-24 18:00:26 +08:00
using osu.Game.Graphics.UserInterfaceV2 ;
2019-09-23 03:45:23 +08:00
using osu.Game.Online.API ;
using osu.Game.Overlays ;
2019-11-11 16:03:50 +08:00
using osu.Game.Rulesets ;
2019-09-22 03:15:02 +08:00
using osu.Game.Tournament.IPC ;
2020-05-16 09:03:10 +08:00
using osu.Game.Tournament.Models ;
2019-09-23 03:22:50 +08:00
using osuTK ;
2019-09-22 03:15:02 +08:00
2021-01-11 13:44:07 +08:00
namespace osu.Game.Tournament.Screens.Setup
2019-09-22 01:10:04 +08:00
{
2022-07-11 19:42:04 +08:00
public class SetupScreen : TournamentScreen
2019-09-22 01:10:04 +08:00
{
2019-09-23 03:45:23 +08:00
private FillFlowContainer fillFlow ;
private LoginOverlay loginOverlay ;
2020-05-25 04:24:46 +08:00
private ResolutionSelector resolution ;
2019-09-23 03:45:23 +08:00
2019-09-22 03:15:02 +08:00
[Resolved]
private MatchIPCInfo ipc { get ; set ; }
2020-06-13 21:05:52 +08:00
[Resolved]
private StableInfo stableInfo { get ; set ; }
2019-09-23 03:45:23 +08:00
[Resolved]
private IAPIProvider api { get ; set ; }
2019-11-11 16:03:50 +08:00
[Resolved]
private RulesetStore rulesets { get ; set ; }
2020-05-16 09:03:10 +08:00
[Resolved(canBeNull: true)]
private TournamentSceneManager sceneManager { get ; set ; }
2020-03-13 14:44:13 +08:00
private Bindable < Size > windowSize ;
2019-09-22 03:15:02 +08:00
[BackgroundDependencyLoader]
2021-01-11 00:34:20 +08:00
private void load ( FrameworkConfigManager frameworkConfig )
2019-09-22 03:15:02 +08:00
{
2020-03-13 14:44:13 +08:00
windowSize = frameworkConfig . GetBindable < Size > ( FrameworkSetting . WindowedSize ) ;
2022-07-12 12:03:43 +08:00
InternalChildren = new Drawable [ ]
2019-09-23 03:45:23 +08:00
{
2022-07-12 12:03:43 +08:00
new Box
{
RelativeSizeAxes = Axes . Both ,
Colour = OsuColour . Gray ( 0.2f ) ,
} ,
fillFlow = new FillFlowContainer
{
RelativeSizeAxes = Axes . X ,
AutoSizeAxes = Axes . Y ,
Direction = FillDirection . Vertical ,
Padding = new MarginPadding ( 10 ) ,
Spacing = new Vector2 ( 10 ) ,
}
2019-09-23 03:45:23 +08:00
} ;
api . LocalUser . BindValueChanged ( _ = > Schedule ( reload ) ) ;
2020-06-13 21:05:52 +08:00
stableInfo . OnStableInfoSaved + = ( ) = > Schedule ( reload ) ;
2019-09-23 03:22:50 +08:00
reload ( ) ;
}
private void reload ( )
{
var fileBasedIpc = ipc as FileBasedIPC ;
2019-09-23 03:45:23 +08:00
fillFlow . Children = new Drawable [ ]
2019-09-23 03:22:50 +08:00
{
new ActionableInfo
{
Label = "Current IPC source" ,
2020-05-18 06:50:08 +08:00
ButtonText = "Change source" ,
2020-06-13 21:05:52 +08:00
Action = ( ) = > sceneManager ? . SetScreen ( new StablePathSelectScreen ( ) ) ,
2020-05-31 23:35:53 +08:00
Value = fileBasedIpc ? . IPCStorage ? . GetFullPath ( string . Empty ) ? ? "Not found" ,
2020-05-16 09:03:10 +08:00
Failing = fileBasedIpc ? . IPCStorage = = null ,
2022-07-12 12:03:43 +08:00
Description =
"The osu!stable installation which is currently being used as a data source. If a source is not found, make sure you have created an empty ipc.txt in your stable cutting-edge installation."
2020-05-16 09:03:10 +08:00
} ,
new ActionableInfo
2019-09-23 03:45:23 +08:00
{
2020-11-05 22:40:20 +08:00
Label = "Current user" ,
ButtonText = "Change sign-in" ,
2019-09-23 03:45:23 +08:00
Action = ( ) = >
{
api . Logout ( ) ;
if ( loginOverlay = = null )
{
2019-09-23 03:49:21 +08:00
AddInternal ( loginOverlay = new LoginOverlay
2019-09-23 03:45:23 +08:00
{
Anchor = Anchor . TopRight ,
Origin = Anchor . TopRight ,
} ) ;
}
loginOverlay . State . Value = Visibility . Visible ;
} ,
Value = api ? . LocalUser . Value . Username ,
Failing = api ? . IsLoggedIn ! = true ,
2020-11-05 22:40:20 +08:00
Description = "In order to access the API and display metadata, signing in is required."
2019-11-11 16:03:50 +08:00
} ,
new LabelledDropdown < RulesetInfo >
{
Label = "Ruleset" ,
2020-11-05 22:40:20 +08:00
Description = "Decides what stats are displayed and which ranks are retrieved for players." ,
2019-11-11 16:03:50 +08:00
Items = rulesets . AvailableRulesets ,
Current = LadderInfo . Ruleset ,
} ,
2020-12-26 22:44:59 +08:00
new TournamentSwitcher
2020-12-07 20:11:13 +08:00
{
Label = "Current tournament" ,
2020-12-07 20:14:59 +08:00
Description = "Changes the background videos and bracket to match the selected tournament. This requires a restart to apply changes." ,
2020-12-07 20:11:13 +08:00
} ,
2020-05-25 04:24:46 +08:00
resolution = new ResolutionSelector
2020-03-13 14:44:13 +08:00
{
Label = "Stream area resolution" ,
2020-05-25 04:24:46 +08:00
ButtonText = "Set height" ,
2020-05-26 02:11:00 +08:00
Action = height = >
2020-03-13 14:44:13 +08:00
{
2020-05-26 02:11:00 +08:00
windowSize . Value = new Size ( ( int ) ( height * aspect_ratio / TournamentSceneManager . STREAM_AREA_WIDTH * TournamentSceneManager . REQUIRED_WIDTH ) , height ) ;
2020-03-13 14:44:13 +08:00
}
2020-03-23 10:47:24 +08:00
} ,
2022-08-31 12:44:06 +08:00
new LabelledSwitchButton
{
Label = "Auto advance screens" ,
Description = "Screens will progress automatically from gameplay -> results -> map pool" ,
Current = LadderInfo . AutoProgressScreens ,
} ,
2019-09-23 03:22:50 +08:00
} ;
}
2020-05-23 01:25:05 +08:00
private const float aspect_ratio = 16f / 9f ;
2020-03-13 14:44:13 +08:00
protected override void Update ( )
{
base . Update ( ) ;
resolution . Value = $"{ScreenSpaceDrawQuad.Width:N0}x{ScreenSpaceDrawQuad.Height:N0}" ;
}
2019-09-22 01:10:04 +08:00
}
}