2020-03-27 09:03:02 +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
2020-03-27 09:03:02 +00:00
using osu.Framework.Allocation ;
2020-11-21 19:06:30 +00:00
using osu.Framework.Bindables ;
2022-08-02 10:50:57 +00:00
using osu.Framework.Graphics.Textures ;
2020-03-27 09:03:02 +00:00
using osu.Framework.Timing ;
namespace osu.Game.Skinning
{
/// <summary>
/// Denotes an object which provides a reference time to start animations from.
/// </summary>
2020-04-02 05:30:22 +00:00
/// <remarks>
/// This should not be used to start an animation immediately at the current time.
2020-07-17 07:57:33 +00:00
/// To do so, use <see cref="LegacySkinExtensions.GetAnimation(ISkin, string, WrapMode, WrapMode, bool, bool, bool, string, bool, double?)"/> with <code>startAtCurrentTime = true</code> instead.
2020-04-02 05:30:22 +00:00
/// </remarks>
2020-03-27 09:03:02 +00:00
[Cached]
public interface IAnimationTimeReference
{
/// <summary>
/// The reference clock.
/// </summary>
IFrameBasedClock Clock { get ; }
/// <summary>
/// The time which animations should be started from, relative to <see cref="Clock"/>.
/// </summary>
2020-11-22 12:11:22 +00:00
Bindable < double > AnimationStartTime { get ; }
2020-03-27 09:03:02 +00:00
}
}