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
using System ;
2021-06-22 07:19:55 +00:00
using System.Collections.Generic ;
2018-04-13 09:19:50 +00:00
namespace osu.Game.Skinning
{
/// <summary>
2023-02-16 06:27:30 +00:00
/// An abstract skin implementation, whose primary purpose is to properly handle component fallback across multiple layers of skins (e.g.: beatmap skin, user skin, default skin).
2018-04-13 09:19:50 +00:00
/// </summary>
2023-02-15 06:14:38 +00:00
/// <remarks>
/// Common usage is to do an initial lookup via <see cref="FindProvider"/>, and use the returned <see cref="ISkin"/>
/// to do further lookups for related components.
///
/// The initial lookup is used to lock consecutive lookups to the same underlying skin source (as to not get some elements
/// from one skin and others from another, which would be the case if using <see cref="ISkin"/> methods like
/// <see cref="ISkin.GetSample"/> directly).
/// </remarks>
2019-04-25 08:36:17 +00:00
public interface ISkinSource : ISkin
2018-04-13 09:19:50 +00:00
{
2021-10-12 03:50:28 +00:00
/// <summary>
/// Fired whenever a source change occurs, signalling that consumers should re-query as required.
/// </summary>
2018-04-13 09:19:50 +00:00
event Action SourceChanged ;
2021-06-06 02:08:54 +00:00
/// <summary>
/// Find the first (if any) skin that can fulfill the lookup.
/// This should be used for cases where subsequent lookups (for related components) need to occur on the same skin.
/// </summary>
/// <returns>The skin to be used for subsequent lookups, or <c>null</c> if none is available.</returns>
2022-11-09 04:44:59 +00:00
ISkin ? FindProvider ( Func < ISkin , bool > lookupFunction ) ;
2021-06-22 07:19:55 +00:00
/// <summary>
/// Retrieve all sources available for lookup, with highest priority source first.
/// </summary>
IEnumerable < ISkin > AllSources { get ; }
2018-04-13 09:19:50 +00:00
}
}