2019-01-24 08:43:03 +00: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.
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2022-06-17 07:37:17 +00:00
|
|
|
#nullable disable
|
|
|
|
|
2021-11-10 13:03:29 +00:00
|
|
|
using System;
|
2022-02-24 20:11:49 +00:00
|
|
|
using System.Diagnostics;
|
2024-01-04 05:30:46 +00:00
|
|
|
using System.Linq;
|
2023-07-30 17:05:08 +00:00
|
|
|
using JetBrains.Annotations;
|
2016-11-14 08:23:33 +00:00
|
|
|
using osu.Framework.Allocation;
|
2023-11-08 13:13:35 +00:00
|
|
|
using osu.Framework.Audio;
|
|
|
|
using osu.Framework.Audio.Sample;
|
2019-02-21 10:04:31 +00:00
|
|
|
using osu.Framework.Bindables;
|
2016-09-17 20:33:46 +00:00
|
|
|
using osu.Framework.Graphics;
|
2023-07-14 10:19:14 +00:00
|
|
|
using osu.Framework.Graphics.Containers;
|
2022-02-23 13:06:22 +00:00
|
|
|
using osu.Framework.Input.Bindings;
|
|
|
|
using osu.Framework.Input.Events;
|
2022-06-27 09:41:27 +00:00
|
|
|
using osu.Framework.Logging;
|
2019-03-02 04:11:34 +00:00
|
|
|
using osu.Framework.Platform;
|
2017-03-28 12:26:20 +00:00
|
|
|
using osu.Framework.Screens;
|
2021-03-03 05:06:39 +00:00
|
|
|
using osu.Game.Beatmaps;
|
2019-09-19 07:26:22 +00:00
|
|
|
using osu.Game.Configuration;
|
2018-09-20 18:13:15 +00:00
|
|
|
using osu.Game.Graphics;
|
2016-09-30 04:30:55 +00:00
|
|
|
using osu.Game.Graphics.Containers;
|
2022-02-23 13:06:22 +00:00
|
|
|
using osu.Game.Input.Bindings;
|
2020-07-06 13:03:09 +00:00
|
|
|
using osu.Game.IO;
|
2019-09-08 05:36:58 +00:00
|
|
|
using osu.Game.Online.API;
|
2019-05-15 03:08:23 +00:00
|
|
|
using osu.Game.Overlays;
|
2024-01-04 05:30:46 +00:00
|
|
|
using osu.Game.Overlays.Dialog;
|
2023-11-24 01:56:59 +00:00
|
|
|
using osu.Game.Overlays.SkinEditor;
|
2021-03-03 05:06:39 +00:00
|
|
|
using osu.Game.Rulesets;
|
2016-11-14 08:23:33 +00:00
|
|
|
using osu.Game.Screens.Backgrounds;
|
2017-03-14 14:18:40 +00:00
|
|
|
using osu.Game.Screens.Edit;
|
2020-12-25 15:50:00 +00:00
|
|
|
using osu.Game.Screens.OnlinePlay.Multiplayer;
|
|
|
|
using osu.Game.Screens.OnlinePlay.Playlists;
|
2016-11-20 19:34:16 +00:00
|
|
|
using osu.Game.Screens.Select;
|
2021-05-19 07:27:38 +00:00
|
|
|
using osuTK;
|
|
|
|
using osuTK.Graphics;
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2016-11-14 08:23:33 +00:00
|
|
|
namespace osu.Game.Screens.Menu
|
2016-08-26 03:28:23 +00:00
|
|
|
{
|
2022-02-23 13:06:22 +00:00
|
|
|
public partial class MainMenu : OsuScreen, IHandlePresentBeatmap, IKeyBindingHandler<GlobalAction>
|
2016-08-26 03:28:23 +00:00
|
|
|
{
|
2019-07-05 04:08:45 +00:00
|
|
|
public const float FADE_IN_DURATION = 300;
|
|
|
|
|
|
|
|
public const float FADE_OUT_DURATION = 400;
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2022-04-19 06:46:03 +00:00
|
|
|
public override bool HideOverlaysOnEnter => Buttons == null || Buttons.State == ButtonSystemState.Initial;
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2019-06-25 09:38:14 +00:00
|
|
|
public override bool AllowBackButton => false;
|
2018-05-14 19:09:09 +00:00
|
|
|
|
2018-11-29 08:18:59 +00:00
|
|
|
public override bool AllowExternalScreenChange => true;
|
|
|
|
|
2024-01-08 11:54:16 +00:00
|
|
|
public override bool? AllowGlobalTrackControl => true;
|
|
|
|
|
2017-03-17 11:09:33 +00:00
|
|
|
private Screen songSelect;
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2019-02-26 00:54:42 +00:00
|
|
|
private MenuSideFlashes sideFlashes;
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2022-04-19 06:46:03 +00:00
|
|
|
protected ButtonSystem Buttons;
|
2019-07-05 04:08:45 +00:00
|
|
|
|
2019-02-25 01:42:36 +00:00
|
|
|
[Resolved]
|
|
|
|
private GameHost host { get; set; }
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2023-06-21 10:06:47 +00:00
|
|
|
[Resolved]
|
|
|
|
private INotificationOverlay notifications { get; set; }
|
|
|
|
|
2020-08-11 03:40:58 +00:00
|
|
|
[Resolved]
|
2020-08-16 14:04:49 +00:00
|
|
|
private MusicController musicController { get; set; }
|
2019-07-09 09:32:49 +00:00
|
|
|
|
2019-09-08 05:36:58 +00:00
|
|
|
[Resolved]
|
|
|
|
private IAPIProvider api { get; set; }
|
|
|
|
|
2023-06-23 06:19:47 +00:00
|
|
|
[Resolved]
|
|
|
|
private Storage storage { get; set; }
|
|
|
|
|
|
|
|
[Resolved(canBeNull: true)]
|
|
|
|
private LoginOverlay login { get; set; }
|
|
|
|
|
2019-09-19 08:40:46 +00:00
|
|
|
[Resolved(canBeNull: true)]
|
2022-04-18 09:09:14 +00:00
|
|
|
private IDialogOverlay dialogOverlay { get; set; }
|
2019-09-19 07:26:22 +00:00
|
|
|
|
2023-12-27 22:07:17 +00:00
|
|
|
[Resolved(canBeNull: true)]
|
|
|
|
private VersionManager versionManager { get; set; }
|
|
|
|
|
2022-07-07 17:00:02 +00:00
|
|
|
protected override BackgroundScreen CreateBackground() => new BackgroundScreenDefault();
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2022-06-15 04:04:08 +00:00
|
|
|
protected override bool PlayExitSound => false;
|
|
|
|
|
2022-03-04 03:21:05 +00:00
|
|
|
private Bindable<double> holdDelay;
|
2019-09-25 12:56:47 +00:00
|
|
|
private Bindable<bool> loginDisplayed;
|
2019-09-19 07:26:22 +00:00
|
|
|
|
2023-06-23 05:46:38 +00:00
|
|
|
private HoldToExitGameOverlay holdToExitGameOverlay;
|
2019-09-19 11:17:58 +00:00
|
|
|
|
2023-06-21 10:06:47 +00:00
|
|
|
private bool exitConfirmedViaDialog;
|
|
|
|
private bool exitConfirmedViaHoldOrClick;
|
|
|
|
|
2020-01-11 04:08:00 +00:00
|
|
|
private ParallaxContainer buttonsContainer;
|
2020-01-11 04:17:13 +00:00
|
|
|
private SongTicker songTicker;
|
2023-07-14 10:19:14 +00:00
|
|
|
private Container logoTarget;
|
2023-12-29 10:50:30 +00:00
|
|
|
private SystemTitle systemTitle;
|
2023-12-28 07:05:20 +00:00
|
|
|
private MenuTip menuTip;
|
|
|
|
private FillFlowContainer bottomElementsFlow;
|
2023-12-28 08:14:16 +00:00
|
|
|
private SupporterDisplay supporterDisplay;
|
2020-01-11 04:08:00 +00:00
|
|
|
|
2023-11-08 13:13:35 +00:00
|
|
|
private Sample reappearSampleSwoosh;
|
|
|
|
|
2023-11-24 01:56:59 +00:00
|
|
|
[Resolved(canBeNull: true)]
|
|
|
|
private SkinEditorOverlay skinEditor { get; set; }
|
|
|
|
|
2019-02-26 00:54:42 +00:00
|
|
|
[BackgroundDependencyLoader(true)]
|
2023-11-08 13:13:35 +00:00
|
|
|
private void load(BeatmapListingOverlay beatmapListing, SettingsOverlay settings, OsuConfigManager config, SessionStatics statics, AudioManager audio)
|
2016-11-01 14:24:14 +00:00
|
|
|
{
|
2022-03-04 03:21:05 +00:00
|
|
|
holdDelay = config.GetBindable<double>(OsuSetting.UIHoldActivationDelay);
|
2019-09-28 12:21:51 +00:00
|
|
|
loginDisplayed = statics.GetBindable<bool>(Static.LoginOverlayDisplayed);
|
2019-09-19 07:26:22 +00:00
|
|
|
|
2020-01-24 07:34:13 +00:00
|
|
|
if (host.CanExit)
|
|
|
|
{
|
2023-06-23 05:46:38 +00:00
|
|
|
AddInternal(holdToExitGameOverlay = new HoldToExitGameOverlay
|
2020-01-24 07:34:13 +00:00
|
|
|
{
|
|
|
|
Action = () =>
|
|
|
|
{
|
2023-06-21 10:06:47 +00:00
|
|
|
exitConfirmedViaHoldOrClick = holdDelay.Value > 0;
|
|
|
|
this.Exit();
|
2020-01-24 07:34:13 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
AddRangeInternal(new[]
|
2016-09-30 04:31:05 +00:00
|
|
|
{
|
2020-01-11 04:08:00 +00:00
|
|
|
buttonsContainer = new ParallaxContainer
|
2016-09-29 11:13:58 +00:00
|
|
|
{
|
2016-10-01 08:02:20 +00:00
|
|
|
ParallaxAmount = 0.01f,
|
|
|
|
Children = new Drawable[]
|
|
|
|
{
|
2022-04-19 06:46:03 +00:00
|
|
|
Buttons = new ButtonSystem
|
2016-10-01 08:02:20 +00:00
|
|
|
{
|
2023-11-24 01:56:59 +00:00
|
|
|
OnEditBeatmap = () =>
|
2020-08-24 10:38:05 +00:00
|
|
|
{
|
|
|
|
Beatmap.SetDefault();
|
2021-09-05 14:59:28 +00:00
|
|
|
this.Push(new EditorLoader());
|
2020-08-24 10:38:05 +00:00
|
|
|
},
|
2023-11-24 01:56:59 +00:00
|
|
|
OnEditSkin = () =>
|
|
|
|
{
|
|
|
|
skinEditor?.Show();
|
|
|
|
},
|
2021-03-03 05:06:39 +00:00
|
|
|
OnSolo = loadSoloSongSelect,
|
2020-12-25 04:38:11 +00:00
|
|
|
OnMultiplayer = () => this.Push(new Multiplayer()),
|
2020-12-25 14:45:44 +00:00
|
|
|
OnPlaylists = () => this.Push(new Playlists()),
|
2023-06-21 10:06:47 +00:00
|
|
|
OnExit = () =>
|
|
|
|
{
|
|
|
|
exitConfirmedViaHoldOrClick = true;
|
|
|
|
this.Exit();
|
|
|
|
}
|
2017-07-19 07:07:11 +00:00
|
|
|
}
|
2016-10-01 08:02:20 +00:00
|
|
|
}
|
2017-07-19 07:07:11 +00:00
|
|
|
},
|
2023-07-14 10:19:14 +00:00
|
|
|
logoTarget = new Container { RelativeSizeAxes = Axes.Both, },
|
2017-07-19 07:13:01 +00:00
|
|
|
sideFlashes = new MenuSideFlashes(),
|
2020-01-24 07:23:41 +00:00
|
|
|
songTicker = new SongTicker
|
|
|
|
{
|
|
|
|
Anchor = Anchor.TopRight,
|
|
|
|
Origin = Anchor.TopRight,
|
|
|
|
Margin = new MarginPadding { Right = 15, Top = 5 }
|
2020-01-24 07:34:13 +00:00
|
|
|
},
|
2023-07-13 11:31:00 +00:00
|
|
|
new KiaiMenuFountains(),
|
2023-12-28 07:05:20 +00:00
|
|
|
bottomElementsFlow = new FillFlowContainer
|
|
|
|
{
|
|
|
|
AutoSizeAxes = Axes.Both,
|
|
|
|
Direction = FillDirection.Vertical,
|
|
|
|
Anchor = Anchor.BottomCentre,
|
|
|
|
Origin = Anchor.BottomCentre,
|
2023-12-28 07:16:27 +00:00
|
|
|
Spacing = new Vector2(5),
|
2023-12-28 07:05:20 +00:00
|
|
|
Children = new Drawable[]
|
|
|
|
{
|
|
|
|
menuTip = new MenuTip
|
|
|
|
{
|
|
|
|
Anchor = Anchor.TopCentre,
|
|
|
|
Origin = Anchor.TopCentre,
|
|
|
|
},
|
2023-12-29 10:50:30 +00:00
|
|
|
systemTitle = new SystemTitle
|
2023-12-28 07:05:20 +00:00
|
|
|
{
|
|
|
|
Anchor = Anchor.TopCentre,
|
|
|
|
Origin = Anchor.TopCentre,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
2023-12-28 08:14:16 +00:00
|
|
|
supporterDisplay = new SupporterDisplay
|
|
|
|
{
|
|
|
|
Margin = new MarginPadding(5),
|
|
|
|
Anchor = Anchor.BottomLeft,
|
|
|
|
Origin = Anchor.BottomLeft,
|
|
|
|
},
|
2023-06-23 05:46:38 +00:00
|
|
|
holdToExitGameOverlay?.CreateProxy() ?? Empty()
|
2019-02-26 00:54:42 +00:00
|
|
|
});
|
2018-09-20 18:13:15 +00:00
|
|
|
|
2022-04-19 06:46:03 +00:00
|
|
|
Buttons.StateChanged += state =>
|
2018-09-20 18:13:15 +00:00
|
|
|
{
|
|
|
|
switch (state)
|
|
|
|
{
|
|
|
|
case ButtonSystemState.Initial:
|
|
|
|
case ButtonSystemState.Exit:
|
2021-01-04 09:32:23 +00:00
|
|
|
ApplyToBackground(b => b.FadeColour(Color4.White, 500, Easing.OutSine));
|
2023-12-29 10:50:30 +00:00
|
|
|
systemTitle.State.Value = Visibility.Hidden;
|
2018-09-20 18:13:15 +00:00
|
|
|
break;
|
2019-04-01 03:44:46 +00:00
|
|
|
|
2018-09-20 18:13:15 +00:00
|
|
|
default:
|
2021-01-04 09:32:23 +00:00
|
|
|
ApplyToBackground(b => b.FadeColour(OsuColour.Gray(0.8f), 500, Easing.OutSine));
|
2023-12-29 10:50:30 +00:00
|
|
|
systemTitle.State.Value = Visibility.Visible;
|
2018-09-20 18:13:15 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
};
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2022-04-19 06:46:03 +00:00
|
|
|
Buttons.OnSettings = () => settings?.ToggleVisibility();
|
|
|
|
Buttons.OnBeatmapListing = () => beatmapListing?.ToggleVisibility();
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2023-11-08 13:13:35 +00:00
|
|
|
reappearSampleSwoosh = audio.Samples.Get(@"Menu/reappear-swoosh");
|
|
|
|
|
2017-03-17 11:09:33 +00:00
|
|
|
preloadSongSelect();
|
|
|
|
}
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2022-05-19 07:42:43 +00:00
|
|
|
public void ReturnToOsuLogo() => Buttons.State = ButtonSystemState.Initial;
|
|
|
|
|
2017-03-17 11:09:33 +00:00
|
|
|
private void preloadSongSelect()
|
|
|
|
{
|
|
|
|
if (songSelect == null)
|
2017-04-02 06:56:12 +00:00
|
|
|
LoadComponentAsync(songSelect = new PlaySongSelect());
|
2017-03-17 11:09:33 +00:00
|
|
|
}
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2021-03-03 05:06:39 +00:00
|
|
|
private void loadSoloSongSelect() => this.Push(consumeSongSelect());
|
2018-07-10 16:32:10 +00:00
|
|
|
|
2017-03-17 11:09:33 +00:00
|
|
|
private Screen consumeSongSelect()
|
|
|
|
{
|
|
|
|
var s = songSelect;
|
|
|
|
songSelect = null;
|
|
|
|
return s;
|
2016-11-01 14:24:14 +00:00
|
|
|
}
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2022-04-21 15:52:44 +00:00
|
|
|
public override void OnEntering(ScreenTransitionEvent e)
|
2016-11-01 14:24:14 +00:00
|
|
|
{
|
2022-04-21 15:52:44 +00:00
|
|
|
base.OnEntering(e);
|
2022-04-19 06:46:03 +00:00
|
|
|
Buttons.FadeInFromZero(500);
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2022-04-21 15:52:44 +00:00
|
|
|
if (e.Last is IntroScreen && musicController.TrackLoaded)
|
2017-04-25 04:33:34 +00:00
|
|
|
{
|
2021-02-18 06:01:11 +00:00
|
|
|
var track = musicController.CurrentTrack;
|
|
|
|
|
|
|
|
// presume the track is the current beatmap's track. not sure how correct this assumption is but it has worked until now.
|
|
|
|
if (!track.IsRunning)
|
2017-04-23 05:36:23 +00:00
|
|
|
{
|
2022-08-17 04:20:24 +00:00
|
|
|
Beatmap.Value.PrepareTrackForPreview(false);
|
2021-02-18 06:01:11 +00:00
|
|
|
track.Restart();
|
2017-05-23 07:26:51 +00:00
|
|
|
}
|
2017-04-25 04:33:34 +00:00
|
|
|
}
|
2020-07-06 13:03:09 +00:00
|
|
|
|
|
|
|
if (storage is OsuStorage osuStorage && osuStorage.Error != OsuStorageError.None)
|
|
|
|
dialogOverlay?.Push(new StorageErrorDialog(osuStorage, osuStorage.Error));
|
2017-07-19 04:32:16 +00:00
|
|
|
}
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2023-07-30 17:05:08 +00:00
|
|
|
[CanBeNull]
|
|
|
|
private Drawable proxiedLogo;
|
|
|
|
|
2017-11-09 08:38:20 +00:00
|
|
|
protected override void LogoArriving(OsuLogo logo, bool resuming)
|
2017-11-01 11:54:58 +00:00
|
|
|
{
|
2017-11-09 08:38:20 +00:00
|
|
|
base.LogoArriving(logo, resuming);
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2022-04-19 06:46:03 +00:00
|
|
|
Buttons.SetOsuLogo(logo);
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2017-11-01 11:54:58 +00:00
|
|
|
logo.FadeColour(Color4.White, 100, Easing.OutQuint);
|
|
|
|
logo.FadeIn(100, Easing.OutQuint);
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2023-07-30 17:05:08 +00:00
|
|
|
proxiedLogo = logo.ProxyToContainer(logoTarget);
|
2023-07-14 10:19:14 +00:00
|
|
|
|
2017-11-01 11:54:58 +00:00
|
|
|
if (resuming)
|
2017-11-09 16:10:40 +00:00
|
|
|
{
|
2022-04-19 06:46:03 +00:00
|
|
|
Buttons.State = ButtonSystemState.TopLevel;
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2019-07-05 04:08:45 +00:00
|
|
|
this.FadeIn(FADE_IN_DURATION, Easing.OutQuint);
|
2020-01-11 04:08:00 +00:00
|
|
|
buttonsContainer.MoveTo(new Vector2(0, 0), FADE_IN_DURATION, Easing.OutQuint);
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2019-07-05 04:08:45 +00:00
|
|
|
sideFlashes.Delay(FADE_IN_DURATION).FadeIn(64, Easing.InQuint);
|
2017-11-09 16:10:40 +00:00
|
|
|
}
|
2019-09-09 16:12:30 +00:00
|
|
|
else if (!api.IsLoggedIn)
|
|
|
|
{
|
2021-11-10 13:03:29 +00:00
|
|
|
// copy out old action to avoid accidentally capturing logo.Action in closure, causing a self-reference loop.
|
|
|
|
var previousAction = logo.Action;
|
|
|
|
|
|
|
|
// we want to hook into logo.Action to display the login overlay, but also preserve the return value of the old action.
|
|
|
|
// therefore pass the old action to displayLogin, so that it can return that value.
|
|
|
|
// this ensures that the OsuLogo sample does not play when it is not desired.
|
|
|
|
logo.Action = () => displayLogin(previousAction);
|
2019-09-09 16:17:58 +00:00
|
|
|
}
|
|
|
|
|
2021-11-10 13:03:29 +00:00
|
|
|
bool displayLogin(Func<bool> originalAction)
|
2019-09-09 16:17:58 +00:00
|
|
|
{
|
2019-09-25 12:56:47 +00:00
|
|
|
if (!loginDisplayed.Value)
|
2019-09-09 16:12:30 +00:00
|
|
|
{
|
|
|
|
Scheduler.AddDelayed(() => login?.Show(), 500);
|
2019-09-25 12:56:47 +00:00
|
|
|
loginDisplayed.Value = true;
|
2019-09-09 16:17:58 +00:00
|
|
|
}
|
|
|
|
|
2021-11-10 13:03:29 +00:00
|
|
|
return originalAction.Invoke();
|
2019-09-09 16:12:30 +00:00
|
|
|
}
|
2017-11-01 11:54:58 +00:00
|
|
|
}
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2023-12-27 22:07:17 +00:00
|
|
|
protected override void Update()
|
|
|
|
{
|
|
|
|
base.Update();
|
|
|
|
|
2023-12-28 07:05:20 +00:00
|
|
|
bottomElementsFlow.Margin = new MarginPadding
|
2023-12-27 22:07:17 +00:00
|
|
|
{
|
|
|
|
Bottom = (versionManager?.DrawHeight + 5) ?? 0
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2017-11-09 08:38:20 +00:00
|
|
|
protected override void LogoSuspending(OsuLogo logo)
|
2017-11-01 11:54:58 +00:00
|
|
|
{
|
2019-05-15 10:39:36 +00:00
|
|
|
var seq = logo.FadeOut(300, Easing.InSine)
|
|
|
|
.ScaleTo(0.2f, 300, Easing.InSine);
|
|
|
|
|
2023-07-30 17:05:08 +00:00
|
|
|
if (proxiedLogo != null)
|
|
|
|
{
|
|
|
|
logo.ReturnProxy();
|
|
|
|
proxiedLogo = null;
|
|
|
|
}
|
2023-07-14 10:19:14 +00:00
|
|
|
|
2022-04-19 06:46:03 +00:00
|
|
|
seq.OnComplete(_ => Buttons.SetOsuLogo(null));
|
|
|
|
seq.OnAbort(_ => Buttons.SetOsuLogo(null));
|
2017-11-01 11:54:58 +00:00
|
|
|
}
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2023-07-30 17:05:08 +00:00
|
|
|
protected override void LogoExiting(OsuLogo logo)
|
|
|
|
{
|
|
|
|
base.LogoExiting(logo);
|
|
|
|
|
|
|
|
if (proxiedLogo != null)
|
|
|
|
{
|
|
|
|
logo.ReturnProxy();
|
|
|
|
proxiedLogo = null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-04-21 15:52:44 +00:00
|
|
|
public override void OnSuspending(ScreenTransitionEvent e)
|
2016-10-01 08:01:29 +00:00
|
|
|
{
|
2022-04-21 15:52:44 +00:00
|
|
|
base.OnSuspending(e);
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2022-04-19 06:46:03 +00:00
|
|
|
Buttons.State = ButtonSystemState.EnteringMode;
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2019-07-05 04:08:45 +00:00
|
|
|
this.FadeOut(FADE_OUT_DURATION, Easing.InSine);
|
2020-01-11 04:08:00 +00:00
|
|
|
buttonsContainer.MoveTo(new Vector2(-800, 0), FADE_OUT_DURATION, Easing.InSine);
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2017-11-09 16:10:40 +00:00
|
|
|
sideFlashes.FadeOut(64, Easing.OutQuint);
|
2023-12-28 07:05:20 +00:00
|
|
|
|
|
|
|
bottomElementsFlow
|
|
|
|
.ScaleTo(0.9f, 1000, Easing.OutQuint)
|
|
|
|
.FadeOut(500, Easing.OutQuint);
|
2023-12-28 08:14:16 +00:00
|
|
|
|
|
|
|
supporterDisplay
|
|
|
|
.FadeOut(500, Easing.OutQuint);
|
2016-10-01 08:01:29 +00:00
|
|
|
}
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2022-04-21 15:52:44 +00:00
|
|
|
public override void OnResuming(ScreenTransitionEvent e)
|
2016-10-01 08:01:29 +00:00
|
|
|
{
|
2022-04-21 15:52:44 +00:00
|
|
|
base.OnResuming(e);
|
2020-01-11 15:27:22 +00:00
|
|
|
|
2023-11-08 13:18:33 +00:00
|
|
|
// Ensures any playing `ButtonSystem` samples are stopped when returning to MainMenu (as to not overlap with the 'back' sample)
|
|
|
|
Buttons.StopSamplePlayback();
|
2023-11-08 13:13:35 +00:00
|
|
|
reappearSampleSwoosh?.Play();
|
|
|
|
|
2021-01-04 09:32:23 +00:00
|
|
|
ApplyToBackground(b => (b as BackgroundScreenDefault)?.Next());
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2020-05-05 01:31:11 +00:00
|
|
|
// we may have consumed our preloaded instance, so let's make another.
|
2017-03-17 11:09:33 +00:00
|
|
|
preloadSongSelect();
|
2019-07-08 22:08:18 +00:00
|
|
|
|
2020-08-16 14:04:49 +00:00
|
|
|
musicController.EnsurePlayingSomething();
|
2023-12-28 07:05:20 +00:00
|
|
|
|
2023-12-28 07:19:12 +00:00
|
|
|
// Cycle tip on resuming
|
2023-12-28 07:05:20 +00:00
|
|
|
menuTip.ShowNextTip();
|
|
|
|
|
|
|
|
bottomElementsFlow
|
|
|
|
.ScaleTo(1, 1000, Easing.OutQuint)
|
|
|
|
.FadeIn(1000, Easing.OutQuint);
|
2016-10-01 08:01:29 +00:00
|
|
|
}
|
2018-04-13 09:19:50 +00:00
|
|
|
|
2022-04-21 15:52:44 +00:00
|
|
|
public override bool OnExiting(ScreenExitEvent e)
|
2016-12-05 10:34:52 +00:00
|
|
|
{
|
2023-06-21 10:06:47 +00:00
|
|
|
bool requiresConfirmation =
|
|
|
|
// we need to have a dialog overlay to confirm in the first place.
|
|
|
|
dialogOverlay != null
|
|
|
|
// if the dialog has already displayed and been accepted by the user, we are good.
|
|
|
|
&& !exitConfirmedViaDialog
|
|
|
|
// Only require confirmation if there is either an ongoing operation or the user exited via a non-hold escape press.
|
|
|
|
&& (notifications.HasOngoingOperations || !exitConfirmedViaHoldOrClick);
|
|
|
|
|
|
|
|
if (requiresConfirmation)
|
2019-09-19 07:26:22 +00:00
|
|
|
{
|
2019-12-22 13:39:25 +00:00
|
|
|
if (dialogOverlay.CurrentDialog is ConfirmExitDialog exitDialog)
|
2024-01-04 05:30:46 +00:00
|
|
|
{
|
|
|
|
if (exitDialog.Buttons.OfType<PopupDialogOkButton>().FirstOrDefault() != null)
|
|
|
|
exitDialog.PerformOkAction();
|
|
|
|
else
|
|
|
|
exitDialog.Flash();
|
|
|
|
}
|
2019-12-22 13:39:25 +00:00
|
|
|
else
|
2023-06-21 10:06:47 +00:00
|
|
|
{
|
|
|
|
dialogOverlay.Push(new ConfirmExitDialog(() =>
|
|
|
|
{
|
|
|
|
exitConfirmedViaDialog = true;
|
|
|
|
this.Exit();
|
|
|
|
}, () =>
|
|
|
|
{
|
2023-06-23 05:46:38 +00:00
|
|
|
holdToExitGameOverlay.Abort();
|
2023-06-21 10:06:47 +00:00
|
|
|
}));
|
|
|
|
}
|
2021-05-19 07:27:38 +00:00
|
|
|
|
|
|
|
return true;
|
2019-12-22 12:52:00 +00:00
|
|
|
}
|
|
|
|
|
2022-04-19 06:46:03 +00:00
|
|
|
Buttons.State = ButtonSystemState.Exit;
|
2020-08-28 07:55:14 +00:00
|
|
|
OverlayActivationMode.Value = OverlayActivation.Disabled;
|
2020-01-24 07:23:41 +00:00
|
|
|
|
2020-01-11 04:17:13 +00:00
|
|
|
songTicker.Hide();
|
2020-01-24 07:23:41 +00:00
|
|
|
|
|
|
|
this.FadeOut(3000);
|
2023-12-28 08:19:41 +00:00
|
|
|
|
|
|
|
bottomElementsFlow
|
|
|
|
.FadeOut(500, Easing.OutQuint);
|
2023-12-28 08:14:16 +00:00
|
|
|
|
|
|
|
supporterDisplay
|
|
|
|
.FadeOut(500, Easing.OutQuint);
|
2023-12-28 08:19:41 +00:00
|
|
|
|
2022-04-21 15:52:44 +00:00
|
|
|
return base.OnExiting(e);
|
2016-12-05 10:34:52 +00:00
|
|
|
}
|
2021-03-03 05:06:39 +00:00
|
|
|
|
|
|
|
public void PresentBeatmap(WorkingBeatmap beatmap, RulesetInfo ruleset)
|
|
|
|
{
|
2022-06-27 09:41:27 +00:00
|
|
|
Logger.Log($"{nameof(MainMenu)} completing {nameof(PresentBeatmap)} with beatmap {beatmap} ruleset {ruleset}");
|
|
|
|
|
2021-03-03 05:06:39 +00:00
|
|
|
Beatmap.Value = beatmap;
|
|
|
|
Ruleset.Value = ruleset;
|
|
|
|
|
|
|
|
Schedule(loadSoloSongSelect);
|
|
|
|
}
|
2022-02-23 13:06:22 +00:00
|
|
|
|
|
|
|
public bool OnPressed(KeyBindingPressEvent<GlobalAction> e)
|
|
|
|
{
|
|
|
|
if (e.Repeat)
|
|
|
|
return false;
|
|
|
|
|
2022-02-24 20:11:49 +00:00
|
|
|
switch (e.Action)
|
2022-02-23 13:06:22 +00:00
|
|
|
{
|
2022-02-24 20:11:49 +00:00
|
|
|
case GlobalAction.Back:
|
|
|
|
// In the case of a host being able to exit, the back action is handled by ExitConfirmOverlay.
|
|
|
|
Debug.Assert(!host.CanExit);
|
|
|
|
|
|
|
|
return host.SuspendToBackground();
|
2022-02-23 13:06:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void OnReleased(KeyBindingReleaseEvent<GlobalAction> e)
|
|
|
|
{
|
|
|
|
}
|
2016-08-26 03:28:23 +00:00
|
|
|
}
|
|
|
|
}
|