2019-09-23 05:15:27 +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.
2022-06-17 07:37:17 +00:00
#nullable disable
2023-11-06 06:44:25 +00:00
using osu.Framework ;
2021-01-07 09:47:20 +00:00
using osu.Game.Graphics.UserInterface ;
2023-10-30 13:08:56 +00:00
using osu.Game.Input ;
2020-10-29 16:31:42 +00:00
using osu.Game.Online.API.Requests.Responses ;
2021-01-07 09:47:20 +00:00
using osu.Game.Overlays ;
2023-06-11 10:53:17 +00:00
using osu.Game.Overlays.Mods ;
2023-12-27 17:38:29 +00:00
using osu.Game.Scoring ;
2020-10-29 16:31:42 +00:00
2019-09-23 05:15:27 +00:00
namespace osu.Game.Configuration
{
2019-09-28 12:21:51 +00:00
/// <summary>
/// Stores global per-session statics. These will not be stored after exiting the game.
/// </summary>
public class SessionStatics : InMemoryConfigManager < Static >
2019-09-23 05:15:27 +00:00
{
2021-12-20 15:51:51 +00:00
protected override void InitialiseDefaults ( )
2021-04-16 09:01:58 +00:00
{
2021-12-21 06:34:32 +00:00
SetDefault ( Static . LoginOverlayDisplayed , false ) ;
SetDefault ( Static . MutedAudioNotificationShownOnce , false ) ;
SetDefault ( Static . LowBatteryNotificationShownOnce , false ) ;
2022-12-15 08:35:39 +00:00
SetDefault ( Static . FeaturedArtistDisclaimerShownOnce , false ) ;
2021-12-21 06:34:32 +00:00
SetDefault ( Static . LastHoverSoundPlaybackTime , ( double? ) null ) ;
2023-06-11 10:53:17 +00:00
SetDefault ( Static . LastModSelectPanelSamplePlaybackTime , ( double? ) null ) ;
2021-12-21 06:34:32 +00:00
SetDefault < APISeasonalBackgrounds > ( Static . SeasonalBackgrounds , null ) ;
2023-11-06 06:44:25 +00:00
SetDefault ( Static . TouchInputActive , RuntimeInfo . IsMobile ) ;
2023-12-27 17:38:29 +00:00
SetDefault < ScoreInfo > ( Static . LastLocalUserScore , null ) ;
2021-04-16 09:01:58 +00:00
}
2021-04-19 02:25:43 +00:00
2021-12-20 15:51:51 +00:00
/// <summary>
2021-12-21 06:34:32 +00:00
/// Revert statics to their defaults after being idle for appropriate amount of time.
2021-12-20 15:51:51 +00:00
/// </summary>
2021-12-21 06:34:32 +00:00
/// <remarks>
/// This only affects a subset of statics which the user would expect to have reset after a break.
/// </remarks>
public void ResetAfterInactivity ( )
2021-12-20 15:51:51 +00:00
{
2021-12-21 06:34:32 +00:00
GetBindable < bool > ( Static . LoginOverlayDisplayed ) . SetDefault ( ) ;
GetBindable < bool > ( Static . MutedAudioNotificationShownOnce ) . SetDefault ( ) ;
GetBindable < bool > ( Static . LowBatteryNotificationShownOnce ) . SetDefault ( ) ;
2021-12-20 15:51:51 +00:00
}
2019-09-23 05:15:27 +00:00
}
2019-09-28 12:21:51 +00:00
public enum Static
2019-09-23 05:15:27 +00:00
{
2019-09-24 02:45:47 +00:00
LoginOverlayDisplayed ,
2020-10-29 16:31:42 +00:00
MutedAudioNotificationShownOnce ,
2021-04-09 21:55:41 +00:00
LowBatteryNotificationShownOnce ,
2022-12-15 08:35:39 +00:00
FeaturedArtistDisclaimerShownOnce ,
2020-10-30 18:59:52 +00:00
/// <summary>
/// Info about seasonal backgrounds available fetched from API - see <see cref="APISeasonalBackgrounds"/>.
/// Value under this lookup can be <c>null</c> if there are no backgrounds available (or API is not reachable).
/// </summary>
2020-10-30 18:55:17 +00:00
SeasonalBackgrounds ,
2021-01-07 09:47:20 +00:00
/// <summary>
/// The last playback time in milliseconds of a hover sample (from <see cref="HoverSounds"/>).
/// Used to debounce hover sounds game-wide to avoid volume saturation, especially in scrolling views with many UI controls like <see cref="SettingsOverlay"/>.
/// </summary>
2022-12-15 08:35:39 +00:00
LastHoverSoundPlaybackTime ,
2023-06-11 10:53:17 +00:00
/// <summary>
/// The last playback time in milliseconds of an on/off sample (from <see cref="ModSelectPanel"/>).
/// Used to debounce <see cref="ModSelectPanel"/> on/off sounds game-wide to avoid volume saturation, especially in activating mod presets with many mods.
/// </summary>
2023-10-30 13:08:56 +00:00
LastModSelectPanelSamplePlaybackTime ,
/// <summary>
/// Whether the last positional input received was a touch input.
/// Used in touchscreen detection scenarios (<see cref="TouchInputInterceptor"/>).
/// </summary>
TouchInputActive ,
2023-12-27 17:38:29 +00:00
/// <summary>
/// Stores the local user's last score (can be completed or aborted).
/// </summary>
LastLocalUserScore ,
2019-09-23 05:15:27 +00:00
}
}