Add actual testing of animations
Before Width: | Height: | Size: 3.9 KiB After Width: | Height: | Size: 2.9 KiB |
BIN
osu.Game.Rulesets.Osu.Tests/Resources/special-skin/hit0-1@2x.png
Normal file
After Width: | Height: | Size: 8.2 KiB |
Before Width: | Height: | Size: 5.5 KiB After Width: | Height: | Size: 3.4 KiB |
After Width: | Height: | Size: 9.7 KiB |
Before Width: | Height: | Size: 4.9 KiB After Width: | Height: | Size: 3.8 KiB |
After Width: | Height: | Size: 13 KiB |
Before Width: | Height: | Size: 3.8 KiB After Width: | Height: | Size: 2.9 KiB |
After Width: | Height: | Size: 8.9 KiB |
@ -2,12 +2,12 @@
|
|||||||
// See the LICENCE file in the repository root for full licence text.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.IO;
|
using System.Text.RegularExpressions;
|
||||||
using System.Linq;
|
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Audio;
|
using osu.Framework.Audio;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
|
using osu.Framework.Graphics.Textures;
|
||||||
using osu.Framework.IO.Stores;
|
using osu.Framework.IO.Stores;
|
||||||
using osu.Game.Skinning;
|
using osu.Game.Skinning;
|
||||||
using osu.Game.Tests.Visual;
|
using osu.Game.Tests.Visual;
|
||||||
@ -28,11 +28,11 @@ namespace osu.Game.Rulesets.Osu.Tests
|
|||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load(AudioManager audio)
|
private void load(AudioManager audio)
|
||||||
{
|
{
|
||||||
var skins = new SkinManager(LocalStorage, ContextFactory, null, audio);
|
var dllStore = new DllResourceStore("osu.Game.Rulesets.Osu.Tests.dll");
|
||||||
|
|
||||||
metricsSkin = getSkinFromResources(skins, "metrics_skin");
|
metricsSkin = new TestLegacySkin(new SkinInfo(), new NamespacedResourceStore<byte[]>(dllStore, "Resources/metrics_skin"), audio, true);
|
||||||
defaultSkin = getSkinFromResources(skins, "default_skin");
|
defaultSkin = new TestLegacySkin(new SkinInfo(), new NamespacedResourceStore<byte[]>(dllStore, "Resources/default_skin"), audio, false);
|
||||||
specialSkin = getSkinFromResources(skins, "special_skin");
|
specialSkin = new TestLegacySkin(new SkinInfo(), new NamespacedResourceStore<byte[]>(dllStore, "Resources/special_skin"), audio, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void SetContents(Func<Drawable> creationFunction)
|
public void SetContents(Func<Drawable> creationFunction)
|
||||||
@ -43,23 +43,32 @@ namespace osu.Game.Rulesets.Osu.Tests
|
|||||||
Cell(3).Child = new LocalSkinOverrideContainer(specialSkin) { RelativeSizeAxes = Axes.Both }.WithChild(creationFunction());
|
Cell(3).Child = new LocalSkinOverrideContainer(specialSkin) { RelativeSizeAxes = Axes.Both }.WithChild(creationFunction());
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Skin getSkinFromResources(SkinManager skins, string name)
|
private class TestLegacySkin : LegacySkin
|
||||||
{
|
{
|
||||||
using (var storage = new DllResourceStore("osu.Game.Rulesets.Osu.Tests.dll"))
|
private readonly bool extrapolateAnimations;
|
||||||
|
|
||||||
|
public TestLegacySkin(SkinInfo skin, IResourceStore<byte[]> storage, AudioManager audioManager, bool extrapolateAnimations)
|
||||||
|
: base(skin, storage, audioManager, "skin.ini")
|
||||||
{
|
{
|
||||||
var tempName = Path.GetTempFileName();
|
this.extrapolateAnimations = extrapolateAnimations;
|
||||||
|
}
|
||||||
|
|
||||||
File.Delete(tempName);
|
public override Texture GetTexture(string componentName)
|
||||||
Directory.CreateDirectory(tempName);
|
{
|
||||||
|
// extrapolate frames to test longer animations
|
||||||
|
if (extrapolateAnimations)
|
||||||
|
{
|
||||||
|
var match = Regex.Match(componentName, "-([0-9]*)");
|
||||||
|
|
||||||
var files = storage.GetAvailableResources().Where(f => f.StartsWith($"Resources/{name}"));
|
if (match.Length > 0)
|
||||||
|
{
|
||||||
|
var number = int.Parse(match.Groups[1].Value);
|
||||||
|
if (number < 60)
|
||||||
|
return base.GetTexture(componentName.Replace($"-{number}", $"-{number % 2}"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
foreach (var file in files)
|
return base.GetTexture(componentName);
|
||||||
using (var stream = storage.GetStream(file))
|
|
||||||
using (var newFile = File.Create(Path.Combine(tempName, Path.GetFileName(file))))
|
|
||||||
stream.CopyTo(newFile);
|
|
||||||
|
|
||||||
return skins.GetSkin(skins.Import(tempName).Result);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|