1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-23 03:43:22 +08:00
osu-lazer/osu.Game/Storyboards/Drawables/DrawableStoryboardSample.cs

98 lines
3.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-06-28 12:43:56 +08:00
2022-06-17 15:37:17 +08:00
#nullable disable
2020-06-16 21:54:50 +08:00
using System.Collections.Generic;
using System.Linq;
2018-06-28 12:43:56 +08:00
using osu.Framework.Allocation;
2019-02-21 18:04:31 +08:00
using osu.Framework.Bindables;
2020-06-16 21:54:50 +08:00
using osu.Game.Rulesets.Mods;
using osu.Game.Skinning;
2018-06-28 12:43:56 +08:00
namespace osu.Game.Storyboards.Drawables
{
public class DrawableStoryboardSample : PausableSkinnableSound
2018-06-28 12:43:56 +08:00
{
/// <summary>
/// The amount of time allowable beyond the start time of the sample, for the sample to start.
/// </summary>
private const double allowable_late_start = 100;
private readonly StoryboardSampleInfo sampleInfo;
2020-06-19 04:46:32 +08:00
2018-06-28 12:43:56 +08:00
public override bool RemoveWhenNotAlive => false;
public DrawableStoryboardSample(StoryboardSampleInfo sampleInfo)
: base(sampleInfo)
2018-06-28 12:43:56 +08:00
{
this.sampleInfo = sampleInfo;
LifetimeStart = sampleInfo.StartTime;
}
[Resolved(CanBeNull = true)]
private IReadOnlyList<Mod> mods { get; set; }
2021-01-22 09:06:24 +08:00
protected override void SkinChanged(ISkinSource skin)
{
base.SkinChanged(skin);
2020-06-16 21:54:50 +08:00
if (mods != null)
{
foreach (var mod in mods.OfType<IApplicableToSample>())
{
foreach (var sample in DrawableSamples)
mod.ApplyToSample(sample);
}
}
2018-06-28 12:43:56 +08:00
}
protected override void SamplePlaybackDisabledChanged(ValueChangedEvent<bool> disabled)
{
if (!RequestedPlaying) return;
if (!Looping && disabled.NewValue)
{
// the default behaviour for sample disabling is to allow one-shot samples to play out.
// storyboards regularly have long running samples that can cause this behaviour to lead to unintended results.
// for this reason, we immediately stop such samples.
Stop();
}
base.SamplePlaybackDisabledChanged(disabled);
}
2018-06-28 12:43:56 +08:00
protected override void Update()
{
base.Update();
// Check if we've yet to pass the sample start time.
if (Time.Current < sampleInfo.StartTime)
2018-06-28 12:43:56 +08:00
{
Stop();
2018-06-28 12:43:56 +08:00
// Playback has stopped, but if the user fast-forwards to a point after the start time of the sample then
// we must not have a lifetime end in order to continue receiving updates and start the sample below.
LifetimeStart = sampleInfo.StartTime;
2018-06-28 12:43:56 +08:00
LifetimeEnd = double.MaxValue;
return;
2018-06-28 12:43:56 +08:00
}
// Ensure that we've elapsed from a point before the sample's start time before playing.
if (Time.Current - Time.Elapsed <= sampleInfo.StartTime)
2018-06-28 12:43:56 +08:00
{
// We've passed the start time of the sample. We only play the sample if we're within an allowable range
// from the sample's start, to reduce layering if we've been fast-forwarded far into the future
if (!RequestedPlaying && Time.Current - sampleInfo.StartTime < allowable_late_start)
Play();
2018-06-28 12:43:56 +08:00
}
// Playback has started, but if the user rewinds to a point before the start time of the sample then
// we must not have a lifetime start in order to continue receiving updates and stop the sample above.
LifetimeStart = double.MinValue;
LifetimeEnd = sampleInfo.StartTime;
2018-06-28 12:43:56 +08:00
}
}
}