1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-26 12:35:34 +08:00

Load json from disk store at skin construction for now

This allows for easier mutation without worrying about changes being
re-read from disk unexpectedly.
This commit is contained in:
Dean Herbert 2021-05-11 11:54:45 +09:00
parent 1bb3c609ae
commit c957293ec3

View File

@ -44,6 +44,32 @@ namespace osu.Game.Skinning
// may be null for default skin. // may be null for default skin.
this.resources = resources; this.resources = resources;
// we may want to move this to some kind of async operation in the future.
foreach (SkinnableTarget skinnableTarget in Enum.GetValues(typeof(SkinnableTarget)))
{
string filename = $"{skinnableTarget}.json";
// skininfo files may be null for default skin.
var fileInfo = SkinInfo.Files?.FirstOrDefault(f => f.Filename == filename);
if (fileInfo == null)
continue;
var bytes = resources?.Files.Get(fileInfo.FileInfo.StoragePath);
if (bytes == null)
continue;
string jsonContent = Encoding.UTF8.GetString(bytes);
DrawableComponentInfo[skinnableTarget] = JsonConvert.DeserializeObject<IEnumerable<SkinnableInfo>>(jsonContent).ToArray();
}
}
public void ResetDrawableTarget(SkinnableElementTargetContainer targetContainer)
{
DrawableComponentInfo.Remove(targetContainer.Target);
} }
public void UpdateDrawableTarget(SkinnableElementTargetContainer targetContainer) public void UpdateDrawableTarget(SkinnableElementTargetContainer targetContainer)
@ -60,34 +86,9 @@ namespace osu.Game.Skinning
var skinnableTarget = target.Target; var skinnableTarget = target.Target;
if (!DrawableComponentInfo.TryGetValue(skinnableTarget, out var skinnableInfo)) if (!DrawableComponentInfo.TryGetValue(skinnableTarget, out var skinnableInfo))
{
switch (skinnableTarget)
{
case SkinnableTarget.MainHUDComponents:
// skininfo files may be null for default skin.
var fileInfo = SkinInfo.Files?.FirstOrDefault(f => f.Filename == $"{skinnableTarget}.json");
if (fileInfo == null)
return null; return null;
var bytes = resources?.Files.Get(fileInfo.FileInfo.StoragePath); return new SkinnableTargetWrapper
if (bytes == null)
return null;
string jsonContent = Encoding.UTF8.GetString(bytes);
DrawableComponentInfo[skinnableTarget] = skinnableInfo =
JsonConvert.DeserializeObject<IEnumerable<SkinnableInfo>>(jsonContent).Where(i => i.Target == SkinnableTarget.MainHUDComponents).ToArray();
break;
}
}
if (skinnableInfo == null)
return null;
return new SkinnableTargetWrapper(skinnableTarget)
{ {
ChildrenEnumerable = skinnableInfo.Select(i => i.CreateInstance()) ChildrenEnumerable = skinnableInfo.Select(i => i.CreateInstance())
}; };
@ -123,15 +124,10 @@ namespace osu.Game.Skinning
#endregion #endregion
} }
public class SkinnableTargetWrapper : Container, IDefaultSkinnableTarget public class SkinnableTargetWrapper : Container, ISkinnableComponent
{ {
// this is just here to implement the interface and allow a silly parent lookup to work (where the target is not the direct parent for reasons). public SkinnableTargetWrapper()
// TODO: need to fix this.
public SkinnableTarget Target { get; }
public SkinnableTargetWrapper(SkinnableTarget target)
{ {
Target = target;
RelativeSizeAxes = Axes.Both; RelativeSizeAxes = Axes.Both;
} }
} }