2019-01-24 16:43:03 +08: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 17:19:50 +08:00
|
|
|
|
|
|
|
|
|
using System;
|
2021-06-22 15:19:55 +08:00
|
|
|
|
using System.Collections.Generic;
|
2021-06-06 10:08:54 +08:00
|
|
|
|
using JetBrains.Annotations;
|
2018-04-13 17:19:50 +08:00
|
|
|
|
|
|
|
|
|
namespace osu.Game.Skinning
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Provides access to skinnable elements.
|
|
|
|
|
/// </summary>
|
2019-04-25 16:36:17 +08:00
|
|
|
|
public interface ISkinSource : ISkin
|
2018-04-13 17:19:50 +08:00
|
|
|
|
{
|
2021-10-12 11:50:28 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Fired whenever a source change occurs, signalling that consumers should re-query as required.
|
|
|
|
|
/// </summary>
|
2018-04-13 17:19:50 +08:00
|
|
|
|
event Action SourceChanged;
|
2021-06-06 10:08:54 +08: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>
|
|
|
|
|
[CanBeNull]
|
|
|
|
|
ISkin FindProvider(Func<ISkin, bool> lookupFunction);
|
2021-06-22 15:19:55 +08:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Retrieve all sources available for lookup, with highest priority source first.
|
|
|
|
|
/// </summary>
|
|
|
|
|
IEnumerable<ISkin> AllSources { get; }
|
2018-04-13 17:19:50 +08:00
|
|
|
|
}
|
|
|
|
|
}
|