mirror of
https://github.com/ppy/osu.git
synced 2025-02-12 07:12:54 +08:00
Fix FindProvider
calls on SkinProvidingContainer
not considering disable flags
Closes #13394.
This commit is contained in:
parent
38fc9347be
commit
448e4e7ee5
@ -27,6 +27,8 @@ namespace osu.Game.Skinning
|
||||
[CanBeNull]
|
||||
private ISkinSource fallbackSource;
|
||||
|
||||
private readonly NoFallbackProxy noFallbackLookupProxy;
|
||||
|
||||
protected virtual bool AllowDrawableLookup(ISkinComponent component) => true;
|
||||
|
||||
protected virtual bool AllowTextureLookup(string componentName) => true;
|
||||
@ -42,6 +44,8 @@ namespace osu.Game.Skinning
|
||||
this.skin = skin;
|
||||
|
||||
RelativeSizeAxes = Axes.Both;
|
||||
|
||||
noFallbackLookupProxy = new NoFallbackProxy(this);
|
||||
}
|
||||
|
||||
public ISkin FindProvider(Func<ISkin, bool> lookupFunction)
|
||||
@ -53,7 +57,8 @@ namespace osu.Game.Skinning
|
||||
}
|
||||
else if (skin != null)
|
||||
{
|
||||
if (lookupFunction(skin))
|
||||
// a proxy must be used here to correctly pass through the "Allow" checks without implicitly falling back to the fallbackSource.
|
||||
if (lookupFunction(noFallbackLookupProxy))
|
||||
return skin;
|
||||
}
|
||||
|
||||
@ -61,46 +66,70 @@ namespace osu.Game.Skinning
|
||||
}
|
||||
|
||||
public Drawable GetDrawableComponent(ISkinComponent component)
|
||||
=> GetDrawableComponent(component, true);
|
||||
|
||||
public Drawable GetDrawableComponent(ISkinComponent component, bool fallback)
|
||||
{
|
||||
Drawable sourceDrawable;
|
||||
if (AllowDrawableLookup(component) && (sourceDrawable = skin?.GetDrawableComponent(component)) != null)
|
||||
return sourceDrawable;
|
||||
|
||||
if (!fallback)
|
||||
return null;
|
||||
|
||||
return fallbackSource?.GetDrawableComponent(component);
|
||||
}
|
||||
|
||||
public Texture GetTexture(string componentName, WrapMode wrapModeS, WrapMode wrapModeT)
|
||||
=> GetTexture(componentName, wrapModeS, wrapModeT, true);
|
||||
|
||||
public Texture GetTexture(string componentName, WrapMode wrapModeS, WrapMode wrapModeT, bool fallback)
|
||||
{
|
||||
Texture sourceTexture;
|
||||
if (AllowTextureLookup(componentName) && (sourceTexture = skin?.GetTexture(componentName, wrapModeS, wrapModeT)) != null)
|
||||
return sourceTexture;
|
||||
|
||||
if (!fallback)
|
||||
return null;
|
||||
|
||||
return fallbackSource?.GetTexture(componentName, wrapModeS, wrapModeT);
|
||||
}
|
||||
|
||||
public ISample GetSample(ISampleInfo sampleInfo)
|
||||
=> GetSample(sampleInfo, true);
|
||||
|
||||
public ISample GetSample(ISampleInfo sampleInfo, bool fallback)
|
||||
{
|
||||
ISample sourceChannel;
|
||||
if (AllowSampleLookup(sampleInfo) && (sourceChannel = skin?.GetSample(sampleInfo)) != null)
|
||||
return sourceChannel;
|
||||
|
||||
if (!fallback)
|
||||
return null;
|
||||
|
||||
return fallbackSource?.GetSample(sampleInfo);
|
||||
}
|
||||
|
||||
public IBindable<TValue> GetConfig<TLookup, TValue>(TLookup lookup)
|
||||
=> GetConfig<TLookup, TValue>(lookup, true);
|
||||
|
||||
public IBindable<TValue> GetConfig<TLookup, TValue>(TLookup lookup, bool fallback)
|
||||
{
|
||||
if (skin != null)
|
||||
{
|
||||
if (lookup is GlobalSkinColours || lookup is SkinCustomColourLookup)
|
||||
return lookupWithFallback<TLookup, TValue>(lookup, AllowColourLookup);
|
||||
return lookupWithFallback<TLookup, TValue>(lookup, AllowColourLookup, fallback);
|
||||
|
||||
return lookupWithFallback<TLookup, TValue>(lookup, AllowConfigurationLookup);
|
||||
return lookupWithFallback<TLookup, TValue>(lookup, AllowConfigurationLookup, fallback);
|
||||
}
|
||||
|
||||
if (!fallback)
|
||||
return null;
|
||||
|
||||
return fallbackSource?.GetConfig<TLookup, TValue>(lookup);
|
||||
}
|
||||
|
||||
private IBindable<TValue> lookupWithFallback<TLookup, TValue>(TLookup lookup, bool canUseSkinLookup)
|
||||
private IBindable<TValue> lookupWithFallback<TLookup, TValue>(TLookup lookup, bool canUseSkinLookup, bool canUseFallback)
|
||||
{
|
||||
if (canUseSkinLookup)
|
||||
{
|
||||
@ -109,6 +138,9 @@ namespace osu.Game.Skinning
|
||||
return bindable;
|
||||
}
|
||||
|
||||
if (!canUseFallback)
|
||||
return null;
|
||||
|
||||
return fallbackSource?.GetConfig<TLookup, TValue>(lookup);
|
||||
}
|
||||
|
||||
@ -137,5 +169,36 @@ namespace osu.Game.Skinning
|
||||
if (fallbackSource != null)
|
||||
fallbackSource.SourceChanged -= TriggerSourceChanged;
|
||||
}
|
||||
|
||||
private class NoFallbackProxy : ISkinSource
|
||||
{
|
||||
private readonly SkinProvidingContainer provider;
|
||||
|
||||
public NoFallbackProxy(SkinProvidingContainer provider)
|
||||
{
|
||||
this.provider = provider;
|
||||
}
|
||||
|
||||
public Drawable GetDrawableComponent(ISkinComponent component)
|
||||
=> provider.GetDrawableComponent(component, false);
|
||||
|
||||
public Texture GetTexture(string componentName, WrapMode wrapModeS, WrapMode wrapModeT)
|
||||
=> provider.GetTexture(componentName, wrapModeS, wrapModeT, false);
|
||||
|
||||
public ISample GetSample(ISampleInfo sampleInfo)
|
||||
=> provider.GetSample(sampleInfo, false);
|
||||
|
||||
public IBindable<TValue> GetConfig<TLookup, TValue>(TLookup lookup)
|
||||
=> provider.GetConfig<TLookup, TValue>(lookup, false);
|
||||
|
||||
public event Action SourceChanged
|
||||
{
|
||||
add => provider.SourceChanged += value;
|
||||
remove => provider.SourceChanged -= value;
|
||||
}
|
||||
|
||||
public ISkin FindProvider(Func<ISkin, bool> lookupFunction) =>
|
||||
provider.FindProvider(lookupFunction);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user