1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-15 14:12:54 +08:00
osu-lazer/osu.Game/Screens/Play/PlayerSettings/PlaybackSettings.cs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

184 lines
7.5 KiB
C#
Raw Normal View History

// 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 17:19:50 +08:00
2024-01-09 12:23:01 +08:00
using System;
using osu.Framework.Allocation;
2019-02-21 18:04:31 +08:00
using osu.Framework.Bindables;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
2024-01-09 12:23:01 +08:00
using osu.Framework.Graphics.Sprites;
using osu.Game.Beatmaps;
using osu.Game.Graphics;
using osu.Game.Graphics.Sprites;
2024-01-09 12:23:01 +08:00
using osu.Game.Graphics.UserInterface;
using osu.Game.Screens.Edit.Timing;
2024-01-09 12:23:01 +08:00
using osuTK;
2024-01-17 14:12:33 +08:00
using osu.Game.Localisation;
2018-04-13 17:19:50 +08:00
namespace osu.Game.Screens.Play.PlayerSettings
2017-05-18 12:09:36 +08:00
{
2018-01-16 01:52:52 +08:00
public partial class PlaybackSettings : PlayerSettingsGroup
2017-05-18 12:09:36 +08:00
{
2017-11-13 10:52:05 +08:00
private const int padding = 10;
2018-04-13 17:19:50 +08:00
public readonly Bindable<double> UserPlaybackRate = new BindableDouble(1)
{
MinValue = 0.05,
MaxValue = 2,
Precision = 0.01,
};
2018-04-13 17:19:50 +08:00
private readonly PlayerSliderBar<double> rateSlider;
2018-04-13 17:19:50 +08:00
private readonly OsuSpriteText multiplierText;
private readonly BindableBool isPaused = new BindableBool();
2024-01-09 12:23:01 +08:00
[Resolved]
2024-01-09 12:48:11 +08:00
private GameplayClockContainer? gameplayClock { get; set; }
2024-01-09 12:23:01 +08:00
[Resolved]
2024-01-09 12:48:11 +08:00
private GameplayState? gameplayState { get; set; }
2024-01-09 12:23:01 +08:00
public PlaybackSettings()
: base("playback")
2017-05-18 12:09:36 +08:00
{
2024-01-09 12:23:01 +08:00
const double seek_amount = 5000;
const double seek_fast_amount = 10000;
2024-01-09 16:30:48 +08:00
IconButton play;
Children = new Drawable[]
2017-05-18 12:09:36 +08:00
{
2024-01-09 12:23:01 +08:00
new FillFlowContainer
2017-10-02 23:19:55 +08:00
{
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
2024-01-09 12:23:01 +08:00
Direction = FillDirection.Vertical,
Spacing = new Vector2(0, padding),
Children = new Drawable[]
{
2024-01-09 12:23:01 +08:00
new FillFlowContainer
{
2024-01-09 12:23:01 +08:00
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Direction = FillDirection.Horizontal,
Spacing = new Vector2(5, 0),
Children = new Drawable[]
{
new SeekButton
2024-01-09 12:23:01 +08:00
{
Anchor = Anchor.Centre,
Origin = Anchor.Centre,
Icon = FontAwesome.Solid.FastBackward,
Action = () => seek(-1, seek_fast_amount),
2024-01-17 14:12:33 +08:00
TooltipText = PlayerSettingsOverlayStrings.SeekBackwardSeconds(seek_fast_amount / 1000),
2024-01-09 12:23:01 +08:00
},
new SeekButton
2024-01-09 12:23:01 +08:00
{
Anchor = Anchor.Centre,
Origin = Anchor.Centre,
Icon = FontAwesome.Solid.Backward,
Action = () => seek(-1, seek_amount),
2024-01-17 14:12:33 +08:00
TooltipText = PlayerSettingsOverlayStrings.SeekBackwardSeconds(seek_amount / 1000),
2024-01-09 12:23:01 +08:00
},
play = new IconButton
{
Anchor = Anchor.Centre,
Origin = Anchor.Centre,
Scale = new Vector2(1.4f),
IconScale = new Vector2(1.4f),
Icon = FontAwesome.Regular.PlayCircle,
Action = () =>
{
if (gameplayClock != null)
{
if (gameplayClock.IsRunning)
gameplayClock.Stop();
else
gameplayClock.Start();
}
},
2024-01-09 12:23:01 +08:00
},
new SeekButton
2024-01-09 12:23:01 +08:00
{
Anchor = Anchor.Centre,
Origin = Anchor.Centre,
Icon = FontAwesome.Solid.Forward,
Action = () => seek(1, seek_amount),
2024-01-17 14:12:33 +08:00
TooltipText = PlayerSettingsOverlayStrings.SeekForwardSeconds(seek_amount / 1000),
2024-01-09 12:23:01 +08:00
},
new SeekButton
2024-01-09 12:23:01 +08:00
{
Anchor = Anchor.Centre,
Origin = Anchor.Centre,
Icon = FontAwesome.Solid.FastForward,
Action = () => seek(1, seek_fast_amount),
2024-01-17 14:12:33 +08:00
TooltipText = PlayerSettingsOverlayStrings.SeekForwardSeconds(seek_fast_amount / 1000),
2024-01-09 12:23:01 +08:00
},
},
},
2024-01-09 12:23:01 +08:00
new Container
{
2024-01-09 12:23:01 +08:00
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Children = new Drawable[]
{
rateSlider = new PlayerSliderBar<double>
{
LabelText = "Playback speed",
Current = UserPlaybackRate,
},
multiplierText = new OsuSpriteText
{
Anchor = Anchor.TopRight,
Origin = Anchor.TopRight,
Font = OsuFont.GetFont(weight: FontWeight.Bold),
Margin = new MarginPadding { Right = 20 },
}
},
},
},
2017-10-02 23:19:55 +08:00
},
2017-05-30 00:00:29 +08:00
};
2024-01-09 12:23:01 +08:00
2024-01-17 14:12:33 +08:00
isPaused.BindValueChanged(paused =>
{
if (!paused.NewValue)
{
play.TooltipText = ToastStrings.PauseTrack;
play.Icon = FontAwesome.Regular.PauseCircle;
}
else
{
play.TooltipText = ToastStrings.PlayTrack;
play.Icon = FontAwesome.Regular.PlayCircle;
}
}, true);
2024-01-09 12:23:01 +08:00
void seek(int direction, double amount)
{
2024-01-09 12:24:09 +08:00
double target = Math.Clamp((gameplayClock?.CurrentTime ?? 0) + (direction * amount), 0, gameplayState?.Beatmap.GetLastObjectTime() ?? 0);
2024-01-09 12:23:01 +08:00
gameplayClock?.Seek(target);
}
2017-05-18 12:09:36 +08:00
}
2018-04-13 17:19:50 +08:00
2017-10-04 01:05:50 +08:00
protected override void LoadComplete()
2017-10-02 09:42:38 +08:00
{
2017-10-04 01:05:50 +08:00
base.LoadComplete();
rateSlider.Current.BindValueChanged(multiplier => multiplierText.Text = $"{multiplier.NewValue:0.00}x", true);
if (gameplayClock != null)
isPaused.BindTarget = gameplayClock.IsPaused;
2024-01-09 12:23:01 +08:00
}
private partial class SeekButton : IconButton
{
public SeekButton()
{
AddInternal(new RepeatingButtonBehaviour(this));
}
}
2017-05-18 12:09:36 +08:00
}
}