mirror of
https://github.com/ppy/osu.git
synced 2025-01-26 18:03:11 +08:00
Remove old files
This commit is contained in:
parent
6db705a3a8
commit
393aa12eec
@ -1 +1 @@
|
|||||||
Subproject commit 0520e3cb51b8f440ec83c087806f732d20803dd8
|
Subproject commit e4101103d744edc3c8c2abd4a715962bc2fb064e
|
@ -1,24 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Audio.Track;
|
|
||||||
using osu.Framework.Graphics.Textures;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Beatmaps
|
|
||||||
{
|
|
||||||
public class TestWorkingBeatmap : WorkingBeatmap
|
|
||||||
{
|
|
||||||
public TestWorkingBeatmap(Beatmap beatmap)
|
|
||||||
: base(beatmap.BeatmapInfo)
|
|
||||||
{
|
|
||||||
this.beatmap = beatmap;
|
|
||||||
}
|
|
||||||
|
|
||||||
private readonly Beatmap beatmap;
|
|
||||||
|
|
||||||
protected override Beatmap GetBeatmap() => beatmap;
|
|
||||||
protected override Texture GetBackground() => null;
|
|
||||||
protected override Track GetTrack() => null;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,25 +0,0 @@
|
|||||||
<configuration>
|
|
||||||
<dllmap os="linux" dll="opengl32.dll" target="libGL.so.1"/>
|
|
||||||
<dllmap os="linux" dll="glu32.dll" target="libGLU.so.1"/>
|
|
||||||
<dllmap os="linux" dll="openal32.dll" target="libopenal.so.1"/>
|
|
||||||
<dllmap os="linux" dll="alut.dll" target="libalut.so.0"/>
|
|
||||||
<dllmap os="linux" dll="opencl.dll" target="libOpenCL.so"/>
|
|
||||||
<dllmap os="linux" dll="libX11" target="libX11.so.6"/>
|
|
||||||
<dllmap os="linux" dll="libXi" target="libXi.so.6"/>
|
|
||||||
<dllmap os="linux" dll="SDL2.dll" target="libSDL2-2.0.so.0"/>
|
|
||||||
<dllmap os="osx" dll="opengl32.dll" target="/System/Library/Frameworks/OpenGL.framework/OpenGL"/>
|
|
||||||
<dllmap os="osx" dll="openal32.dll" target="/System/Library/Frameworks/OpenAL.framework/OpenAL" />
|
|
||||||
<dllmap os="osx" dll="alut.dll" target="/System/Library/Frameworks/OpenAL.framework/OpenAL" />
|
|
||||||
<dllmap os="osx" dll="libGLES.dll" target="/System/Library/Frameworks/OpenGLES.framework/OpenGLES" />
|
|
||||||
<dllmap os="osx" dll="libGLESv1_CM.dll" target="/System/Library/Frameworks/OpenGLES.framework/OpenGLES" />
|
|
||||||
<dllmap os="osx" dll="libGLESv2.dll" target="/System/Library/Frameworks/OpenGLES.framework/OpenGLES" />
|
|
||||||
<dllmap os="osx" dll="opencl.dll" target="/System/Library/Frameworks/OpenCL.framework/OpenCL"/>
|
|
||||||
<dllmap os="osx" dll="SDL2.dll" target="libSDL2.dylib"/>
|
|
||||||
<!-- XQuartz compatibility (X11 on Mac) -->
|
|
||||||
<dllmap os="osx" dll="libGL.so.1" target="/usr/X11/lib/libGL.dylib"/>
|
|
||||||
<dllmap os="osx" dll="libX11" target="/usr/X11/lib/libX11.dylib"/>
|
|
||||||
<dllmap os="osx" dll="libXcursor.so.1" target="/usr/X11/lib/libXcursor.dylib"/>
|
|
||||||
<dllmap os="osx" dll="libXi" target="/usr/X11/lib/libXi.dylib"/>
|
|
||||||
<dllmap os="osx" dll="libXinerama" target="/usr/X11/lib/libXinerama.dylib"/>
|
|
||||||
<dllmap os="osx" dll="libXrandr.so.2" target="/usr/X11/lib/libXrandr.dylib"/>
|
|
||||||
</configuration>
|
|
@ -1,29 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework;
|
|
||||||
using osu.Framework.Platform;
|
|
||||||
using SQLite.Net;
|
|
||||||
using SQLite.Net.Interop;
|
|
||||||
using SQLite.Net.Platform.Generic;
|
|
||||||
using SQLite.Net.Platform.Win32;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Platform
|
|
||||||
{
|
|
||||||
public class TestStorage : DesktopStorage
|
|
||||||
{
|
|
||||||
public TestStorage(string baseName) : base(baseName)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public override SQLiteConnection GetDatabase(string name)
|
|
||||||
{
|
|
||||||
ISQLitePlatform platform;
|
|
||||||
if (RuntimeInfo.IsWindows)
|
|
||||||
platform = new SQLitePlatformWin32();
|
|
||||||
else
|
|
||||||
platform = new SQLitePlatformGeneric();
|
|
||||||
return new SQLiteConnection(platform, @":memory:");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,34 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Platform;
|
|
||||||
using osu.Framework.Testing;
|
|
||||||
using osu.Game;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
public abstract class OsuTestCase : TestCase
|
|
||||||
{
|
|
||||||
public override void RunTest()
|
|
||||||
{
|
|
||||||
using (var host = new HeadlessGameHost(realtime: false))
|
|
||||||
host.Run(new OsuTestCaseTestRunner(this));
|
|
||||||
}
|
|
||||||
|
|
||||||
public class OsuTestCaseTestRunner : OsuGameBase
|
|
||||||
{
|
|
||||||
private readonly OsuTestCase testCase;
|
|
||||||
|
|
||||||
public OsuTestCaseTestRunner(OsuTestCase testCase)
|
|
||||||
{
|
|
||||||
this.testCase = testCase;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void LoadComplete()
|
|
||||||
{
|
|
||||||
base.LoadComplete();
|
|
||||||
Add(new TestCaseTestRunner.TestRunner(testCase));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,205 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using osu.Framework.Audio.Track;
|
|
||||||
using osu.Framework.Extensions.Color4Extensions;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Framework.Graphics.Shapes;
|
|
||||||
using osu.Framework.Lists;
|
|
||||||
using osu.Framework.Timing;
|
|
||||||
using osu.Game.Beatmaps.ControlPoints;
|
|
||||||
using osu.Game.Graphics.Containers;
|
|
||||||
using osu.Game.Graphics.Sprites;
|
|
||||||
using osu.Game.Overlays;
|
|
||||||
using OpenTK.Graphics;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseBeatSyncedContainer : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Tests beat synced containers.";
|
|
||||||
|
|
||||||
private readonly MusicController mc;
|
|
||||||
|
|
||||||
public TestCaseBeatSyncedContainer()
|
|
||||||
{
|
|
||||||
Clock = new FramedClock();
|
|
||||||
Clock.ProcessFrame();
|
|
||||||
|
|
||||||
Add(new BeatContainer
|
|
||||||
{
|
|
||||||
Anchor = Anchor.BottomCentre,
|
|
||||||
Origin = Anchor.BottomCentre,
|
|
||||||
});
|
|
||||||
|
|
||||||
Add(mc = new MusicController
|
|
||||||
{
|
|
||||||
Origin = Anchor.TopRight,
|
|
||||||
Anchor = Anchor.TopRight,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void LoadComplete()
|
|
||||||
{
|
|
||||||
base.LoadComplete();
|
|
||||||
mc.ToggleVisibility();
|
|
||||||
}
|
|
||||||
|
|
||||||
private class BeatContainer : BeatSyncedContainer
|
|
||||||
{
|
|
||||||
private const int flash_layer_heigth = 150;
|
|
||||||
|
|
||||||
private readonly InfoString timingPointCount;
|
|
||||||
private readonly InfoString currentTimingPoint;
|
|
||||||
private readonly InfoString beatCount;
|
|
||||||
private readonly InfoString currentBeat;
|
|
||||||
private readonly InfoString beatsPerMinute;
|
|
||||||
private readonly InfoString adjustedBeatLength;
|
|
||||||
private readonly InfoString timeUntilNextBeat;
|
|
||||||
private readonly InfoString timeSinceLastBeat;
|
|
||||||
|
|
||||||
private readonly Box flashLayer;
|
|
||||||
|
|
||||||
public BeatContainer()
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.X;
|
|
||||||
AutoSizeAxes = Axes.Y;
|
|
||||||
Children = new Drawable[]
|
|
||||||
{
|
|
||||||
new Container
|
|
||||||
{
|
|
||||||
Name = @"Info Layer",
|
|
||||||
Anchor = Anchor.BottomLeft,
|
|
||||||
Origin = Anchor.BottomLeft,
|
|
||||||
AutoSizeAxes = Axes.Both,
|
|
||||||
Margin = new MarginPadding { Bottom = flash_layer_heigth },
|
|
||||||
Children = new Drawable[]
|
|
||||||
{
|
|
||||||
new Box
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Colour = Color4.Black.Opacity(150),
|
|
||||||
},
|
|
||||||
new FillFlowContainer
|
|
||||||
{
|
|
||||||
Anchor = Anchor.BottomLeft,
|
|
||||||
Origin = Anchor.BottomLeft,
|
|
||||||
AutoSizeAxes = Axes.Both,
|
|
||||||
Direction = FillDirection.Vertical,
|
|
||||||
Children = new Drawable[]
|
|
||||||
{
|
|
||||||
timingPointCount = new InfoString(@"Timing points amount"),
|
|
||||||
currentTimingPoint = new InfoString(@"Current timing point"),
|
|
||||||
beatCount = new InfoString(@"Beats amount (in the current timing point)"),
|
|
||||||
currentBeat = new InfoString(@"Current beat"),
|
|
||||||
beatsPerMinute = new InfoString(@"BPM"),
|
|
||||||
adjustedBeatLength = new InfoString(@"Adjusted beat length"),
|
|
||||||
timeUntilNextBeat = new InfoString(@"Time until next beat"),
|
|
||||||
timeSinceLastBeat = new InfoString(@"Time since last beat"),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
new Container
|
|
||||||
{
|
|
||||||
Name = @"Color indicator",
|
|
||||||
Anchor = Anchor.BottomCentre,
|
|
||||||
Origin = Anchor.BottomCentre,
|
|
||||||
RelativeSizeAxes = Axes.X,
|
|
||||||
Height = flash_layer_heigth,
|
|
||||||
Children = new Drawable[]
|
|
||||||
{
|
|
||||||
new Box
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Colour = Color4.Black,
|
|
||||||
},
|
|
||||||
flashLayer = new Box
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Colour = Color4.White,
|
|
||||||
Alpha = 0,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
Beatmap.ValueChanged += delegate
|
|
||||||
{
|
|
||||||
timingPointCount.Value = 0;
|
|
||||||
currentTimingPoint.Value = 0;
|
|
||||||
beatCount.Value = 0;
|
|
||||||
currentBeat.Value = 0;
|
|
||||||
beatsPerMinute.Value = 0;
|
|
||||||
adjustedBeatLength.Value = 0;
|
|
||||||
timeUntilNextBeat.Value = 0;
|
|
||||||
timeSinceLastBeat.Value = 0;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
private SortedList<TimingControlPoint> timingPoints => Beatmap.Value.Beatmap.ControlPointInfo.TimingPoints;
|
|
||||||
private TimingControlPoint getNextTimingPoint(TimingControlPoint current)
|
|
||||||
{
|
|
||||||
if (timingPoints[timingPoints.Count - 1] == current)
|
|
||||||
return current;
|
|
||||||
|
|
||||||
return timingPoints[timingPoints.IndexOf(current) + 1];
|
|
||||||
}
|
|
||||||
|
|
||||||
private int calculateBeatCount(TimingControlPoint current)
|
|
||||||
{
|
|
||||||
if (timingPoints.Count == 0) return 0;
|
|
||||||
|
|
||||||
if (timingPoints[timingPoints.Count - 1] == current)
|
|
||||||
return (int)Math.Ceiling((Beatmap.Value.Track.Length - current.Time) / current.BeatLength);
|
|
||||||
|
|
||||||
return (int)Math.Ceiling((getNextTimingPoint(current).Time - current.Time) / current.BeatLength);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void Update()
|
|
||||||
{
|
|
||||||
base.Update();
|
|
||||||
timeUntilNextBeat.Value = TimeUntilNextBeat;
|
|
||||||
timeSinceLastBeat.Value = TimeSinceLastBeat;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void OnNewBeat(int beatIndex, TimingControlPoint timingPoint, EffectControlPoint effectPoint, TrackAmplitudes amplitudes)
|
|
||||||
{
|
|
||||||
base.OnNewBeat(beatIndex, timingPoint, effectPoint, amplitudes);
|
|
||||||
|
|
||||||
timingPointCount.Value = timingPoints.Count;
|
|
||||||
currentTimingPoint.Value = timingPoints.IndexOf(timingPoint);
|
|
||||||
beatCount.Value = calculateBeatCount(timingPoint);
|
|
||||||
currentBeat.Value = beatIndex;
|
|
||||||
beatsPerMinute.Value = 60000 / timingPoint.BeatLength;
|
|
||||||
adjustedBeatLength.Value = timingPoint.BeatLength;
|
|
||||||
|
|
||||||
flashLayer.FadeOutFromOne(timingPoint.BeatLength);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private class InfoString : FillFlowContainer
|
|
||||||
{
|
|
||||||
private const int text_size = 20;
|
|
||||||
private const int margin = 7;
|
|
||||||
|
|
||||||
private readonly OsuSpriteText valueText;
|
|
||||||
|
|
||||||
public double Value
|
|
||||||
{
|
|
||||||
set { valueText.Text = $"{value:G}"; }
|
|
||||||
}
|
|
||||||
|
|
||||||
public InfoString(string header)
|
|
||||||
{
|
|
||||||
AutoSizeAxes = Axes.Both;
|
|
||||||
Direction = FillDirection.Horizontal;
|
|
||||||
Add(new OsuSpriteText { Text = header + @": ", TextSize = text_size });
|
|
||||||
Add(valueText = new OsuSpriteText { TextSize = text_size });
|
|
||||||
Margin = new MarginPadding(margin);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,26 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using NUnit.Framework;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Game.Screens.Select;
|
|
||||||
using OpenTK;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
[TestFixture]
|
|
||||||
internal class TestCaseBeatmapDetailArea : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Beatmap details in song select";
|
|
||||||
|
|
||||||
public TestCaseBeatmapDetailArea()
|
|
||||||
{
|
|
||||||
Add(new BeatmapDetailArea
|
|
||||||
{
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
Size = new Vector2(550f, 450f),
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,115 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System.Linq;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Game.Screens.Select;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseBeatmapDetails : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => "BeatmapDetails tab of BeatmapDetailArea";
|
|
||||||
|
|
||||||
public TestCaseBeatmapDetails()
|
|
||||||
{
|
|
||||||
BeatmapDetails details;
|
|
||||||
Add(details = new BeatmapDetails
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Padding = new MarginPadding(150),
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep("beatmap all metrics", () => details.Beatmap = new BeatmapInfo
|
|
||||||
{
|
|
||||||
Version = "All Metrics",
|
|
||||||
Metadata = new BeatmapMetadata
|
|
||||||
{
|
|
||||||
Source = "osu!lazer",
|
|
||||||
Tags = "this beatmap has all the metrics",
|
|
||||||
},
|
|
||||||
Difficulty = new BeatmapDifficulty
|
|
||||||
{
|
|
||||||
CircleSize = 7,
|
|
||||||
DrainRate = 1,
|
|
||||||
OverallDifficulty = 5.7f,
|
|
||||||
ApproachRate = 3.5f,
|
|
||||||
},
|
|
||||||
StarDifficulty = 5.3f,
|
|
||||||
Metrics = new BeatmapMetrics
|
|
||||||
{
|
|
||||||
Ratings = Enumerable.Range(0, 10),
|
|
||||||
Fails = Enumerable.Range(1, 100).Select(i => i % 12 - 6),
|
|
||||||
Retries = Enumerable.Range(-2, 100).Select(i => i % 12 - 6),
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep("beatmap ratings", () => details.Beatmap = new BeatmapInfo
|
|
||||||
{
|
|
||||||
Version = "Only Ratings",
|
|
||||||
Metadata = new BeatmapMetadata
|
|
||||||
{
|
|
||||||
Source = "osu!lazer",
|
|
||||||
Tags = "this beatmap has ratings metrics but not retries or fails",
|
|
||||||
},
|
|
||||||
Difficulty = new BeatmapDifficulty
|
|
||||||
{
|
|
||||||
CircleSize = 6,
|
|
||||||
DrainRate = 9,
|
|
||||||
OverallDifficulty = 6,
|
|
||||||
ApproachRate = 6,
|
|
||||||
},
|
|
||||||
StarDifficulty = 4.8f,
|
|
||||||
Metrics = new BeatmapMetrics
|
|
||||||
{
|
|
||||||
Ratings = Enumerable.Range(0, 10),
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep("beatmap fails retries", () => details.Beatmap = new BeatmapInfo
|
|
||||||
{
|
|
||||||
Version = "Only Retries and Fails",
|
|
||||||
Metadata = new BeatmapMetadata
|
|
||||||
{
|
|
||||||
Source = "osu!lazer",
|
|
||||||
Tags = "this beatmap has retries and fails but no ratings",
|
|
||||||
},
|
|
||||||
Difficulty = new BeatmapDifficulty
|
|
||||||
{
|
|
||||||
CircleSize = 3.7f,
|
|
||||||
DrainRate = 6,
|
|
||||||
OverallDifficulty = 6,
|
|
||||||
ApproachRate = 7,
|
|
||||||
},
|
|
||||||
StarDifficulty = 2.91f,
|
|
||||||
Metrics = new BeatmapMetrics
|
|
||||||
{
|
|
||||||
Fails = Enumerable.Range(1, 100).Select(i => i % 12 - 6),
|
|
||||||
Retries = Enumerable.Range(-2, 100).Select(i => i % 12 - 6),
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep("beatmap no metrics", () => details.Beatmap = new BeatmapInfo
|
|
||||||
{
|
|
||||||
Version = "No Metrics",
|
|
||||||
Metadata = new BeatmapMetadata
|
|
||||||
{
|
|
||||||
Source = "osu!lazer",
|
|
||||||
Tags = "this beatmap has no metrics",
|
|
||||||
},
|
|
||||||
Difficulty = new BeatmapDifficulty
|
|
||||||
{
|
|
||||||
CircleSize = 5,
|
|
||||||
DrainRate = 5,
|
|
||||||
OverallDifficulty = 5.5f,
|
|
||||||
ApproachRate = 6.5f,
|
|
||||||
},
|
|
||||||
StarDifficulty = 1.97f,
|
|
||||||
Metrics = new BeatmapMetrics(),
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep("null beatmap", () => details.Beatmap = null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,29 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Game.Graphics;
|
|
||||||
using osu.Game.Screens.Select.Options;
|
|
||||||
using OpenTK.Graphics;
|
|
||||||
using OpenTK.Input;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseBeatmapOptionsOverlay : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Beatmap options in song select";
|
|
||||||
|
|
||||||
public TestCaseBeatmapOptionsOverlay()
|
|
||||||
{
|
|
||||||
var overlay = new BeatmapOptionsOverlay();
|
|
||||||
|
|
||||||
overlay.AddButton(@"Remove", @"from unplayed", FontAwesome.fa_times_circle_o, Color4.Purple, null, Key.Number1);
|
|
||||||
overlay.AddButton(@"Clear", @"local scores", FontAwesome.fa_eraser, Color4.Purple, null, Key.Number2);
|
|
||||||
overlay.AddButton(@"Edit", @"Beatmap", FontAwesome.fa_pencil, Color4.Yellow, null, Key.Number3);
|
|
||||||
overlay.AddButton(@"Delete", @"Beatmap", FontAwesome.fa_trash, Color4.Pink, null, Key.Number4, float.MaxValue);
|
|
||||||
|
|
||||||
Add(overlay);
|
|
||||||
|
|
||||||
AddStep(@"Toggle", overlay.ToggleVisibility);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,36 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Game.Graphics.UserInterface;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseBreadcrumbs : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"breadcrumb > control";
|
|
||||||
|
|
||||||
public TestCaseBreadcrumbs()
|
|
||||||
{
|
|
||||||
BreadcrumbControl<BreadcrumbTab> c;
|
|
||||||
Add(c = new BreadcrumbControl<BreadcrumbTab>
|
|
||||||
{
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
RelativeSizeAxes = Axes.X,
|
|
||||||
Width = 0.5f,
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep(@"first", () => c.Current.Value = BreadcrumbTab.Click);
|
|
||||||
AddStep(@"second", () => c.Current.Value = BreadcrumbTab.The);
|
|
||||||
AddStep(@"third", () => c.Current.Value = BreadcrumbTab.Circles);
|
|
||||||
}
|
|
||||||
|
|
||||||
private enum BreadcrumbTab
|
|
||||||
{
|
|
||||||
Click,
|
|
||||||
The,
|
|
||||||
Circles,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,35 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Game.Rulesets;
|
|
||||||
using osu.Game.Rulesets.Catch;
|
|
||||||
using osu.Game.Rulesets.Catch.UI;
|
|
||||||
using OpenTK;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseCatcher : OsuTestCase
|
|
||||||
{
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load(RulesetStore rulesets)
|
|
||||||
{
|
|
||||||
Children = new Drawable[]
|
|
||||||
{
|
|
||||||
new CatchInputManager(rulesets.GetRuleset(2))
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Child = new CatcherArea
|
|
||||||
{
|
|
||||||
RelativePositionAxes = Axes.Both,
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Anchor = Anchor.BottomLeft,
|
|
||||||
Origin = Anchor.BottomLeft,
|
|
||||||
Size = new Vector2(1, 0.2f),
|
|
||||||
}
|
|
||||||
},
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,21 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Game.Overlays;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseChatDisplay : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Testing chat api and overlay";
|
|
||||||
|
|
||||||
public TestCaseChatDisplay()
|
|
||||||
{
|
|
||||||
Add(new ChatOverlay
|
|
||||||
{
|
|
||||||
State = Visibility.Visible
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,97 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Framework.Graphics.Cursor;
|
|
||||||
using osu.Framework.Graphics.Shapes;
|
|
||||||
using osu.Framework.Graphics.UserInterface;
|
|
||||||
using osu.Game.Graphics.UserInterface;
|
|
||||||
using OpenTK;
|
|
||||||
using OpenTK.Graphics;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseContextMenu : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Menu visible on right click";
|
|
||||||
|
|
||||||
private const int start_time = 0;
|
|
||||||
private const int duration = 1000;
|
|
||||||
|
|
||||||
private readonly Container container;
|
|
||||||
|
|
||||||
public TestCaseContextMenu()
|
|
||||||
{
|
|
||||||
Add(container = new MyContextMenuContainer
|
|
||||||
{
|
|
||||||
Size = new Vector2(200),
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
Children = new Drawable[]
|
|
||||||
{
|
|
||||||
new Box
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Colour = Color4.Green,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
Add(new AnotherContextMenuContainer
|
|
||||||
{
|
|
||||||
Size = new Vector2(200),
|
|
||||||
Anchor = Anchor.CentreLeft,
|
|
||||||
Origin = Anchor.CentreLeft,
|
|
||||||
Children = new Drawable[]
|
|
||||||
{
|
|
||||||
new Box
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Colour = Color4.Red,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void LoadComplete()
|
|
||||||
{
|
|
||||||
base.LoadComplete();
|
|
||||||
|
|
||||||
// Move box along a square trajectory
|
|
||||||
container.Loop(c => c
|
|
||||||
.MoveTo(new Vector2(0, 100), duration).Then()
|
|
||||||
.MoveTo(new Vector2(100, 100), duration).Then()
|
|
||||||
.MoveTo(new Vector2(100, 0), duration).Then()
|
|
||||||
.MoveTo(Vector2.Zero, duration)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
private class MyContextMenuContainer : Container, IHasContextMenu
|
|
||||||
{
|
|
||||||
public MenuItem[] ContextMenuItems => new MenuItem[]
|
|
||||||
{
|
|
||||||
new OsuMenuItem(@"Some option"),
|
|
||||||
new OsuMenuItem(@"Highlighted option", MenuItemType.Highlighted),
|
|
||||||
new OsuMenuItem(@"Another option"),
|
|
||||||
new OsuMenuItem(@"Choose me please"),
|
|
||||||
new OsuMenuItem(@"And me too"),
|
|
||||||
new OsuMenuItem(@"Trying to fill"),
|
|
||||||
new OsuMenuItem(@"Destructive option", MenuItemType.Destructive),
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
private class AnotherContextMenuContainer : Container, IHasContextMenu
|
|
||||||
{
|
|
||||||
public MenuItem[] ContextMenuItems => new MenuItem[]
|
|
||||||
{
|
|
||||||
new OsuMenuItem(@"Simple option"),
|
|
||||||
new OsuMenuItem(@"Simple very very long option"),
|
|
||||||
new OsuMenuItem(@"Change width", MenuItemType.Highlighted, () => this.ResizeWidthTo(Width * 2, 100, Easing.OutQuint)),
|
|
||||||
new OsuMenuItem(@"Change height", MenuItemType.Highlighted, () => this.ResizeHeightTo(Height * 2, 100, Easing.OutQuint)),
|
|
||||||
new OsuMenuItem(@"Change width back", MenuItemType.Destructive, () => this.ResizeWidthTo(Width / 2, 100, Easing.OutQuint)),
|
|
||||||
new OsuMenuItem(@"Change height back", MenuItemType.Destructive, () => this.ResizeHeightTo(Height / 2, 100, Easing.OutQuint)),
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,75 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Game.Graphics;
|
|
||||||
using osu.Game.Overlays;
|
|
||||||
using osu.Game.Overlays.Dialog;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseDialogOverlay : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Display dialogs";
|
|
||||||
|
|
||||||
public TestCaseDialogOverlay()
|
|
||||||
{
|
|
||||||
DialogOverlay overlay;
|
|
||||||
|
|
||||||
Add(overlay = new DialogOverlay());
|
|
||||||
|
|
||||||
AddStep("dialog #1", () => overlay.Push(new PopupDialog
|
|
||||||
{
|
|
||||||
Icon = FontAwesome.fa_trash_o,
|
|
||||||
HeaderText = @"Confirm deletion of",
|
|
||||||
BodyText = @"Ayase Rie - Yuima-ru*World TVver.",
|
|
||||||
Buttons = new PopupDialogButton[]
|
|
||||||
{
|
|
||||||
new PopupDialogOkButton
|
|
||||||
{
|
|
||||||
Text = @"I never want to see this again.",
|
|
||||||
Action = () => System.Console.WriteLine(@"OK"),
|
|
||||||
},
|
|
||||||
new PopupDialogCancelButton
|
|
||||||
{
|
|
||||||
Text = @"Firetruck, I still want quick ranks!",
|
|
||||||
Action = () => System.Console.WriteLine(@"Cancel"),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}));
|
|
||||||
|
|
||||||
AddStep("dialog #2", () => overlay.Push(new PopupDialog
|
|
||||||
{
|
|
||||||
Icon = FontAwesome.fa_gear,
|
|
||||||
HeaderText = @"What do you want to do with",
|
|
||||||
BodyText = "Camellia as \"Bang Riot\" - Blastix Riotz",
|
|
||||||
Buttons = new PopupDialogButton[]
|
|
||||||
{
|
|
||||||
new PopupDialogOkButton
|
|
||||||
{
|
|
||||||
Text = @"Manage collections",
|
|
||||||
},
|
|
||||||
new PopupDialogOkButton
|
|
||||||
{
|
|
||||||
Text = @"Delete...",
|
|
||||||
},
|
|
||||||
new PopupDialogOkButton
|
|
||||||
{
|
|
||||||
Text = @"Remove from unplayed",
|
|
||||||
},
|
|
||||||
new PopupDialogOkButton
|
|
||||||
{
|
|
||||||
Text = @"Clear local scores",
|
|
||||||
},
|
|
||||||
new PopupDialogOkButton
|
|
||||||
{
|
|
||||||
Text = @"Edit",
|
|
||||||
},
|
|
||||||
new PopupDialogCancelButton
|
|
||||||
{
|
|
||||||
Text = @"Cancel",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,223 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Game.Overlays;
|
|
||||||
using osu.Game.Rulesets;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
public class TestCaseDirect : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"osu!direct overlay";
|
|
||||||
|
|
||||||
private DirectOverlay direct;
|
|
||||||
private RulesetStore rulesets;
|
|
||||||
|
|
||||||
protected override void LoadComplete()
|
|
||||||
{
|
|
||||||
base.LoadComplete();
|
|
||||||
|
|
||||||
Add(direct = new DirectOverlay());
|
|
||||||
newBeatmaps();
|
|
||||||
|
|
||||||
AddStep(@"toggle", direct.ToggleVisibility);
|
|
||||||
AddStep(@"result counts", () => direct.ResultAmounts = new DirectOverlay.ResultCounts(1, 4, 13));
|
|
||||||
}
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load(RulesetStore rulesets)
|
|
||||||
{
|
|
||||||
this.rulesets = rulesets;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void newBeatmaps()
|
|
||||||
{
|
|
||||||
var ruleset = rulesets.GetRuleset(0);
|
|
||||||
|
|
||||||
direct.BeatmapSets = new[]
|
|
||||||
{
|
|
||||||
new BeatmapSetInfo
|
|
||||||
{
|
|
||||||
OnlineBeatmapSetID = 578332,
|
|
||||||
Metadata = new BeatmapMetadata
|
|
||||||
{
|
|
||||||
Title = @"OrVid",
|
|
||||||
Artist = @"An",
|
|
||||||
Author = @"RLC",
|
|
||||||
Source = @"",
|
|
||||||
Tags = @"acuticnotes an-fillnote revid tear tearvid encrpted encryption axi axivid quad her hervid recoll",
|
|
||||||
},
|
|
||||||
OnlineInfo = new BeatmapSetOnlineInfo
|
|
||||||
{
|
|
||||||
Covers = new BeatmapSetOnlineCovers
|
|
||||||
{
|
|
||||||
Card = @"https://assets.ppy.sh/beatmaps/578332/covers/card.jpg?1494591390",
|
|
||||||
Cover = @"https://assets.ppy.sh/beatmaps/578332/covers/cover.jpg?1494591390",
|
|
||||||
},
|
|
||||||
Preview = @"https://b.ppy.sh/preview/578332.mp3",
|
|
||||||
PlayCount = 97,
|
|
||||||
FavouriteCount = 72,
|
|
||||||
},
|
|
||||||
Beatmaps = new List<BeatmapInfo>
|
|
||||||
{
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
Ruleset = ruleset,
|
|
||||||
StarDifficulty = 5.35f,
|
|
||||||
Metadata = new BeatmapMetadata(),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
new BeatmapSetInfo
|
|
||||||
{
|
|
||||||
OnlineBeatmapSetID = 599627,
|
|
||||||
Metadata = new BeatmapMetadata
|
|
||||||
{
|
|
||||||
Title = @"tiny lamp",
|
|
||||||
Artist = @"fhana",
|
|
||||||
Author = @"Sotarks",
|
|
||||||
Source = @"ぎんぎつね",
|
|
||||||
Tags = @"lantis junichi sato yuxuki waga kevin mitsunaga towana gingitsune opening op full ver version kalibe collab collaboration",
|
|
||||||
},
|
|
||||||
OnlineInfo = new BeatmapSetOnlineInfo
|
|
||||||
{
|
|
||||||
Covers = new BeatmapSetOnlineCovers
|
|
||||||
{
|
|
||||||
Card = @"https://assets.ppy.sh/beatmaps/599627/covers/card.jpg?1494539318",
|
|
||||||
Cover = @"https://assets.ppy.sh/beatmaps/599627/covers/cover.jpg?1494539318",
|
|
||||||
},
|
|
||||||
Preview = @"https//b.ppy.sh/preview/599627.mp3",
|
|
||||||
PlayCount = 3082,
|
|
||||||
FavouriteCount = 14,
|
|
||||||
},
|
|
||||||
Beatmaps = new List<BeatmapInfo>
|
|
||||||
{
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
Ruleset = ruleset,
|
|
||||||
StarDifficulty = 5.81f,
|
|
||||||
Metadata = new BeatmapMetadata(),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
new BeatmapSetInfo
|
|
||||||
{
|
|
||||||
OnlineBeatmapSetID = 513268,
|
|
||||||
Metadata = new BeatmapMetadata
|
|
||||||
{
|
|
||||||
Title = @"At Gwanghwamun",
|
|
||||||
Artist = @"KYUHYUN",
|
|
||||||
Author = @"Cerulean Veyron",
|
|
||||||
Source = @"",
|
|
||||||
Tags = @"soul ballad kh super junior sj suju 슈퍼주니어 kt뮤직 sm엔터테인먼트 s.m.entertainment kt music 1st mini album ep",
|
|
||||||
},
|
|
||||||
OnlineInfo = new BeatmapSetOnlineInfo
|
|
||||||
{
|
|
||||||
Covers = new BeatmapSetOnlineCovers
|
|
||||||
{
|
|
||||||
Card = @"https://assets.ppy.sh/beatmaps/513268/covers/card.jpg?1494502863",
|
|
||||||
Cover = @"https://assets.ppy.sh/beatmaps/513268/covers/cover.jpg?1494502863",
|
|
||||||
},
|
|
||||||
Preview = @"https//b.ppy.sh/preview/513268.mp3",
|
|
||||||
PlayCount = 2762,
|
|
||||||
FavouriteCount = 15,
|
|
||||||
},
|
|
||||||
Beatmaps = new List<BeatmapInfo>
|
|
||||||
{
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
Ruleset = ruleset,
|
|
||||||
StarDifficulty = 0.9f,
|
|
||||||
Metadata = new BeatmapMetadata(),
|
|
||||||
},
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
Ruleset = ruleset,
|
|
||||||
StarDifficulty = 1.1f,
|
|
||||||
},
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
Ruleset = ruleset,
|
|
||||||
StarDifficulty = 2.02f,
|
|
||||||
},
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
Ruleset = ruleset,
|
|
||||||
StarDifficulty = 3.49f,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
new BeatmapSetInfo
|
|
||||||
{
|
|
||||||
OnlineBeatmapSetID = 586841,
|
|
||||||
Metadata = new BeatmapMetadata
|
|
||||||
{
|
|
||||||
Title = @"RHAPSODY OF BLUE SKY",
|
|
||||||
Artist = @"fhana",
|
|
||||||
Author = @"[Kamiya]",
|
|
||||||
Source = @"小林さんちのメイドラゴン",
|
|
||||||
Tags = @"kobayashi san chi no maidragon aozora no opening anime maid dragon oblivion karen dynamix imoutosan pata-mon gxytcgxytc",
|
|
||||||
},
|
|
||||||
OnlineInfo = new BeatmapSetOnlineInfo
|
|
||||||
{
|
|
||||||
Covers = new BeatmapSetOnlineCovers
|
|
||||||
{
|
|
||||||
Card = @"https://assets.ppy.sh/beatmaps/586841/covers/card.jpg?1494052741",
|
|
||||||
Cover = @"https://assets.ppy.sh/beatmaps/586841/covers/cover.jpg?1494052741",
|
|
||||||
},
|
|
||||||
Preview = @"https//b.ppy.sh/preview/586841.mp3",
|
|
||||||
PlayCount = 62317,
|
|
||||||
FavouriteCount = 161,
|
|
||||||
},
|
|
||||||
Beatmaps = new List<BeatmapInfo>
|
|
||||||
{
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
Ruleset = ruleset,
|
|
||||||
StarDifficulty = 1.26f,
|
|
||||||
Metadata = new BeatmapMetadata(),
|
|
||||||
},
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
Ruleset = ruleset,
|
|
||||||
StarDifficulty = 2.01f,
|
|
||||||
},
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
Ruleset = ruleset,
|
|
||||||
StarDifficulty = 2.87f,
|
|
||||||
},
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
Ruleset = ruleset,
|
|
||||||
StarDifficulty = 3.76f,
|
|
||||||
},
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
Ruleset = ruleset,
|
|
||||||
StarDifficulty = 3.93f,
|
|
||||||
},
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
Ruleset = ruleset,
|
|
||||||
StarDifficulty = 4.37f,
|
|
||||||
},
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
Ruleset = ruleset,
|
|
||||||
StarDifficulty = 5.13f,
|
|
||||||
},
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
Ruleset = ruleset,
|
|
||||||
StarDifficulty = 5.42f,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,132 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Game.Online.Multiplayer;
|
|
||||||
using osu.Game.Rulesets;
|
|
||||||
using osu.Game.Screens.Multiplayer;
|
|
||||||
using osu.Game.Users;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseDrawableRoom : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Select your favourite room";
|
|
||||||
|
|
||||||
private RulesetStore rulesets;
|
|
||||||
|
|
||||||
protected override void LoadComplete()
|
|
||||||
{
|
|
||||||
base.LoadComplete();
|
|
||||||
|
|
||||||
DrawableRoom first;
|
|
||||||
Add(new FillFlowContainer
|
|
||||||
{
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
AutoSizeAxes = Axes.Y,
|
|
||||||
Width = 580f,
|
|
||||||
Direction = FillDirection.Vertical,
|
|
||||||
Children = new Drawable[]
|
|
||||||
{
|
|
||||||
first = new DrawableRoom(new Room
|
|
||||||
{
|
|
||||||
Name = { Value = @"Great Room Right Here" },
|
|
||||||
Host = { Value = new User { Username = @"Naeferith", Id = 9492835, Country = new Country { FlagName = @"FR" } } },
|
|
||||||
Status = { Value = new RoomStatusOpen() },
|
|
||||||
Type = { Value = new GameTypeTeamVersus() },
|
|
||||||
Beatmap =
|
|
||||||
{
|
|
||||||
Value = new BeatmapInfo
|
|
||||||
{
|
|
||||||
StarDifficulty = 4.65,
|
|
||||||
Ruleset = rulesets.GetRuleset(3),
|
|
||||||
Metadata = new BeatmapMetadata
|
|
||||||
{
|
|
||||||
Title = @"Critical Crystal",
|
|
||||||
Artist = @"Seiryu",
|
|
||||||
},
|
|
||||||
BeatmapSet = new BeatmapSetInfo
|
|
||||||
{
|
|
||||||
OnlineInfo = new BeatmapSetOnlineInfo
|
|
||||||
{
|
|
||||||
Covers = new BeatmapSetOnlineCovers
|
|
||||||
{
|
|
||||||
Cover = @"https://assets.ppy.sh//beatmaps/376340/covers/cover.jpg?1456478455",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
Participants =
|
|
||||||
{
|
|
||||||
Value = new[]
|
|
||||||
{
|
|
||||||
new User { GlobalRank = 1355 },
|
|
||||||
new User { GlobalRank = 8756 },
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}),
|
|
||||||
new DrawableRoom(new Room
|
|
||||||
{
|
|
||||||
Name = { Value = @"Relax It's The Weekend" },
|
|
||||||
Host = { Value = new User { Username = @"peppy", Id = 2, Country = new Country { FlagName = @"AU" } } },
|
|
||||||
Status = { Value = new RoomStatusPlaying() },
|
|
||||||
Type = { Value = new GameTypeTagTeam() },
|
|
||||||
Beatmap =
|
|
||||||
{
|
|
||||||
Value = new BeatmapInfo
|
|
||||||
{
|
|
||||||
StarDifficulty = 1.96,
|
|
||||||
Ruleset = rulesets.GetRuleset(0),
|
|
||||||
Metadata = new BeatmapMetadata
|
|
||||||
{
|
|
||||||
Title = @"Serendipity",
|
|
||||||
Artist = @"ZAQ",
|
|
||||||
},
|
|
||||||
BeatmapSet = new BeatmapSetInfo
|
|
||||||
{
|
|
||||||
OnlineInfo = new BeatmapSetOnlineInfo
|
|
||||||
{
|
|
||||||
Covers = new BeatmapSetOnlineCovers
|
|
||||||
{
|
|
||||||
Cover = @"https://assets.ppy.sh//beatmaps/526839/covers/cover.jpg?1493815706",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
Participants =
|
|
||||||
{
|
|
||||||
Value = new[]
|
|
||||||
{
|
|
||||||
new User { GlobalRank = 578975 },
|
|
||||||
new User { GlobalRank = 24554 },
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}),
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep(@"change title", () => first.Room.Name.Value = @"I Changed Name");
|
|
||||||
AddStep(@"change host", () => first.Room.Host.Value = new User { Username = @"DrabWeb", Id = 6946022, Country = new Country { FlagName = @"CA" } });
|
|
||||||
AddStep(@"change status", () => first.Room.Status.Value = new RoomStatusPlaying());
|
|
||||||
AddStep(@"change type", () => first.Room.Type.Value = new GameTypeVersus());
|
|
||||||
AddStep(@"change beatmap", () => first.Room.Beatmap.Value = null);
|
|
||||||
AddStep(@"change participants", () => first.Room.Participants.Value = new[]
|
|
||||||
{
|
|
||||||
new User { GlobalRank = 1254 },
|
|
||||||
new User { GlobalRank = 123189 },
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load(RulesetStore rulesets)
|
|
||||||
{
|
|
||||||
this.rulesets = rulesets;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,83 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using osu.Game.Screens.Tournament;
|
|
||||||
using osu.Game.Screens.Tournament.Teams;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseDrawings : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => "Tournament drawings";
|
|
||||||
|
|
||||||
public TestCaseDrawings()
|
|
||||||
{
|
|
||||||
Add(new Drawings
|
|
||||||
{
|
|
||||||
TeamList = new TestTeamList(),
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private class TestTeamList : ITeamList
|
|
||||||
{
|
|
||||||
public IEnumerable<DrawingsTeam> Teams { get; } = new[]
|
|
||||||
{
|
|
||||||
new DrawingsTeam
|
|
||||||
{
|
|
||||||
FlagName = "GB",
|
|
||||||
FullName = "United Kingdom",
|
|
||||||
Acronym = "UK"
|
|
||||||
},
|
|
||||||
new DrawingsTeam
|
|
||||||
{
|
|
||||||
FlagName = "FR",
|
|
||||||
FullName = "France",
|
|
||||||
Acronym = "FRA"
|
|
||||||
},
|
|
||||||
new DrawingsTeam
|
|
||||||
{
|
|
||||||
FlagName = "CN",
|
|
||||||
FullName = "China",
|
|
||||||
Acronym = "CHN"
|
|
||||||
},
|
|
||||||
new DrawingsTeam
|
|
||||||
{
|
|
||||||
FlagName = "AU",
|
|
||||||
FullName = "Australia",
|
|
||||||
Acronym = "AUS"
|
|
||||||
},
|
|
||||||
new DrawingsTeam
|
|
||||||
{
|
|
||||||
FlagName = "JP",
|
|
||||||
FullName = "Japan",
|
|
||||||
Acronym = "JPN"
|
|
||||||
},
|
|
||||||
new DrawingsTeam
|
|
||||||
{
|
|
||||||
FlagName = "RO",
|
|
||||||
FullName = "Romania",
|
|
||||||
Acronym = "ROM"
|
|
||||||
},
|
|
||||||
new DrawingsTeam
|
|
||||||
{
|
|
||||||
FlagName = "IT",
|
|
||||||
FullName = "Italy",
|
|
||||||
Acronym = "PIZZA"
|
|
||||||
},
|
|
||||||
new DrawingsTeam
|
|
||||||
{
|
|
||||||
FlagName = "VE",
|
|
||||||
FullName = "Venezuela",
|
|
||||||
Acronym = "VNZ"
|
|
||||||
},
|
|
||||||
new DrawingsTeam
|
|
||||||
{
|
|
||||||
FlagName = "US",
|
|
||||||
FullName = "United States of America",
|
|
||||||
Acronym = "USA"
|
|
||||||
},
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,84 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Game.Graphics.UserInterface;
|
|
||||||
using osu.Game.Screens.Edit.Menus;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
public class TestCaseEditorMenuBar : OsuTestCase
|
|
||||||
{
|
|
||||||
public TestCaseEditorMenuBar()
|
|
||||||
{
|
|
||||||
Add(new EditorMenuBar
|
|
||||||
{
|
|
||||||
Anchor = Anchor.TopCentre,
|
|
||||||
Origin = Anchor.TopCentre,
|
|
||||||
Y = 50,
|
|
||||||
Items = new[]
|
|
||||||
{
|
|
||||||
new EditorMenuBarItem("File")
|
|
||||||
{
|
|
||||||
Items = new[]
|
|
||||||
{
|
|
||||||
new EditorMenuItem("Clear All Notes"),
|
|
||||||
new EditorMenuItem("Open Difficulty..."),
|
|
||||||
new EditorMenuItem("Save"),
|
|
||||||
new EditorMenuItem("Create a new Difficulty..."),
|
|
||||||
new EditorMenuItemSpacer(),
|
|
||||||
new EditorMenuItem("Revert to Saved"),
|
|
||||||
new EditorMenuItem("Revert to Saved (Full)"),
|
|
||||||
new EditorMenuItemSpacer(),
|
|
||||||
new EditorMenuItem("Test Beatmap"),
|
|
||||||
new EditorMenuItem("Open AiMod"),
|
|
||||||
new EditorMenuItemSpacer(),
|
|
||||||
new EditorMenuItem("Upload Beatmap..."),
|
|
||||||
new EditorMenuItem("Export Package"),
|
|
||||||
new EditorMenuItem("Export Map Package"),
|
|
||||||
new EditorMenuItem("Import from..."),
|
|
||||||
new EditorMenuItemSpacer(),
|
|
||||||
new EditorMenuItem("Open Song Folder"),
|
|
||||||
new EditorMenuItem("Open .osu in Notepad"),
|
|
||||||
new EditorMenuItem("Open .osb in Notepad"),
|
|
||||||
new EditorMenuItemSpacer(),
|
|
||||||
new EditorMenuItem("Exit"),
|
|
||||||
}
|
|
||||||
},
|
|
||||||
new EditorMenuBarItem("Timing")
|
|
||||||
{
|
|
||||||
Items = new[]
|
|
||||||
{
|
|
||||||
new EditorMenuItem("Time Signature"),
|
|
||||||
new EditorMenuItem("Metronome Clicks"),
|
|
||||||
new EditorMenuItemSpacer(),
|
|
||||||
new EditorMenuItem("Add Timing Section"),
|
|
||||||
new EditorMenuItem("Add Inheriting Section"),
|
|
||||||
new EditorMenuItem("Reset Current Section"),
|
|
||||||
new EditorMenuItem("Delete Timing Section"),
|
|
||||||
new EditorMenuItem("Resnap Current Section"),
|
|
||||||
new EditorMenuItemSpacer(),
|
|
||||||
new EditorMenuItem("Timing Setup"),
|
|
||||||
new EditorMenuItemSpacer(),
|
|
||||||
new EditorMenuItem("Resnap All Notes", MenuItemType.Destructive),
|
|
||||||
new EditorMenuItem("Move all notes in time...", MenuItemType.Destructive),
|
|
||||||
new EditorMenuItem("Recalculate Slider Lengths", MenuItemType.Destructive),
|
|
||||||
new EditorMenuItem("Delete All Timing Sections", MenuItemType.Destructive),
|
|
||||||
new EditorMenuItemSpacer(),
|
|
||||||
new EditorMenuItem("Set Current Position as Preview Point"),
|
|
||||||
}
|
|
||||||
},
|
|
||||||
new EditorMenuBarItem("Testing")
|
|
||||||
{
|
|
||||||
Items = new[]
|
|
||||||
{
|
|
||||||
new EditorMenuItem("Item 1"),
|
|
||||||
new EditorMenuItem("Item 2"),
|
|
||||||
new EditorMenuItem("Item 3"),
|
|
||||||
}
|
|
||||||
},
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,120 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using osu.Desktop.Tests.Beatmaps;
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Framework.MathUtils;
|
|
||||||
using osu.Framework.Timing;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Game.Beatmaps.ControlPoints;
|
|
||||||
using osu.Game.Rulesets;
|
|
||||||
using osu.Game.Rulesets.Catch;
|
|
||||||
using osu.Game.Rulesets.Catch.UI;
|
|
||||||
using osu.Game.Rulesets.Mania;
|
|
||||||
using osu.Game.Rulesets.Mania.UI;
|
|
||||||
using osu.Game.Rulesets.Objects;
|
|
||||||
using osu.Game.Rulesets.Osu;
|
|
||||||
using osu.Game.Rulesets.Osu.Objects;
|
|
||||||
using osu.Game.Rulesets.Osu.UI;
|
|
||||||
using osu.Game.Rulesets.Taiko;
|
|
||||||
using osu.Game.Rulesets.Taiko.UI;
|
|
||||||
using OpenTK;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseGamefield : OsuTestCase
|
|
||||||
{
|
|
||||||
private RulesetStore rulesets;
|
|
||||||
|
|
||||||
public override string Description => @"Showing hitobjects and what not.";
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load(RulesetStore rulesets)
|
|
||||||
{
|
|
||||||
this.rulesets = rulesets;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void LoadComplete()
|
|
||||||
{
|
|
||||||
base.LoadComplete();
|
|
||||||
|
|
||||||
List<HitObject> objects = new List<HitObject>();
|
|
||||||
|
|
||||||
int time = 500;
|
|
||||||
for (int i = 0; i < 100; i++)
|
|
||||||
{
|
|
||||||
objects.Add(new HitCircle
|
|
||||||
{
|
|
||||||
StartTime = time,
|
|
||||||
Position = new Vector2(RNG.Next(0, (int)OsuPlayfield.BASE_SIZE.X), RNG.Next(0, (int)OsuPlayfield.BASE_SIZE.Y)),
|
|
||||||
Scale = RNG.NextSingle(0.5f, 1.0f),
|
|
||||||
});
|
|
||||||
|
|
||||||
time += RNG.Next(50, 500);
|
|
||||||
}
|
|
||||||
|
|
||||||
var controlPointInfo = new ControlPointInfo();
|
|
||||||
controlPointInfo.TimingPoints.Add(new TimingControlPoint
|
|
||||||
{
|
|
||||||
BeatLength = 200
|
|
||||||
});
|
|
||||||
|
|
||||||
WorkingBeatmap beatmap = new TestWorkingBeatmap(new Beatmap
|
|
||||||
{
|
|
||||||
HitObjects = objects,
|
|
||||||
BeatmapInfo = new BeatmapInfo
|
|
||||||
{
|
|
||||||
Difficulty = new BeatmapDifficulty(),
|
|
||||||
Ruleset = rulesets.Query<RulesetInfo>().First(),
|
|
||||||
Metadata = new BeatmapMetadata
|
|
||||||
{
|
|
||||||
Artist = @"Unknown",
|
|
||||||
Title = @"Sample Beatmap",
|
|
||||||
Author = @"peppy",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
ControlPointInfo = controlPointInfo
|
|
||||||
});
|
|
||||||
|
|
||||||
AddRange(new Drawable[]
|
|
||||||
{
|
|
||||||
new Container
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
//ensure we are at offset 0
|
|
||||||
Clock = new FramedClock(),
|
|
||||||
Children = new Drawable[]
|
|
||||||
{
|
|
||||||
new OsuRulesetContainer(new OsuRuleset(new RulesetInfo()), beatmap, false)
|
|
||||||
{
|
|
||||||
Scale = new Vector2(0.5f),
|
|
||||||
Anchor = Anchor.TopLeft,
|
|
||||||
Origin = Anchor.TopLeft
|
|
||||||
},
|
|
||||||
new TaikoRulesetContainer(new TaikoRuleset(new RulesetInfo()),beatmap, false)
|
|
||||||
{
|
|
||||||
Scale = new Vector2(0.5f),
|
|
||||||
Anchor = Anchor.TopRight,
|
|
||||||
Origin = Anchor.TopRight
|
|
||||||
},
|
|
||||||
new CatchRulesetContainer(new CatchRuleset(new RulesetInfo()),beatmap, false)
|
|
||||||
{
|
|
||||||
Scale = new Vector2(0.5f),
|
|
||||||
Anchor = Anchor.BottomLeft,
|
|
||||||
Origin = Anchor.BottomLeft
|
|
||||||
},
|
|
||||||
new ManiaRulesetContainer(new ManiaRuleset(new RulesetInfo()),beatmap, false)
|
|
||||||
{
|
|
||||||
Scale = new Vector2(0.5f),
|
|
||||||
Anchor = Anchor.BottomRight,
|
|
||||||
Origin = Anchor.BottomRight
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,39 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System.Linq;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Game.Graphics.UserInterface;
|
|
||||||
using OpenTK;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseGraph : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => "graph";
|
|
||||||
|
|
||||||
public TestCaseGraph()
|
|
||||||
{
|
|
||||||
BarGraph graph;
|
|
||||||
|
|
||||||
Children = new[]
|
|
||||||
{
|
|
||||||
graph = new BarGraph
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
Size = new Vector2(0.5f),
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
AddStep("values from 1-10", () => graph.Values = Enumerable.Range(1, 10).Select(i => (float)i));
|
|
||||||
AddStep("values from 1-100", () => graph.Values = Enumerable.Range(1, 100).Select(i => (float)i));
|
|
||||||
AddStep("reversed values from 1-10", () => graph.Values = Enumerable.Range(1, 10).Reverse().Select(i => (float)i));
|
|
||||||
AddStep("Bottom to top", () => graph.Direction = BarDirection.BottomToTop);
|
|
||||||
AddStep("Top to bottom", () => graph.Direction = BarDirection.TopToBottom);
|
|
||||||
AddStep("Left to right", () => graph.Direction = BarDirection.LeftToRight);
|
|
||||||
AddStep("Right to left", () => graph.Direction = BarDirection.RightToLeft);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,127 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Framework.Timing;
|
|
||||||
using osu.Game.Rulesets.Objects.Drawables;
|
|
||||||
using osu.Game.Rulesets.Osu.Objects;
|
|
||||||
using osu.Game.Rulesets.Osu.Objects.Drawables;
|
|
||||||
using OpenTK;
|
|
||||||
using osu.Game.Rulesets.Osu;
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Game.Rulesets;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseHitObjects : OsuTestCase
|
|
||||||
{
|
|
||||||
private FramedClock framedClock;
|
|
||||||
|
|
||||||
private bool auto;
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load(RulesetStore rulesets)
|
|
||||||
{
|
|
||||||
var rateAdjustClock = new StopwatchClock(true);
|
|
||||||
framedClock = new FramedClock(rateAdjustClock);
|
|
||||||
|
|
||||||
AddStep(@"circles", () => loadHitobjects(HitObjectType.Circle));
|
|
||||||
AddStep(@"slider", () => loadHitobjects(HitObjectType.Slider));
|
|
||||||
AddStep(@"spinner", () => loadHitobjects(HitObjectType.Spinner));
|
|
||||||
|
|
||||||
AddToggleStep("Auto", state => { auto = state; loadHitobjects(mode); });
|
|
||||||
AddSliderStep("Playback speed", 0.0, 2.0, 0.5, v => rateAdjustClock.Rate = v);
|
|
||||||
|
|
||||||
framedClock.ProcessFrame();
|
|
||||||
|
|
||||||
var clockAdjustContainer = new Container
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Clock = framedClock,
|
|
||||||
Children = new[]
|
|
||||||
{
|
|
||||||
playfieldContainer = new OsuInputManager(rulesets.GetRuleset(0)) { RelativeSizeAxes = Axes.Both },
|
|
||||||
approachContainer = new Container { RelativeSizeAxes = Axes.Both }
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
Add(clockAdjustContainer);
|
|
||||||
}
|
|
||||||
|
|
||||||
private HitObjectType mode = HitObjectType.Slider;
|
|
||||||
|
|
||||||
private Container playfieldContainer;
|
|
||||||
private Container approachContainer;
|
|
||||||
|
|
||||||
private void loadHitobjects(HitObjectType mode)
|
|
||||||
{
|
|
||||||
this.mode = mode;
|
|
||||||
|
|
||||||
switch (mode)
|
|
||||||
{
|
|
||||||
case HitObjectType.Circle:
|
|
||||||
const int count = 10;
|
|
||||||
|
|
||||||
for (int i = 0; i < count; i++)
|
|
||||||
{
|
|
||||||
var h = new HitCircle
|
|
||||||
{
|
|
||||||
StartTime = framedClock.CurrentTime + 600 + i * 80,
|
|
||||||
Position = new Vector2((i - count / 2) * 14),
|
|
||||||
};
|
|
||||||
|
|
||||||
add(new DrawableHitCircle(h));
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case HitObjectType.Slider:
|
|
||||||
add(new DrawableSlider(new Slider
|
|
||||||
{
|
|
||||||
StartTime = framedClock.CurrentTime + 600,
|
|
||||||
ControlPoints = new List<Vector2>
|
|
||||||
{
|
|
||||||
new Vector2(-200, 0),
|
|
||||||
new Vector2(400, 0),
|
|
||||||
},
|
|
||||||
Distance = 400,
|
|
||||||
Position = new Vector2(-200, 0),
|
|
||||||
Velocity = 1,
|
|
||||||
TickDistance = 100,
|
|
||||||
}));
|
|
||||||
break;
|
|
||||||
case HitObjectType.Spinner:
|
|
||||||
add(new DrawableSpinner(new Spinner
|
|
||||||
{
|
|
||||||
StartTime = framedClock.CurrentTime + 600,
|
|
||||||
EndTime = framedClock.CurrentTime + 1600,
|
|
||||||
Position = new Vector2(0, 0),
|
|
||||||
}));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private int depth;
|
|
||||||
|
|
||||||
private void add(DrawableOsuHitObject h)
|
|
||||||
{
|
|
||||||
h.Anchor = Anchor.Centre;
|
|
||||||
h.Depth = depth++;
|
|
||||||
|
|
||||||
if (auto)
|
|
||||||
h.State = ArmedState.Hit;
|
|
||||||
|
|
||||||
playfieldContainer.Add(h);
|
|
||||||
var proxyable = h as IDrawableHitObjectWithProxiedApproach;
|
|
||||||
if (proxyable != null)
|
|
||||||
approachContainer.Add(proxyable.ProxiedLayer.CreateProxy());
|
|
||||||
}
|
|
||||||
|
|
||||||
private enum HitObjectType
|
|
||||||
{
|
|
||||||
Circle,
|
|
||||||
Slider,
|
|
||||||
Spinner
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,25 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Game.Overlays;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
public class TestCaseKeyConfiguration : OsuTestCase
|
|
||||||
{
|
|
||||||
private readonly KeyBindingOverlay overlay;
|
|
||||||
|
|
||||||
public override string Description => @"Key configuration";
|
|
||||||
|
|
||||||
public TestCaseKeyConfiguration()
|
|
||||||
{
|
|
||||||
Child = overlay = new KeyBindingOverlay();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void LoadComplete()
|
|
||||||
{
|
|
||||||
base.LoadComplete();
|
|
||||||
overlay.Show();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,41 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.MathUtils;
|
|
||||||
using osu.Game.Screens.Play;
|
|
||||||
using OpenTK.Input;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseKeyCounter : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Tests key counter";
|
|
||||||
|
|
||||||
public TestCaseKeyCounter()
|
|
||||||
{
|
|
||||||
KeyCounterCollection kc = new KeyCounterCollection
|
|
||||||
{
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
IsCounting = true,
|
|
||||||
Children = new KeyCounter[]
|
|
||||||
{
|
|
||||||
new KeyCounterKeyboard(Key.Z),
|
|
||||||
new KeyCounterKeyboard(Key.X),
|
|
||||||
new KeyCounterMouse(MouseButton.Left),
|
|
||||||
new KeyCounterMouse(MouseButton.Right),
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
AddStep("Add random", () =>
|
|
||||||
{
|
|
||||||
Key key = (Key)((int)Key.A + RNG.Next(26));
|
|
||||||
kc.Add(new KeyCounterKeyboard(key));
|
|
||||||
});
|
|
||||||
AddSliderStep("Fade time", 0, 200, 50, v => kc.FadeTime = v);
|
|
||||||
|
|
||||||
Add(kc);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,222 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using OpenTK;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Game.Rulesets.Mods;
|
|
||||||
using osu.Game.Rulesets.Osu.Mods;
|
|
||||||
using osu.Game.Rulesets.Scoring;
|
|
||||||
using osu.Game.Screens.Select.Leaderboards;
|
|
||||||
using osu.Game.Users;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseLeaderboard : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"From song select";
|
|
||||||
|
|
||||||
private readonly Leaderboard leaderboard;
|
|
||||||
|
|
||||||
private void newScores()
|
|
||||||
{
|
|
||||||
var scores = new[]
|
|
||||||
{
|
|
||||||
new Score
|
|
||||||
{
|
|
||||||
Rank = ScoreRank.XH,
|
|
||||||
Accuracy = 1,
|
|
||||||
MaxCombo = 244,
|
|
||||||
TotalScore = 1707827,
|
|
||||||
Mods = new Mod[] { new OsuModHidden(), new OsuModHardRock(), },
|
|
||||||
User = new User
|
|
||||||
{
|
|
||||||
Id = 6602580,
|
|
||||||
Username = @"waaiiru",
|
|
||||||
Country = new Country
|
|
||||||
{
|
|
||||||
FullName = @"Spain",
|
|
||||||
FlagName = @"ES",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
new Score
|
|
||||||
{
|
|
||||||
Rank = ScoreRank.X,
|
|
||||||
Accuracy = 1,
|
|
||||||
MaxCombo = 244,
|
|
||||||
TotalScore = 1707827,
|
|
||||||
Mods = new Mod[] { new OsuModHidden(), new OsuModHardRock(), },
|
|
||||||
User = new User
|
|
||||||
{
|
|
||||||
Id = 4608074,
|
|
||||||
Username = @"Skycries",
|
|
||||||
Country = new Country
|
|
||||||
{
|
|
||||||
FullName = @"Brazil",
|
|
||||||
FlagName = @"BR",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
new Score
|
|
||||||
{
|
|
||||||
Rank = ScoreRank.SH,
|
|
||||||
Accuracy = 1,
|
|
||||||
MaxCombo = 244,
|
|
||||||
TotalScore = 1707827,
|
|
||||||
Mods = new Mod[] { new OsuModHidden(), new OsuModHardRock(), },
|
|
||||||
User = new User
|
|
||||||
{
|
|
||||||
Id = 1014222,
|
|
||||||
Username = @"eLy",
|
|
||||||
Country = new Country
|
|
||||||
{
|
|
||||||
FullName = @"Japan",
|
|
||||||
FlagName = @"JP",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
new Score
|
|
||||||
{
|
|
||||||
Rank = ScoreRank.S,
|
|
||||||
Accuracy = 1,
|
|
||||||
MaxCombo = 244,
|
|
||||||
TotalScore = 1707827,
|
|
||||||
Mods = new Mod[] { new OsuModHidden(), new OsuModHardRock(), },
|
|
||||||
User = new User
|
|
||||||
{
|
|
||||||
Id = 1541390,
|
|
||||||
Username = @"Toukai",
|
|
||||||
Country = new Country
|
|
||||||
{
|
|
||||||
FullName = @"Canada",
|
|
||||||
FlagName = @"CA",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
new Score
|
|
||||||
{
|
|
||||||
Rank = ScoreRank.A,
|
|
||||||
Accuracy = 1,
|
|
||||||
MaxCombo = 244,
|
|
||||||
TotalScore = 1707827,
|
|
||||||
Mods = new Mod[] { new OsuModHidden(), new OsuModHardRock(), },
|
|
||||||
User = new User
|
|
||||||
{
|
|
||||||
Id = 2243452,
|
|
||||||
Username = @"Satoruu",
|
|
||||||
Country = new Country
|
|
||||||
{
|
|
||||||
FullName = @"Venezuela",
|
|
||||||
FlagName = @"VE",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
new Score
|
|
||||||
{
|
|
||||||
Rank = ScoreRank.B,
|
|
||||||
Accuracy = 0.9826,
|
|
||||||
MaxCombo = 244,
|
|
||||||
TotalScore = 1707827,
|
|
||||||
Mods = new Mod[] { new OsuModHidden(), new OsuModHardRock(), },
|
|
||||||
User = new User
|
|
||||||
{
|
|
||||||
Id = 2705430,
|
|
||||||
Username = @"Mooha",
|
|
||||||
Country = new Country
|
|
||||||
{
|
|
||||||
FullName = @"France",
|
|
||||||
FlagName = @"FR",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
new Score
|
|
||||||
{
|
|
||||||
Rank = ScoreRank.C,
|
|
||||||
Accuracy = 0.9654,
|
|
||||||
MaxCombo = 244,
|
|
||||||
TotalScore = 1707827,
|
|
||||||
Mods = new Mod[] { new OsuModHidden(), new OsuModHardRock(), },
|
|
||||||
User = new User
|
|
||||||
{
|
|
||||||
Id = 7151382,
|
|
||||||
Username = @"Mayuri Hana",
|
|
||||||
Country = new Country
|
|
||||||
{
|
|
||||||
FullName = @"Thailand",
|
|
||||||
FlagName = @"TH",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
new Score
|
|
||||||
{
|
|
||||||
Rank = ScoreRank.F,
|
|
||||||
Accuracy = 0.6025,
|
|
||||||
MaxCombo = 244,
|
|
||||||
TotalScore = 1707827,
|
|
||||||
Mods = new Mod[] { new OsuModHidden(), new OsuModHardRock(), },
|
|
||||||
User = new User
|
|
||||||
{
|
|
||||||
Id = 2051389,
|
|
||||||
Username = @"FunOrange",
|
|
||||||
Country = new Country
|
|
||||||
{
|
|
||||||
FullName = @"Canada",
|
|
||||||
FlagName = @"CA",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
new Score
|
|
||||||
{
|
|
||||||
Rank = ScoreRank.F,
|
|
||||||
Accuracy = 0.5140,
|
|
||||||
MaxCombo = 244,
|
|
||||||
TotalScore = 1707827,
|
|
||||||
Mods = new Mod[] { new OsuModHidden(), new OsuModHardRock(), },
|
|
||||||
User = new User
|
|
||||||
{
|
|
||||||
Id = 6169483,
|
|
||||||
Username = @"-Hebel-",
|
|
||||||
Country = new Country
|
|
||||||
{
|
|
||||||
FullName = @"Mexico",
|
|
||||||
FlagName = @"MX",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
new Score
|
|
||||||
{
|
|
||||||
Rank = ScoreRank.F,
|
|
||||||
Accuracy = 0.4222,
|
|
||||||
MaxCombo = 244,
|
|
||||||
TotalScore = 1707827,
|
|
||||||
Mods = new Mod[] { new OsuModHidden(), new OsuModHardRock(), },
|
|
||||||
User = new User
|
|
||||||
{
|
|
||||||
Id = 6702666,
|
|
||||||
Username = @"prhtnsm",
|
|
||||||
Country = new Country
|
|
||||||
{
|
|
||||||
FullName = @"Germany",
|
|
||||||
FlagName = @"DE",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
leaderboard.Scores = scores;
|
|
||||||
}
|
|
||||||
|
|
||||||
public TestCaseLeaderboard()
|
|
||||||
{
|
|
||||||
Add(leaderboard = new Leaderboard
|
|
||||||
{
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Size = new Vector2(550f, 450f),
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep(@"New Scores", newScores);
|
|
||||||
newScores();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,94 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Game.Rulesets.Mania;
|
|
||||||
using osu.Game.Rulesets.Mania.Objects;
|
|
||||||
using osu.Game.Rulesets.Mania.Objects.Drawables;
|
|
||||||
using OpenTK;
|
|
||||||
using OpenTK.Graphics;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseManiaHitObjects : OsuTestCase
|
|
||||||
{
|
|
||||||
public TestCaseManiaHitObjects()
|
|
||||||
{
|
|
||||||
Add(new FillFlowContainer
|
|
||||||
{
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
RelativeSizeAxes = Axes.Y,
|
|
||||||
Direction = FillDirection.Horizontal,
|
|
||||||
Spacing = new Vector2(10, 0),
|
|
||||||
// Imagine that the containers containing the drawable notes are the "columns"
|
|
||||||
Children = new Drawable[]
|
|
||||||
{
|
|
||||||
new Container
|
|
||||||
{
|
|
||||||
Name = "Normal note column",
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
RelativeSizeAxes = Axes.Y,
|
|
||||||
Width = 50,
|
|
||||||
Children = new[]
|
|
||||||
{
|
|
||||||
new Container
|
|
||||||
{
|
|
||||||
Name = "Timing section",
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
RelativeChildSize = new Vector2(1, 10000),
|
|
||||||
Children = new[]
|
|
||||||
{
|
|
||||||
new DrawableNote(new Note(), ManiaAction.Key1)
|
|
||||||
{
|
|
||||||
Y = 5000,
|
|
||||||
LifetimeStart = double.MinValue,
|
|
||||||
LifetimeEnd = double.MaxValue,
|
|
||||||
AccentColour = Color4.Red
|
|
||||||
},
|
|
||||||
new DrawableNote(new Note(), ManiaAction.Key1)
|
|
||||||
{
|
|
||||||
Y = 6000,
|
|
||||||
LifetimeStart = double.MinValue,
|
|
||||||
LifetimeEnd = double.MaxValue,
|
|
||||||
AccentColour = Color4.Red
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
new Container
|
|
||||||
{
|
|
||||||
Name = "Hold note column",
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
RelativeSizeAxes = Axes.Y,
|
|
||||||
Width = 50,
|
|
||||||
Children = new[]
|
|
||||||
{
|
|
||||||
new Container
|
|
||||||
{
|
|
||||||
Name = "Timing section",
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
RelativeChildSize = new Vector2(1, 10000),
|
|
||||||
Children = new[]
|
|
||||||
{
|
|
||||||
new DrawableHoldNote(new HoldNote(), ManiaAction.Key1)
|
|
||||||
{
|
|
||||||
Y = 5000,
|
|
||||||
Height = 1000,
|
|
||||||
LifetimeStart = double.MinValue,
|
|
||||||
LifetimeEnd = double.MaxValue,
|
|
||||||
AccentColour = Color4.Red
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,162 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Linq;
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Framework.Extensions.IEnumerableExtensions;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Timing;
|
|
||||||
using osu.Game.Rulesets.Mania;
|
|
||||||
using osu.Game.Rulesets.Mania.Objects;
|
|
||||||
using osu.Game.Rulesets.Mania.Objects.Drawables;
|
|
||||||
using osu.Game.Rulesets.Mania.Timing;
|
|
||||||
using osu.Game.Rulesets.Mania.UI;
|
|
||||||
using osu.Game.Rulesets.Timing;
|
|
||||||
using osu.Game.Rulesets;
|
|
||||||
using osu.Game.Rulesets.Mania.Judgements;
|
|
||||||
using osu.Game.Rulesets.Objects.Drawables;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseManiaPlayfield : OsuTestCase
|
|
||||||
{
|
|
||||||
private const double start_time = 500;
|
|
||||||
private const double duration = 500;
|
|
||||||
|
|
||||||
public override string Description => @"Mania playfield";
|
|
||||||
|
|
||||||
protected override double TimePerAction => 200;
|
|
||||||
|
|
||||||
private RulesetInfo maniaRuleset;
|
|
||||||
|
|
||||||
public TestCaseManiaPlayfield()
|
|
||||||
{
|
|
||||||
var rng = new Random(1337);
|
|
||||||
|
|
||||||
AddStep("1 column", () => createPlayfield(1, SpecialColumnPosition.Normal));
|
|
||||||
AddStep("4 columns", () => createPlayfield(4, SpecialColumnPosition.Normal));
|
|
||||||
AddStep("Left special style", () => createPlayfield(4, SpecialColumnPosition.Left));
|
|
||||||
AddStep("Right special style", () => createPlayfield(4, SpecialColumnPosition.Right));
|
|
||||||
AddStep("5 columns", () => createPlayfield(5, SpecialColumnPosition.Normal));
|
|
||||||
AddStep("8 columns", () => createPlayfield(8, SpecialColumnPosition.Normal));
|
|
||||||
AddStep("Left special style", () => createPlayfield(8, SpecialColumnPosition.Left));
|
|
||||||
AddStep("Right special style", () => createPlayfield(8, SpecialColumnPosition.Right));
|
|
||||||
AddStep("Reversed", () => createPlayfield(4, SpecialColumnPosition.Normal, true));
|
|
||||||
|
|
||||||
AddStep("Notes with input", () => createPlayfieldWithNotes(false));
|
|
||||||
AddStep("Notes with input (reversed)", () => createPlayfieldWithNotes(false, true));
|
|
||||||
AddStep("Notes with gravity", () => createPlayfieldWithNotes(true));
|
|
||||||
AddStep("Notes with gravity (reversed)", () => createPlayfieldWithNotes(true, true));
|
|
||||||
|
|
||||||
AddStep("Hit explosion", () =>
|
|
||||||
{
|
|
||||||
var playfield = createPlayfield(4, SpecialColumnPosition.Normal);
|
|
||||||
|
|
||||||
int col = rng.Next(0, 4);
|
|
||||||
|
|
||||||
var note = new DrawableNote(new Note { Column = col }, ManiaAction.Key1)
|
|
||||||
{
|
|
||||||
AccentColour = playfield.Columns.ElementAt(col).AccentColour
|
|
||||||
};
|
|
||||||
|
|
||||||
playfield.OnJudgement(note, new ManiaJudgement { Result = HitResult.Perfect });
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load(RulesetStore rulesets)
|
|
||||||
{
|
|
||||||
maniaRuleset = rulesets.GetRuleset(3);
|
|
||||||
}
|
|
||||||
|
|
||||||
private SpeedAdjustmentContainer createTimingChange(double time, bool gravity) => new ManiaSpeedAdjustmentContainer(new MultiplierControlPoint(time)
|
|
||||||
{
|
|
||||||
TimingPoint = { BeatLength = 1000 }
|
|
||||||
}, gravity ? ScrollingAlgorithm.Gravity : ScrollingAlgorithm.Basic);
|
|
||||||
|
|
||||||
private ManiaPlayfield createPlayfield(int cols, SpecialColumnPosition specialPos, bool inverted = false)
|
|
||||||
{
|
|
||||||
Clear();
|
|
||||||
|
|
||||||
var inputManager = new ManiaInputManager(maniaRuleset, cols) { RelativeSizeAxes = Axes.Both };
|
|
||||||
Add(inputManager);
|
|
||||||
|
|
||||||
ManiaPlayfield playfield;
|
|
||||||
inputManager.Add(playfield = new ManiaPlayfield(cols)
|
|
||||||
{
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
SpecialColumnPosition = specialPos
|
|
||||||
});
|
|
||||||
|
|
||||||
playfield.Inverted.Value = inverted;
|
|
||||||
|
|
||||||
return playfield;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void createPlayfieldWithNotes(bool gravity, bool inverted = false)
|
|
||||||
{
|
|
||||||
Clear();
|
|
||||||
|
|
||||||
var rateAdjustClock = new StopwatchClock(true) { Rate = 1 };
|
|
||||||
|
|
||||||
var inputManager = new ManiaInputManager(maniaRuleset, 4) { RelativeSizeAxes = Axes.Both };
|
|
||||||
Add(inputManager);
|
|
||||||
|
|
||||||
ManiaPlayfield playfield;
|
|
||||||
inputManager.Add(playfield = new ManiaPlayfield(4)
|
|
||||||
{
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
Clock = new FramedClock(rateAdjustClock)
|
|
||||||
});
|
|
||||||
|
|
||||||
playfield.Inverted.Value = inverted;
|
|
||||||
|
|
||||||
if (!gravity)
|
|
||||||
playfield.Columns.ForEach(c => c.Add(createTimingChange(0, false)));
|
|
||||||
|
|
||||||
for (double t = start_time; t <= start_time + duration; t += 100)
|
|
||||||
{
|
|
||||||
if (gravity)
|
|
||||||
playfield.Columns.ElementAt(0).Add(createTimingChange(t, true));
|
|
||||||
|
|
||||||
playfield.Add(new DrawableNote(new Note
|
|
||||||
{
|
|
||||||
StartTime = t,
|
|
||||||
Column = 0
|
|
||||||
}, ManiaAction.Key1));
|
|
||||||
|
|
||||||
if (gravity)
|
|
||||||
playfield.Columns.ElementAt(3).Add(createTimingChange(t, true));
|
|
||||||
|
|
||||||
playfield.Add(new DrawableNote(new Note
|
|
||||||
{
|
|
||||||
StartTime = t,
|
|
||||||
Column = 3
|
|
||||||
}, ManiaAction.Key4));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (gravity)
|
|
||||||
playfield.Columns.ElementAt(1).Add(createTimingChange(start_time, true));
|
|
||||||
|
|
||||||
playfield.Add(new DrawableHoldNote(new HoldNote
|
|
||||||
{
|
|
||||||
StartTime = start_time,
|
|
||||||
Duration = duration,
|
|
||||||
Column = 1
|
|
||||||
}, ManiaAction.Key2));
|
|
||||||
|
|
||||||
if (gravity)
|
|
||||||
playfield.Columns.ElementAt(2).Add(createTimingChange(start_time, true));
|
|
||||||
|
|
||||||
playfield.Add(new DrawableHoldNote(new HoldNote
|
|
||||||
{
|
|
||||||
StartTime = start_time,
|
|
||||||
Duration = duration,
|
|
||||||
Column = 2
|
|
||||||
}, ManiaAction.Key3));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,26 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Game.Overlays;
|
|
||||||
using osu.Game.Users;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseMedalOverlay : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"medal get!";
|
|
||||||
|
|
||||||
public TestCaseMedalOverlay()
|
|
||||||
{
|
|
||||||
AddStep(@"display", () =>
|
|
||||||
{
|
|
||||||
LoadComponentAsync(new MedalOverlay(new Medal
|
|
||||||
{
|
|
||||||
Name = @"Animations",
|
|
||||||
InternalName = @"all-intro-doubletime",
|
|
||||||
Description = @"More complex than you think.",
|
|
||||||
}), Add);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,25 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Graphics.Colour;
|
|
||||||
using osu.Framework.Graphics.Shapes;
|
|
||||||
using osu.Game.Screens.Menu;
|
|
||||||
using OpenTK.Graphics;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseMenuButtonSystem : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Main menu button system";
|
|
||||||
|
|
||||||
public TestCaseMenuButtonSystem()
|
|
||||||
{
|
|
||||||
Add(new Box
|
|
||||||
{
|
|
||||||
Colour = ColourInfo.GradientVertical(Color4.Gray, Color4.WhiteSmoke),
|
|
||||||
RelativeSizeAxes = Framework.Graphics.Axes.Both,
|
|
||||||
});
|
|
||||||
Add(new ButtonSystem());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,57 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Framework.Logging;
|
|
||||||
using osu.Game.Screens.Play;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseMenuOverlays : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Tests pause and fail overlays";
|
|
||||||
|
|
||||||
public TestCaseMenuOverlays()
|
|
||||||
{
|
|
||||||
FailOverlay failOverlay;
|
|
||||||
PauseContainer.PauseOverlay pauseOverlay;
|
|
||||||
|
|
||||||
var retryCount = 0;
|
|
||||||
|
|
||||||
Add(pauseOverlay = new PauseContainer.PauseOverlay
|
|
||||||
{
|
|
||||||
OnResume = () => Logger.Log(@"Resume"),
|
|
||||||
OnRetry = () => Logger.Log(@"Retry"),
|
|
||||||
OnQuit = () => Logger.Log(@"Quit"),
|
|
||||||
});
|
|
||||||
Add(failOverlay = new FailOverlay
|
|
||||||
{
|
|
||||||
OnRetry = () => Logger.Log(@"Retry"),
|
|
||||||
OnQuit = () => Logger.Log(@"Quit"),
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep(@"Pause", delegate
|
|
||||||
{
|
|
||||||
if (failOverlay.State == Visibility.Visible)
|
|
||||||
{
|
|
||||||
failOverlay.Hide();
|
|
||||||
}
|
|
||||||
pauseOverlay.Show();
|
|
||||||
});
|
|
||||||
AddStep("Fail", delegate
|
|
||||||
{
|
|
||||||
if (pauseOverlay.State == Visibility.Visible)
|
|
||||||
{
|
|
||||||
pauseOverlay.Hide();
|
|
||||||
}
|
|
||||||
failOverlay.Show();
|
|
||||||
});
|
|
||||||
AddStep("Add Retry", delegate
|
|
||||||
{
|
|
||||||
retryCount++;
|
|
||||||
pauseOverlay.Retries = retryCount;
|
|
||||||
failOverlay.Retries = retryCount;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,56 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Game.Overlays.Mods;
|
|
||||||
using osu.Game.Rulesets;
|
|
||||||
using osu.Game.Screens.Play.HUD;
|
|
||||||
using OpenTK;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseMods : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Mod select overlay and in-game display";
|
|
||||||
|
|
||||||
private ModSelectOverlay modSelect;
|
|
||||||
private ModDisplay modDisplay;
|
|
||||||
|
|
||||||
private RulesetStore rulesets;
|
|
||||||
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load(RulesetStore rulesets)
|
|
||||||
{
|
|
||||||
this.rulesets = rulesets;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void LoadComplete()
|
|
||||||
{
|
|
||||||
base.LoadComplete();
|
|
||||||
|
|
||||||
Add(modSelect = new ModSelectOverlay
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.X,
|
|
||||||
Origin = Anchor.BottomCentre,
|
|
||||||
Anchor = Anchor.BottomCentre,
|
|
||||||
});
|
|
||||||
|
|
||||||
Add(modDisplay = new ModDisplay
|
|
||||||
{
|
|
||||||
Anchor = Anchor.TopRight,
|
|
||||||
Origin = Anchor.TopRight,
|
|
||||||
AutoSizeAxes = Axes.Both,
|
|
||||||
Position = new Vector2(0, 25),
|
|
||||||
});
|
|
||||||
|
|
||||||
modDisplay.Current.BindTo(modSelect.SelectedMods);
|
|
||||||
|
|
||||||
AddStep("Toggle", modSelect.ToggleVisibility);
|
|
||||||
|
|
||||||
foreach (var ruleset in rulesets.AllRulesets)
|
|
||||||
AddStep(ruleset.CreateInstance().Description, () => modSelect.Ruleset.Value = ruleset);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,43 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Framework.Configuration;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Framework.Timing;
|
|
||||||
using osu.Game;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Game.Overlays;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseMusicController : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Tests music controller ui.";
|
|
||||||
|
|
||||||
private readonly Bindable<WorkingBeatmap> beatmapBacking = new Bindable<WorkingBeatmap>();
|
|
||||||
|
|
||||||
public TestCaseMusicController()
|
|
||||||
{
|
|
||||||
Clock = new FramedClock();
|
|
||||||
|
|
||||||
var mc = new MusicController
|
|
||||||
{
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
Anchor = Anchor.Centre
|
|
||||||
};
|
|
||||||
Add(mc);
|
|
||||||
|
|
||||||
AddToggleStep(@"toggle visibility", state => mc.State = state ? Visibility.Visible : Visibility.Hidden);
|
|
||||||
AddStep(@"show", () => mc.State = Visibility.Visible);
|
|
||||||
AddToggleStep(@"toggle beatmap lock", state => beatmapBacking.Disabled = state);
|
|
||||||
}
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load(OsuGameBase game)
|
|
||||||
{
|
|
||||||
beatmapBacking.BindTo(game.Beatmap);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,113 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Linq;
|
|
||||||
using NUnit.Framework;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Framework.MathUtils;
|
|
||||||
using osu.Game.Overlays;
|
|
||||||
using osu.Game.Overlays.Notifications;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
[TestFixture]
|
|
||||||
internal class TestCaseNotificationOverlay : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"I handle notifications";
|
|
||||||
|
|
||||||
private readonly NotificationOverlay manager;
|
|
||||||
|
|
||||||
public TestCaseNotificationOverlay()
|
|
||||||
{
|
|
||||||
progressingNotifications.Clear();
|
|
||||||
|
|
||||||
Content.Add(manager = new NotificationOverlay
|
|
||||||
{
|
|
||||||
Anchor = Anchor.TopRight,
|
|
||||||
Origin = Anchor.TopRight,
|
|
||||||
});
|
|
||||||
|
|
||||||
AddToggleStep(@"show", state => manager.State = state ? Visibility.Visible : Visibility.Hidden);
|
|
||||||
|
|
||||||
AddStep(@"simple #1", sendNotification1);
|
|
||||||
AddStep(@"simple #2", sendNotification2);
|
|
||||||
AddStep(@"progress #1", sendProgress1);
|
|
||||||
AddStep(@"progress #2", sendProgress2);
|
|
||||||
AddStep(@"barrage", () => sendBarrage());
|
|
||||||
}
|
|
||||||
|
|
||||||
private void sendBarrage(int remaining = 100)
|
|
||||||
{
|
|
||||||
switch (RNG.Next(0, 4))
|
|
||||||
{
|
|
||||||
case 0:
|
|
||||||
sendNotification1();
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
sendNotification2();
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
sendProgress1();
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
sendProgress2();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (remaining > 0)
|
|
||||||
Scheduler.AddDelayed(() => sendBarrage(remaining - 1), 80);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void Update()
|
|
||||||
{
|
|
||||||
base.Update();
|
|
||||||
|
|
||||||
progressingNotifications.RemoveAll(n => n.State == ProgressNotificationState.Completed);
|
|
||||||
|
|
||||||
while (progressingNotifications.Count(n => n.State == ProgressNotificationState.Active) < 3)
|
|
||||||
{
|
|
||||||
var p = progressingNotifications.FirstOrDefault(n => n.IsAlive && n.State == ProgressNotificationState.Queued);
|
|
||||||
if (p == null)
|
|
||||||
break;
|
|
||||||
|
|
||||||
p.State = ProgressNotificationState.Active;
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach (var n in progressingNotifications.FindAll(n => n.State == ProgressNotificationState.Active))
|
|
||||||
{
|
|
||||||
if (n.Progress < 1)
|
|
||||||
n.Progress += (float)(Time.Elapsed / 2000) * RNG.NextSingle();
|
|
||||||
else
|
|
||||||
n.State = ProgressNotificationState.Completed;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void sendProgress2()
|
|
||||||
{
|
|
||||||
var n = new ProgressNotification { Text = @"Downloading Haitai..." };
|
|
||||||
manager.Post(n);
|
|
||||||
progressingNotifications.Add(n);
|
|
||||||
}
|
|
||||||
|
|
||||||
private readonly List<ProgressNotification> progressingNotifications = new List<ProgressNotification>();
|
|
||||||
|
|
||||||
private void sendProgress1()
|
|
||||||
{
|
|
||||||
var n = new ProgressNotification { Text = @"Uploading to BSS..." };
|
|
||||||
manager.Post(n);
|
|
||||||
progressingNotifications.Add(n);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void sendNotification2()
|
|
||||||
{
|
|
||||||
manager.Post(new SimpleNotification { Text = @"You are amazing" });
|
|
||||||
}
|
|
||||||
|
|
||||||
private void sendNotification1()
|
|
||||||
{
|
|
||||||
manager.Post(new SimpleNotification { Text = @"Welcome to osu!. Enjoy your stay!" });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,46 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Framework.Configuration;
|
|
||||||
using osu.Game.Overlays;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseOnScreenDisplay : OsuTestCase
|
|
||||||
{
|
|
||||||
private FrameworkConfigManager config;
|
|
||||||
private Bindable<FrameSync> frameSyncMode;
|
|
||||||
|
|
||||||
public override string Description => @"Make it easier to see setting changes";
|
|
||||||
|
|
||||||
protected override void LoadComplete()
|
|
||||||
{
|
|
||||||
base.LoadComplete();
|
|
||||||
|
|
||||||
Add(new OnScreenDisplay());
|
|
||||||
|
|
||||||
frameSyncMode = config.GetBindable<FrameSync>(FrameworkSetting.FrameSync);
|
|
||||||
|
|
||||||
FrameSync initial = frameSyncMode.Value;
|
|
||||||
|
|
||||||
AddRepeatStep(@"Change frame limiter", setNextMode, 3);
|
|
||||||
|
|
||||||
AddStep(@"Restore frame limiter", () => frameSyncMode.Value = initial);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setNextMode()
|
|
||||||
{
|
|
||||||
var nextMode = frameSyncMode.Value + 1;
|
|
||||||
if (nextMode > FrameSync.Unlimited)
|
|
||||||
nextMode = FrameSync.VSync;
|
|
||||||
frameSyncMode.Value = nextMode;
|
|
||||||
}
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load(FrameworkConfigManager config)
|
|
||||||
{
|
|
||||||
this.config = config;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,102 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using osu.Desktop.Tests.Platform;
|
|
||||||
using osu.Framework.MathUtils;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Game.Database;
|
|
||||||
using osu.Game.Rulesets;
|
|
||||||
using osu.Game.Screens.Select;
|
|
||||||
using osu.Game.Screens.Select.Filter;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCasePlaySongSelect : OsuTestCase
|
|
||||||
{
|
|
||||||
private readonly BeatmapManager manager;
|
|
||||||
|
|
||||||
public override string Description => @"with fake data";
|
|
||||||
|
|
||||||
private readonly RulesetStore rulesets;
|
|
||||||
|
|
||||||
public TestCasePlaySongSelect()
|
|
||||||
{
|
|
||||||
PlaySongSelect songSelect;
|
|
||||||
|
|
||||||
if (manager == null)
|
|
||||||
{
|
|
||||||
var storage = new TestStorage(@"TestCasePlaySongSelect");
|
|
||||||
|
|
||||||
var backingDatabase = storage.GetDatabase(@"client");
|
|
||||||
backingDatabase.CreateTable<StoreVersion>();
|
|
||||||
|
|
||||||
rulesets = new RulesetStore(backingDatabase);
|
|
||||||
manager = new BeatmapManager(storage, null, backingDatabase, rulesets, null);
|
|
||||||
|
|
||||||
for (int i = 0; i < 100; i += 10)
|
|
||||||
manager.Import(createTestBeatmapSet(i));
|
|
||||||
}
|
|
||||||
|
|
||||||
Add(songSelect = new PlaySongSelect());
|
|
||||||
|
|
||||||
AddStep(@"Sort by Artist", delegate { songSelect.FilterControl.Sort = SortMode.Artist; });
|
|
||||||
AddStep(@"Sort by Title", delegate { songSelect.FilterControl.Sort = SortMode.Title; });
|
|
||||||
AddStep(@"Sort by Author", delegate { songSelect.FilterControl.Sort = SortMode.Author; });
|
|
||||||
AddStep(@"Sort by Difficulty", delegate { songSelect.FilterControl.Sort = SortMode.Difficulty; });
|
|
||||||
}
|
|
||||||
|
|
||||||
private BeatmapSetInfo createTestBeatmapSet(int i)
|
|
||||||
{
|
|
||||||
return new BeatmapSetInfo
|
|
||||||
{
|
|
||||||
OnlineBeatmapSetID = 1234 + i,
|
|
||||||
Hash = "d8e8fca2dc0f896fd7cb4cb0031ba249",
|
|
||||||
Metadata = new BeatmapMetadata
|
|
||||||
{
|
|
||||||
OnlineBeatmapSetID = 1234 + i,
|
|
||||||
// Create random metadata, then we can check if sorting works based on these
|
|
||||||
Artist = "MONACA " + RNG.Next(0, 9),
|
|
||||||
Title = "Black Song " + RNG.Next(0, 9),
|
|
||||||
Author = "Some Guy " + RNG.Next(0, 9),
|
|
||||||
},
|
|
||||||
Beatmaps = new List<BeatmapInfo>(new[]
|
|
||||||
{
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
OnlineBeatmapID = 1234 + i,
|
|
||||||
Ruleset = rulesets.Query<RulesetInfo>().First(),
|
|
||||||
Path = "normal.osu",
|
|
||||||
Version = "Normal",
|
|
||||||
Difficulty = new BeatmapDifficulty
|
|
||||||
{
|
|
||||||
OverallDifficulty = 3.5f,
|
|
||||||
}
|
|
||||||
},
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
OnlineBeatmapID = 1235 + i,
|
|
||||||
Ruleset = rulesets.Query<RulesetInfo>().First(),
|
|
||||||
Path = "hard.osu",
|
|
||||||
Version = "Hard",
|
|
||||||
Difficulty = new BeatmapDifficulty
|
|
||||||
{
|
|
||||||
OverallDifficulty = 5,
|
|
||||||
}
|
|
||||||
},
|
|
||||||
new BeatmapInfo
|
|
||||||
{
|
|
||||||
OnlineBeatmapID = 1236 + i,
|
|
||||||
Ruleset = rulesets.Query<RulesetInfo>().First(),
|
|
||||||
Path = "insane.osu",
|
|
||||||
Version = "Insane",
|
|
||||||
Difficulty = new BeatmapDifficulty
|
|
||||||
{
|
|
||||||
OverallDifficulty = 7,
|
|
||||||
}
|
|
||||||
},
|
|
||||||
}),
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,771 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Desktop.Tests.Beatmaps;
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Framework.Graphics.Shapes;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Game.Rulesets;
|
|
||||||
using osu.Game.Screens.Play;
|
|
||||||
using OpenTK.Graphics;
|
|
||||||
using osu.Game.Rulesets.Mods;
|
|
||||||
using System.Linq;
|
|
||||||
using osu.Game.Beatmaps.Formats;
|
|
||||||
using System.Text;
|
|
||||||
using System.IO;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCasePlayer : OsuTestCase
|
|
||||||
{
|
|
||||||
protected Player Player;
|
|
||||||
private RulesetStore rulesets;
|
|
||||||
|
|
||||||
public override string Description => @"Showing everything to play the game.";
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load(RulesetStore rulesets)
|
|
||||||
{
|
|
||||||
this.rulesets = rulesets;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void LoadComplete()
|
|
||||||
{
|
|
||||||
base.LoadComplete();
|
|
||||||
|
|
||||||
Add(new Box
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Framework.Graphics.Axes.Both,
|
|
||||||
Colour = Color4.Black,
|
|
||||||
});
|
|
||||||
|
|
||||||
foreach (var r in rulesets.Query<RulesetInfo>())
|
|
||||||
AddStep(r.Name, () => loadPlayerFor(r));
|
|
||||||
|
|
||||||
loadPlayerFor(rulesets.Query<RulesetInfo>().First());
|
|
||||||
}
|
|
||||||
|
|
||||||
private void loadPlayerFor(RulesetInfo r)
|
|
||||||
{
|
|
||||||
Beatmap beatmap;
|
|
||||||
|
|
||||||
using (var stream = new MemoryStream(Encoding.UTF8.GetBytes(test_beatmap_data)))
|
|
||||||
using (var reader = new StreamReader(stream))
|
|
||||||
beatmap = BeatmapDecoder.GetDecoder(reader).Decode(reader);
|
|
||||||
|
|
||||||
beatmap.BeatmapInfo.Ruleset = r;
|
|
||||||
|
|
||||||
var instance = r.CreateInstance();
|
|
||||||
|
|
||||||
WorkingBeatmap working = new TestWorkingBeatmap(beatmap);
|
|
||||||
working.Mods.Value = new[] { instance.GetAllMods().First(m => m is ModNoFail) };
|
|
||||||
|
|
||||||
if (Player != null)
|
|
||||||
Remove(Player);
|
|
||||||
|
|
||||||
Add(Player = CreatePlayer(working, instance));
|
|
||||||
}
|
|
||||||
|
|
||||||
protected virtual Player CreatePlayer(WorkingBeatmap beatmap, Ruleset ruleset)
|
|
||||||
{
|
|
||||||
return new Player
|
|
||||||
{
|
|
||||||
InitialBeatmap = beatmap
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
private const string test_beatmap_data =
|
|
||||||
@"osu file format v14
|
|
||||||
|
|
||||||
[General]
|
|
||||||
AudioLeadIn: 500
|
|
||||||
PreviewTime: 53498
|
|
||||||
Countdown: 0
|
|
||||||
SampleSet: Soft
|
|
||||||
StackLeniency: 0.7
|
|
||||||
Mode: 0
|
|
||||||
LetterboxInBreaks: 0
|
|
||||||
WidescreenStoryboard: 1
|
|
||||||
|
|
||||||
[Editor]
|
|
||||||
DistanceSpacing: 1.2
|
|
||||||
BeatDivisor: 4
|
|
||||||
GridSize: 4
|
|
||||||
TimelineZoom: 1
|
|
||||||
|
|
||||||
[Metadata]
|
|
||||||
Title:My Love
|
|
||||||
TitleUnicode:My Love
|
|
||||||
Artist:Kuba Oms
|
|
||||||
ArtistUnicode:Kuba Oms
|
|
||||||
Creator:W h i t e
|
|
||||||
Version:Hard
|
|
||||||
Source:ADHD
|
|
||||||
Tags:Monthly Beatmapping Contest Electronic folk pop w_h_i_t_e
|
|
||||||
BeatmapID:397534
|
|
||||||
BeatmapSetID:163112
|
|
||||||
|
|
||||||
[Difficulty]
|
|
||||||
HPDrainRate:5
|
|
||||||
CircleSize:4
|
|
||||||
OverallDifficulty:6
|
|
||||||
ApproachRate:7
|
|
||||||
SliderMultiplier:1.44
|
|
||||||
SliderTickRate:2
|
|
||||||
|
|
||||||
[Events]
|
|
||||||
//Break Periods
|
|
||||||
2,69870,83770
|
|
||||||
2,152170,158770
|
|
||||||
//Storyboard Layer 0 (Background)
|
|
||||||
//Storyboard Layer 1 (Fail)
|
|
||||||
//Storyboard Layer 2 (Pass)
|
|
||||||
//Storyboard Layer 3 (Foreground)
|
|
||||||
//Storyboard Sound Samples
|
|
||||||
|
|
||||||
[TimingPoints]
|
|
||||||
2170,468.75,4,2,0,40,1,0
|
|
||||||
4045,-100,4,2,0,30,0,0
|
|
||||||
4162,-100,4,2,0,40,0,0
|
|
||||||
5920,-100,4,2,0,30,0,0
|
|
||||||
6037,-100,4,2,0,40,0,0
|
|
||||||
7795,-100,4,2,0,30,0,0
|
|
||||||
7912,-100,4,2,0,40,0,0
|
|
||||||
9670,-100,4,2,0,40,0,0
|
|
||||||
9787,-100,4,2,0,50,0,0
|
|
||||||
11545,-100,4,2,0,40,0,0
|
|
||||||
11662,-100,4,2,0,50,0,0
|
|
||||||
13420,-100,4,2,0,40,0,0
|
|
||||||
13537,-100,4,2,0,50,0,0
|
|
||||||
15295,-100,4,2,0,40,0,0
|
|
||||||
15412,-100,4,2,0,50,0,0
|
|
||||||
17170,-100,4,2,0,40,0,0
|
|
||||||
17287,-100,4,2,0,50,0,0
|
|
||||||
19045,-100,4,2,0,40,0,0
|
|
||||||
19162,-100,4,2,0,50,0,0
|
|
||||||
20920,-100,4,2,0,40,0,0
|
|
||||||
21037,-100,4,2,0,50,0,0
|
|
||||||
22795,-100,4,2,0,40,0,0
|
|
||||||
22912,-100,4,2,0,50,0,0
|
|
||||||
24670,-100,4,2,0,70,0,0
|
|
||||||
37560,-200,4,2,0,30,0,0
|
|
||||||
38263,-200,4,2,0,5,0,0
|
|
||||||
38966,-100,4,2,0,30,0,0
|
|
||||||
39670,-100,4,2,0,70,0,0
|
|
||||||
53732,-100,4,2,0,40,0,0
|
|
||||||
54670,-100,4,2,0,80,0,1
|
|
||||||
55138,-100,4,2,0,60,0,1
|
|
||||||
55255,-100,4,2,0,80,0,1
|
|
||||||
56076,-100,4,2,0,60,0,1
|
|
||||||
56193,-100,4,2,0,80,0,1
|
|
||||||
57013,-100,4,2,0,60,0,1
|
|
||||||
57130,-100,4,2,0,80,0,1
|
|
||||||
57951,-100,4,2,0,60,0,1
|
|
||||||
58068,-100,4,2,0,80,0,1
|
|
||||||
58888,-100,4,2,0,60,0,1
|
|
||||||
59005,-100,4,2,0,80,0,1
|
|
||||||
59826,-100,4,2,0,60,0,1
|
|
||||||
59943,-100,4,2,0,80,0,1
|
|
||||||
60763,-100,4,2,0,60,0,1
|
|
||||||
60880,-100,4,2,0,80,0,1
|
|
||||||
61701,-100,4,2,0,60,0,1
|
|
||||||
61818,-100,4,2,0,80,0,1
|
|
||||||
62638,-100,4,2,0,60,0,1
|
|
||||||
62755,-100,4,2,0,80,0,1
|
|
||||||
63576,-100,4,2,0,60,0,1
|
|
||||||
63693,-100,4,2,0,80,0,1
|
|
||||||
64513,-100,4,2,0,60,0,1
|
|
||||||
64630,-100,4,2,0,80,0,1
|
|
||||||
65451,-100,4,2,0,60,0,1
|
|
||||||
65568,-100,4,2,0,80,0,1
|
|
||||||
66388,-100,4,2,0,60,0,1
|
|
||||||
66505,-100,4,2,0,80,0,1
|
|
||||||
67326,-100,4,2,0,60,0,1
|
|
||||||
67443,-100,4,2,0,80,0,1
|
|
||||||
68263,-100,4,2,0,60,0,1
|
|
||||||
68380,-100,4,2,0,80,0,1
|
|
||||||
69201,-100,4,2,0,60,0,1
|
|
||||||
69318,-100,4,2,0,80,0,1
|
|
||||||
69670,-100,4,2,0,70,0,0
|
|
||||||
84670,-100,4,2,0,70,0,0
|
|
||||||
97560,-200,4,2,0,70,0,0
|
|
||||||
97795,-200,4,2,0,30,0,0
|
|
||||||
98966,-100,4,2,0,30,0,0
|
|
||||||
99670,-100,4,2,0,70,0,0
|
|
||||||
113732,-100,4,2,0,40,0,0
|
|
||||||
114670,-100,4,2,0,80,0,1
|
|
||||||
115138,-100,4,2,0,60,0,1
|
|
||||||
115255,-100,4,2,0,80,0,1
|
|
||||||
116076,-100,4,2,0,60,0,1
|
|
||||||
116193,-100,4,2,0,80,0,1
|
|
||||||
117013,-100,4,2,0,60,0,1
|
|
||||||
117130,-100,4,2,0,80,0,1
|
|
||||||
117951,-100,4,2,0,60,0,1
|
|
||||||
118068,-100,4,2,0,80,0,1
|
|
||||||
118888,-100,4,2,0,60,0,1
|
|
||||||
119005,-100,4,2,0,80,0,1
|
|
||||||
119826,-100,4,2,0,60,0,1
|
|
||||||
119943,-100,4,2,0,80,0,1
|
|
||||||
120763,-100,4,2,0,60,0,1
|
|
||||||
120880,-100,4,2,0,80,0,1
|
|
||||||
121701,-100,4,2,0,60,0,1
|
|
||||||
121818,-100,4,2,0,80,0,1
|
|
||||||
122638,-100,4,2,0,60,0,1
|
|
||||||
122755,-100,4,2,0,80,0,1
|
|
||||||
123576,-100,4,2,0,60,0,1
|
|
||||||
123693,-100,4,2,0,80,0,1
|
|
||||||
124513,-100,4,2,0,60,0,1
|
|
||||||
124630,-100,4,2,0,80,0,1
|
|
||||||
125451,-100,4,2,0,60,0,1
|
|
||||||
125568,-100,4,2,0,80,0,1
|
|
||||||
126388,-100,4,2,0,60,0,1
|
|
||||||
126505,-100,4,2,0,80,0,1
|
|
||||||
127326,-100,4,2,0,60,0,1
|
|
||||||
127443,-100,4,2,0,80,0,1
|
|
||||||
128263,-100,4,2,0,60,0,1
|
|
||||||
128380,-100,4,2,0,80,0,1
|
|
||||||
129201,-100,4,2,0,60,0,1
|
|
||||||
129318,-100,4,2,0,80,0,1
|
|
||||||
129670,-200,4,2,0,40,0,0
|
|
||||||
144670,-133.333333333333,4,2,0,40,0,0
|
|
||||||
159670,-133.333333333333,4,2,0,40,0,0
|
|
||||||
163420,-133.333333333333,4,2,0,45,0,0
|
|
||||||
163888,-125,4,2,0,50,0,0
|
|
||||||
164357,-117.647058823529,4,2,0,55,0,0
|
|
||||||
164826,-111.111111111111,4,2,0,60,0,0
|
|
||||||
165295,-105.263157894737,4,2,0,65,0,0
|
|
||||||
165763,-100,4,2,0,70,0,0
|
|
||||||
166232,-100,4,2,0,40,0,0
|
|
||||||
167170,-100,4,2,0,80,0,1
|
|
||||||
167638,-100,4,2,0,60,0,1
|
|
||||||
167755,-100,4,2,0,80,0,1
|
|
||||||
168576,-100,4,2,0,60,0,1
|
|
||||||
168693,-100,4,2,0,80,0,1
|
|
||||||
169513,-100,4,2,0,60,0,1
|
|
||||||
169630,-100,4,2,0,80,0,1
|
|
||||||
170451,-100,4,2,0,60,0,1
|
|
||||||
170568,-100,4,2,0,80,0,1
|
|
||||||
171388,-100,4,2,0,60,0,1
|
|
||||||
171505,-100,4,2,0,80,0,1
|
|
||||||
172326,-100,4,2,0,60,0,1
|
|
||||||
172443,-100,4,2,0,80,0,1
|
|
||||||
173263,-100,4,2,0,60,0,1
|
|
||||||
173380,-100,4,2,0,80,0,1
|
|
||||||
174201,-100,4,2,0,60,0,1
|
|
||||||
174318,-100,4,2,0,80,0,1
|
|
||||||
175138,-100,4,2,0,60,0,1
|
|
||||||
175255,-100,4,2,0,80,0,1
|
|
||||||
176076,-100,4,2,0,60,0,1
|
|
||||||
176193,-100,4,2,0,80,0,1
|
|
||||||
177013,-100,4,2,0,60,0,1
|
|
||||||
177130,-100,4,2,0,80,0,1
|
|
||||||
177951,-100,4,2,0,60,0,1
|
|
||||||
178068,-100,4,2,0,80,0,1
|
|
||||||
178888,-100,4,2,0,60,0,1
|
|
||||||
179005,-100,4,2,0,80,0,1
|
|
||||||
179826,-100,4,2,0,60,0,1
|
|
||||||
179943,-100,4,2,0,80,0,1
|
|
||||||
180763,-100,4,2,0,60,0,1
|
|
||||||
180880,-100,4,2,0,80,0,1
|
|
||||||
180998,-100,4,2,0,80,0,0
|
|
||||||
181466,-100,4,2,0,60,0,0
|
|
||||||
181584,-100,4,2,0,80,0,0
|
|
||||||
181935,-100,4,2,0,80,0,0
|
|
||||||
182170,-100,4,2,0,80,0,1
|
|
||||||
182638,-100,4,2,0,60,0,1
|
|
||||||
182755,-100,4,2,0,80,0,1
|
|
||||||
183576,-100,4,2,0,60,0,1
|
|
||||||
183693,-100,4,2,0,80,0,1
|
|
||||||
184513,-100,4,2,0,60,0,1
|
|
||||||
184630,-100,4,2,0,80,0,1
|
|
||||||
185451,-100,4,2,0,60,0,1
|
|
||||||
185568,-100,4,2,0,80,0,1
|
|
||||||
186388,-100,4,2,0,60,0,1
|
|
||||||
186505,-100,4,2,0,80,0,1
|
|
||||||
187326,-100,4,2,0,60,0,1
|
|
||||||
187443,-100,4,2,0,80,0,1
|
|
||||||
188263,-100,4,2,0,60,0,1
|
|
||||||
188380,-100,4,2,0,80,0,1
|
|
||||||
189201,-100,4,2,0,60,0,1
|
|
||||||
189318,-100,4,2,0,80,0,1
|
|
||||||
190138,-100,4,2,0,60,0,1
|
|
||||||
190255,-100,4,2,0,80,0,1
|
|
||||||
191076,-100,4,2,0,60,0,1
|
|
||||||
191193,-100,4,2,0,80,0,1
|
|
||||||
192013,-100,4,2,0,60,0,1
|
|
||||||
192130,-100,4,2,0,80,0,1
|
|
||||||
192951,-100,4,2,0,60,0,1
|
|
||||||
193068,-100,4,2,0,80,0,1
|
|
||||||
193888,-100,4,2,0,60,0,1
|
|
||||||
194005,-100,4,2,0,80,0,1
|
|
||||||
194826,-100,4,2,0,60,0,1
|
|
||||||
194943,-100,4,2,0,80,0,1
|
|
||||||
195295,-100,4,2,0,50,0,1
|
|
||||||
195529,-100,4,2,0,52,0,1
|
|
||||||
195646,-100,4,2,0,54,0,1
|
|
||||||
195763,-100,4,2,0,56,0,1
|
|
||||||
195880,-100,4,2,0,58,0,1
|
|
||||||
195998,-100,4,2,0,60,0,1
|
|
||||||
196115,-100,4,2,0,62,0,1
|
|
||||||
196232,-100,4,2,0,64,0,1
|
|
||||||
196349,-100,4,2,0,68,0,1
|
|
||||||
196466,-100,4,2,0,70,0,1
|
|
||||||
196584,-100,4,2,0,72,0,1
|
|
||||||
196701,-100,4,2,0,74,0,1
|
|
||||||
196818,-100,4,2,0,76,0,1
|
|
||||||
196935,-100,4,2,0,78,0,1
|
|
||||||
197052,-100,4,2,0,80,0,1
|
|
||||||
197170,-100,4,2,0,80,0,0
|
|
||||||
197873,-100,4,2,0,60,0,0
|
|
||||||
197990,-100,4,2,0,80,0,0
|
|
||||||
198341,-100,4,2,0,60,0,0
|
|
||||||
199045,-100,4,2,0,80,0,0
|
|
||||||
199279,-100,4,2,0,60,0,0
|
|
||||||
199630,-100,4,2,0,80,0,0
|
|
||||||
200216,-100,4,2,0,60,0,0
|
|
||||||
200334,-100,4,2,0,80,0,0
|
|
||||||
201623,-100,4,2,0,60,0,0
|
|
||||||
201740,-100,4,2,0,80,0,0
|
|
||||||
202326,-100,4,2,0,60,0,0
|
|
||||||
202443,-100,4,2,0,80,0,0
|
|
||||||
203029,-100,4,2,0,60,0,0
|
|
||||||
203498,-100,4,2,0,80,0,0
|
|
||||||
203966,-100,4,2,0,60,0,0
|
|
||||||
204201,-100,4,2,0,80,0,0
|
|
||||||
205373,-100,4,2,0,60,0,0
|
|
||||||
205490,-100,4,2,0,80,0,0
|
|
||||||
205841,-100,4,2,0,60,0,0
|
|
||||||
206076,-100,4,2,0,60,0,0
|
|
||||||
206545,-100,4,2,0,80,0,0
|
|
||||||
206779,-100,4,2,0,60,0,0
|
|
||||||
207130,-100,4,2,0,80,0,0
|
|
||||||
207716,-100,4,2,0,60,0,0
|
|
||||||
207951,-100,4,2,0,80,0,0
|
|
||||||
209123,-100,4,2,0,60,0,0
|
|
||||||
209240,-100,4,2,0,80,0,0
|
|
||||||
209826,-100,4,2,0,60,0,0
|
|
||||||
209943,-100,4,2,0,80,0,0
|
|
||||||
210529,-100,4,2,0,60,0,0
|
|
||||||
210880,-100,4,2,0,80,0,0
|
|
||||||
211232,-100,4,2,0,60,0,0
|
|
||||||
211701,-100,4,2,0,70,0,0
|
|
||||||
212170,-100,4,2,0,80,0,0
|
|
||||||
212873,-100,4,2,0,60,0,0
|
|
||||||
212990,-100,4,2,0,80,0,0
|
|
||||||
213341,-100,4,2,0,60,0,0
|
|
||||||
213576,-100,4,2,0,60,0,0
|
|
||||||
214045,-100,4,2,0,80,0,0
|
|
||||||
214279,-100,4,2,0,60,0,0
|
|
||||||
214630,-100,4,2,0,80,0,0
|
|
||||||
215216,-100,4,2,0,60,0,0
|
|
||||||
215451,-100,4,2,0,80,0,0
|
|
||||||
216623,-100,4,2,0,60,0,0
|
|
||||||
216740,-100,4,2,0,80,0,0
|
|
||||||
217326,-100,4,2,0,60,0,0
|
|
||||||
217443,-100,4,2,0,80,0,0
|
|
||||||
218029,-100,4,2,0,60,0,0
|
|
||||||
218498,-100,4,2,0,80,0,0
|
|
||||||
218732,-100,4,2,0,50,0,0
|
|
||||||
219670,-100,4,2,0,70,0,0
|
|
||||||
220138,-100,4,2,0,65,0,0
|
|
||||||
220373,-100,4,2,0,45,0,0
|
|
||||||
220490,-100,4,2,0,65,0,0
|
|
||||||
220607,-100,4,2,0,60,0,0
|
|
||||||
220841,-100,4,2,0,35,0,0
|
|
||||||
221076,-100,4,2,0,35,0,0
|
|
||||||
221545,-100,4,2,0,50,0,0
|
|
||||||
221779,-100,4,2,0,30,0,0
|
|
||||||
222013,-111.111111111111,4,2,0,25,0,0
|
|
||||||
222130,-111.111111111111,4,2,0,40,0,0
|
|
||||||
222482,-125,4,2,0,40,0,0
|
|
||||||
222716,-125,4,2,0,20,0,0
|
|
||||||
222951,-100,4,2,0,15,0,0
|
|
||||||
223420,-100,4,2,0,30,0,0
|
|
||||||
224357,-100,4,2,0,25,0,0
|
|
||||||
225295,-100,4,2,0,20,0,0
|
|
||||||
226232,-100,4,2,0,15,0,0
|
|
||||||
226701,-100,4,2,0,10,0,0
|
|
||||||
227170,-100,4,2,0,5,0,0
|
|
||||||
|
|
||||||
|
|
||||||
[Colours]
|
|
||||||
Combo1 : 17,254,176
|
|
||||||
Combo2 : 173,255,95
|
|
||||||
Combo3 : 255,88,100
|
|
||||||
Combo4 : 255,94,55
|
|
||||||
|
|
||||||
[HitObjects]
|
|
||||||
320,256,2170,6,0,P|256:284|192:256,1,144,4|0,0:0|0:0,0:0:0:0:
|
|
||||||
144,184,2873,1,0,0:0:0:0:
|
|
||||||
108,260,3107,2,0,P|112:296|100:336,1,72
|
|
||||||
28,288,3576,2,0,P|24:252|36:212,1,72,0|0,0:0|0:0,0:0:0:0:
|
|
||||||
76,140,4045,6,0,L|220:136,1,144,4|0,0:0|0:0,0:0:0:0:
|
|
||||||
292,88,4748,1,0,0:0:0:0:
|
|
||||||
292,88,4982,2,0,P|304:120|300:168,1,72
|
|
||||||
388,168,5451,2,0,P|396:133|416:103,1,72,0|0,0:0|0:0,0:0:0:0:
|
|
||||||
472,172,5920,6,0,B|470:200|457:222|457:222|488:256|476:308,1,144,4|0,0:0|0:0,0:0:0:0:
|
|
||||||
396,280,6623,1,0,0:0:0:0:
|
|
||||||
324,328,6857,2,0,P|288:332|252:324,1,72
|
|
||||||
180,280,7326,2,0,L|108:284,1,72,0|0,0:0|0:0,0:0:0:0:
|
|
||||||
256,192,7795,12,0,9670,0:0:0:0:
|
|
||||||
428,212,10138,1,0,0:0:0:0:
|
|
||||||
292,320,10607,1,0,0:0:0:0:
|
|
||||||
184,184,11076,2,0,L|112:180,1,72,0|0,0:0|0:0,0:0:0:0:
|
|
||||||
24,172,11545,5,6,0:0:0:0:
|
|
||||||
160,280,12013,1,0,0:0:0:0:
|
|
||||||
268,144,12482,1,0,0:0:0:0:
|
|
||||||
132,36,12951,2,0,L|204:32,1,72,0|0,0:0|0:0,0:0:0:0:
|
|
||||||
284,60,13420,6,0,P|340:100|344:180,2,144,6|0|0,0:0|0:0|0:0,0:0:0:0:
|
|
||||||
268,144,14591,1,0,0:0:0:0:
|
|
||||||
284,228,14826,2,0,P|316:248|364:252,1,72,0|0,0:0|0:0,0:0:0:0:
|
|
||||||
436,248,15295,6,0,P|372:272|344:340,1,144,6|2,0:0|0:0,0:0:0:0:
|
|
||||||
168,338,16232,2,0,P|141:273|76:248,1,144,2|2,0:0|0:0,0:0:0:0:
|
|
||||||
4,296,16935,1,0,0:0:0:0:
|
|
||||||
80,336,17170,5,6,0:0:0:0:
|
|
||||||
44,168,17638,1,0,0:0:0:0:
|
|
||||||
212,128,18107,1,0,0:0:0:0:
|
|
||||||
248,296,18576,2,0,P|284:288|320:292,1,72,0|0,0:0|0:0,0:0:0:0:
|
|
||||||
400,324,19045,5,6,0:0:0:0:
|
|
||||||
280,200,19513,1,0,0:0:0:0:
|
|
||||||
368,52,19982,1,0,0:0:0:0:
|
|
||||||
488,176,20451,2,0,P|452:168|416:172,1,72,0|0,0:0|0:0,0:0:0:0:
|
|
||||||
336,200,20920,6,0,P|284:216|200:192,1,144,6|0,0:0|0:0,0:0:0:0:
|
|
||||||
200,192,21857,2,0,L|204:264,1,72,0|0,0:3|0:0,0:0:0:0:
|
|
||||||
117,244,22326,2,0,L|120:172,1,72,0|0,0:0|0:0,0:0:0:0:
|
|
||||||
40,152,22795,6,0,L|28:296,2,144,6|0|0,0:0|0:0|0:0,0:0:0:0:
|
|
||||||
152,24,24201,1,0,0:0:0:0:
|
|
||||||
220,76,24435,1,0,3:0:0:0:
|
|
||||||
304,56,24670,6,0,P|288:120|296:196,1,144,4|2,0:3|0:3,0:0:0:0:
|
|
||||||
344,268,25373,1,0,0:0:0:0:
|
|
||||||
416,316,25607,2,0,P|452:312|508:316,2,72,0|0|2,0:0|0:0|0:3,0:0:0:0:
|
|
||||||
244,344,26545,6,0,P|176:356|108:328,1,144,4|2,0:3|0:3,0:0:0:0:
|
|
||||||
60,256,27248,1,0,0:0:0:0:
|
|
||||||
36,172,27482,2,0,L|40:100,2,72,0|0|2,0:0|0:0|0:3,0:0:0:0:
|
|
||||||
188,252,28420,6,0,P|192:184|196:100,1,144,4|2,0:3|0:3,0:0:0:0:
|
|
||||||
140,40,29123,1,0,0:0:0:0:
|
|
||||||
140,40,29357,2,0,B|172:16|220:24|220:24|288:36,1,144,0|2,0:0|0:3,0:0:0:0:
|
|
||||||
364,52,30060,1,0,0:0:0:0:
|
|
||||||
308,116,30295,6,0,B|300:168|300:168|328:256,1,144,4|2,0:3|0:3,0:0:0:0:
|
|
||||||
340,340,30998,1,0,0:0:0:0:
|
|
||||||
260,308,31232,2,0,L|188:304,1,72,0|2,0:0|0:3,0:0:0:0:
|
|
||||||
100,296,31701,1,2,0:3:0:0:
|
|
||||||
136,374,31935,1,0,0:0:0:0:
|
|
||||||
152,224,32170,6,0,P|160:152|132:88,1,144,4|2,0:3|0:3,0:0:0:0:
|
|
||||||
56,48,32873,1,0,0:0:0:0:
|
|
||||||
60,136,33107,2,0,L|56:208,2,72,0|0|2,0:0|0:0|0:3,0:0:0:0:
|
|
||||||
224,76,34045,6,0,P|289:104|360:96,1,144,4|2,0:3|0:3,0:0:0:0:
|
|
||||||
432,48,34748,1,0,0:0:0:0:
|
|
||||||
440,132,34982,2,0,B|432:156|432:156|436:204,2,72,0|0|2,0:0|0:0|0:3,0:0:0:0:
|
|
||||||
448,304,35920,6,0,B|412:315|380:292|380:292|348:269|312:280,1,144,4|2,0:3|0:3,0:0:0:0:
|
|
||||||
332,364,36623,1,0,0:0:0:0:
|
|
||||||
247,339,36857,2,0,P|230:308|225:273,2,72,0|0|2,0:0|0:0|0:3,0:0:0:0:
|
|
||||||
312,280,37560,6,0,L|316:172,1,108
|
|
||||||
134,35,38966,5,0,0:0:0:0:
|
|
||||||
72,96,39201,2,0,P|119:119|171:111,1,108,0|0,0:0|0:0,0:0:0:0:
|
|
||||||
192,100,39670,6,0,L|200:172,1,72,4|2,0:0|0:0,0:0:0:0:
|
|
||||||
147,240,40138,2,0,P|133:272|132:308,1,72,0|2,1:0|0:0,0:0:0:0:
|
|
||||||
216,292,40607,2,0,B|260:308|260:308|356:292,1,144,4|0,2:3|1:0,1:0:0:0:
|
|
||||||
356,292,41310,1,2,0:0:0:0:
|
|
||||||
436,327,41545,6,0,P|441:292|435:257,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
364,204,42013,2,0,P|336:144|352:68,1,144,0|4,1:0|2:3,1:0:0:0:
|
|
||||||
404,0,42716,1,2,0:0:0:0:
|
|
||||||
440,80,42951,2,0,B|464:84|464:84|512:80,1,72,0|2,1:0|0:0,0:0:0:0:
|
|
||||||
351,71,43420,6,0,B|296:68|296:68|268:76|268:76|196:72,1,144,4|0,2:3|1:0,1:0:0:0:
|
|
||||||
120,68,44123,1,2,0:0:0:0:
|
|
||||||
160,144,44357,2,0,P|172:180|168:232,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
76,264,44826,2,0,P|76:228|88:194,1,72,0|2,1:0|0:0,0:0:0:0:
|
|
||||||
160,144,45295,5,4,0:3:0:0:
|
|
||||||
244,164,45529,1,2,0:0:0:0:
|
|
||||||
268,248,45763,2,0,L|344:252,1,72,0|2,1:0|0:0,0:0:0:0:
|
|
||||||
408,156,46232,2,0,L|336:159,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
212,72,46701,2,0,L|288:76,1,72,0|2,1:0|0:0,0:0:0:0:
|
|
||||||
400,72,47170,6,0,P|464:96|488:172,1,144,4|0,2:0|1:0,1:0:0:0:
|
|
||||||
476,248,47873,1,2,0:0:0:0:
|
|
||||||
436,324,48107,2,0,L|284:320,1,144,4|0,2:3|1:0,1:0:0:0:
|
|
||||||
204,316,48810,1,2,0:0:0:0:
|
|
||||||
127,355,49045,6,0,P|120:321|124:285,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
192,232,49513,2,0,L|335:228,1,144,0|4,1:0|2:3,1:0:0:0:
|
|
||||||
412,188,50216,1,2,0:0:0:0:
|
|
||||||
444,108,50451,2,0,P|452:72|448:36,1,72,0|2,1:0|0:0,0:0:0:0:
|
|
||||||
368,68,50920,6,0,B|332:79|300:56|300:56|268:33|232:44,1,144,4|0,2:3|1:0,1:0:0:0:
|
|
||||||
152,76,51623,1,2,0:0:0:0:
|
|
||||||
76,116,51857,2,0,L|80:268,1,144,4|0,2:3|1:0,1:0:0:0:
|
|
||||||
80,260,52560,1,2,0:0:0:0:
|
|
||||||
8,308,52795,6,0,P|34:334|69:346,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
148,312,53263,2,0,P|163:278|162:241,1,72,0|2,1:0|0:0,0:0:0:0:
|
|
||||||
156,156,53732,5,0,3:0:0:0:
|
|
||||||
156,156,53966,1,2,0:0:0:0:
|
|
||||||
236,196,54201,2,0,L|312:192,1,72,8|0,0:3|0:0,0:0:0:0:
|
|
||||||
368,256,54670,6,0,P|392:216|352:116,1,144,4|2,0:0|1:2,0:0:0:0:
|
|
||||||
288,92,55373,1,0,0:0:0:0:
|
|
||||||
360,40,55607,2,0,L|432:36,1,72,4|0,0:3|3:0,0:0:0:0:
|
|
||||||
288,92,56076,2,0,L|216:88,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
132,72,56545,6,0,P|172:88|200:184,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
143,241,57248,1,0,0:0:0:0:
|
|
||||||
65,202,57482,2,0,P|87:174|119:157,1,72,4|0,0:3|3:0,0:0:0:0:
|
|
||||||
132,324,57951,2,0,P|98:312|72:288,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
143,241,58420,6,0,L|288:240,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
372,240,59123,1,0,0:0:0:0:
|
|
||||||
330,314,59357,2,0,P|318:350|322:390,1,72,4|0,0:3|3:0,0:0:0:0:
|
|
||||||
452,264,59826,2,0,P|453:228|442:194,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
384,128,60295,6,0,B|336:144|336:144|244:128,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
164,160,60998,2,0,P|160:116|168:88,1,72,0|4,0:0|0:3,0:0:0:0:
|
|
||||||
244,128,61466,2,0,P|248:172|240:200,1,72,0|2,3:0|1:2,0:0:0:0:
|
|
||||||
168,248,61935,1,0,0:0:0:0:
|
|
||||||
120,320,62170,6,0,P|196:328|252:272,2,144,4|2|4,0:3|1:2|0:3,0:0:0:0:
|
|
||||||
80,244,63341,1,0,3:0:0:0:
|
|
||||||
100,160,63576,2,0,L|24:156,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
180,128,64045,6,0,P|249:138|304:94,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
226,57,64748,1,0,0:0:0:0:
|
|
||||||
304,94,64982,2,0,L|300:166,1,72,4|0,0:3|3:0,0:0:0:0:
|
|
||||||
377,203,65451,2,0,L|388:132,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
468,180,65920,6,0,L|432:328,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
276,252,66857,2,0,P|208:248|140:280,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
84,344,67560,1,0,0:0:0:0:
|
|
||||||
56,260,67795,6,0,L|52:188,2,72,4|2|2,0:3|0:0|1:2,0:0:0:0:
|
|
||||||
168,128,68732,2,0,L|172:56,2,72,4|2|2,0:3|0:0|1:2,0:0:0:0:
|
|
||||||
244,168,69435,1,0,0:0:0:0:
|
|
||||||
332,164,69670,1,4,0:3:0:0:
|
|
||||||
208,328,84670,6,0,P|224:264|216:188,1,144,4|2,0:3|0:3,0:0:0:0:
|
|
||||||
168,116,85373,1,0,0:0:0:0:
|
|
||||||
96,68,85607,2,0,P|60:72|4:68,2,72,0|0|2,0:0|0:0|0:3,0:0:0:0:
|
|
||||||
268,40,86545,6,0,P|336:28|404:56,1,144,4|2,0:3|0:3,0:0:0:0:
|
|
||||||
452,128,87248,1,0,0:0:0:0:
|
|
||||||
476,212,87482,2,0,L|472:284,2,72,0|0|2,0:0|0:0|0:3,0:0:0:0:
|
|
||||||
324,132,88420,6,0,P|320:200|316:284,1,144,4|2,0:3|0:3,0:0:0:0:
|
|
||||||
372,344,89123,1,0,0:0:0:0:
|
|
||||||
372,344,89357,2,0,B|340:368|292:360|292:360|224:348,1,144,0|2,0:0|0:3,0:0:0:0:
|
|
||||||
148,332,90060,1,0,0:0:0:0:
|
|
||||||
204,268,90295,6,0,B|212:216|212:216|184:128,1,144,4|2,0:3|0:3,0:0:0:0:
|
|
||||||
172,44,90998,1,0,0:0:0:0:
|
|
||||||
252,76,91232,2,0,L|324:80,1,72,0|2,0:0|0:3,0:0:0:0:
|
|
||||||
412,88,91701,1,2,0:3:0:0:
|
|
||||||
377,9,91935,1,0,0:0:0:0:
|
|
||||||
360,160,92170,6,0,P|352:232|380:296,1,144,4|2,0:3|0:3,0:0:0:0:
|
|
||||||
456,336,92873,1,0,0:0:0:0:
|
|
||||||
452,248,93107,2,0,L|456:176,2,72,0|0|2,0:0|0:0|0:3,0:0:0:0:
|
|
||||||
288,308,94045,6,0,P|223:280|152:288,1,144,4|2,0:3|0:3,0:0:0:0:
|
|
||||||
80,336,94748,1,0,0:0:0:0:
|
|
||||||
72,252,94982,2,0,B|80:228|80:228|76:180,2,72,0|0|2,0:0|0:0|0:3,0:0:0:0:
|
|
||||||
64,80,95920,6,0,B|100:69|132:92|132:92|164:115|200:104,1,144,4|2,0:3|0:3,0:0:0:0:
|
|
||||||
180,20,96623,1,0,0:0:0:0:
|
|
||||||
265,45,96857,2,0,P|282:76|287:111,2,72,0|0|2,0:0|0:0|0:3,0:0:0:0:
|
|
||||||
200,104,97560,1,0,0:0:0:0:
|
|
||||||
200,104,97677,1,0,0:0:0:0:
|
|
||||||
200,104,97795,6,0,B|196:142|217:166|217:166|176:180|160:220,1,144,4|0,0:3|0:0,0:0:0:0:
|
|
||||||
240,248,98966,5,0,0:0:0:0:
|
|
||||||
202,325,99201,2,0,P|254:333|301:309,1,108,0|0,0:0|0:0,0:0:0:0:
|
|
||||||
315,292,99670,6,0,L|323:220,1,72,4|2,0:0|0:0,0:0:0:0:
|
|
||||||
365,144,100138,2,0,P|379:112|380:76,1,72,0|2,1:0|0:0,0:0:0:0:
|
|
||||||
296,92,100607,2,0,B|252:76|252:76|156:92,1,144,4|0,2:3|1:0,1:0:0:0:
|
|
||||||
156,92,101310,1,2,0:0:0:0:
|
|
||||||
76,57,101545,6,0,P|71:92|77:127,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
148,180,102013,2,0,P|176:240|160:316,1,144,0|4,1:0|2:3,1:0:0:0:
|
|
||||||
108,384,102716,1,2,0:0:0:0:
|
|
||||||
72,304,102951,2,0,B|48:300|48:300|0:304,1,72,0|2,1:0|0:0,0:0:0:0:
|
|
||||||
161,313,103420,6,0,B|216:316|216:316|244:308|244:308|316:312,1,144,4|0,2:3|1:0,1:0:0:0:
|
|
||||||
392,316,104123,1,2,0:0:0:0:
|
|
||||||
352,240,104357,2,0,P|340:204|344:152,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
436,120,104826,2,0,P|436:156|424:190,1,72,0|2,1:0|0:0,0:0:0:0:
|
|
||||||
352,240,105295,5,4,0:3:0:0:
|
|
||||||
268,220,105529,1,2,0:0:0:0:
|
|
||||||
244,136,105763,2,0,L|168:132,1,72,0|2,1:0|0:0,0:0:0:0:
|
|
||||||
104,228,106232,2,0,L|176:225,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
300,312,106701,2,0,L|224:308,1,72,0|2,1:0|0:0,0:0:0:0:
|
|
||||||
112,312,107170,6,0,P|48:288|24:212,1,144,4|0,2:0|1:0,1:0:0:0:
|
|
||||||
36,136,107873,1,2,0:0:0:0:
|
|
||||||
76,60,108107,2,0,L|228:64,1,144,4|0,2:3|1:0,1:0:0:0:
|
|
||||||
308,68,108810,1,2,0:0:0:0:
|
|
||||||
385,29,109045,6,0,P|392:63|388:99,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
320,152,109513,2,0,L|177:156,1,144,0|4,1:0|2:3,1:0:0:0:
|
|
||||||
100,196,110216,1,2,0:0:0:0:
|
|
||||||
68,276,110451,2,0,P|60:312|64:348,1,72,0|2,1:0|0:0,0:0:0:0:
|
|
||||||
144,316,110920,6,0,B|180:305|212:328|212:328|244:351|280:340,1,144,4|0,2:3|1:0,1:0:0:0:
|
|
||||||
360,308,111623,1,2,0:0:0:0:
|
|
||||||
436,268,111857,2,0,L|432:116,1,144,4|0,2:3|1:0,1:0:0:0:
|
|
||||||
432,124,112560,1,2,0:0:0:0:
|
|
||||||
504,76,112795,6,0,P|478:50|443:38,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
364,72,113263,2,0,P|349:106|350:143,1,72,0|2,1:0|0:0,0:0:0:0:
|
|
||||||
356,228,113732,5,0,3:0:0:0:
|
|
||||||
356,228,113966,1,2,0:0:0:0:
|
|
||||||
276,188,114201,2,0,L|200:192,1,72,8|0,0:3|0:0,0:0:0:0:
|
|
||||||
144,128,114670,6,0,P|120:168|160:268,1,144,4|2,0:0|1:2,0:0:0:0:
|
|
||||||
224,292,115373,1,0,0:0:0:0:
|
|
||||||
152,344,115607,2,0,L|80:348,1,72,4|0,0:3|3:0,0:0:0:0:
|
|
||||||
224,292,116076,2,0,L|296:296,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
380,312,116545,6,0,P|340:296|312:200,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
369,143,117248,1,0,0:0:0:0:
|
|
||||||
447,182,117482,2,0,P|425:210|393:227,1,72,4|0,0:3|3:0,0:0:0:0:
|
|
||||||
380,60,117951,2,0,P|414:72|440:96,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
369,143,118420,6,0,L|224:144,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
140,144,119123,1,0,0:0:0:0:
|
|
||||||
182,70,119357,2,0,P|194:34|190:-6,1,72,4|0,0:3|3:0,0:0:0:0:
|
|
||||||
60,120,119826,2,0,P|59:156|70:190,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
128,256,120295,6,0,B|176:240|176:240|268:256,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
348,224,120998,2,0,P|352:268|344:296,1,72,0|4,0:0|0:3,0:0:0:0:
|
|
||||||
268,256,121466,2,0,P|264:212|272:184,1,72,0|2,3:0|1:2,0:0:0:0:
|
|
||||||
344,136,121935,1,0,0:0:0:0:
|
|
||||||
392,64,122170,6,0,P|316:56|260:112,2,144,4|2|4,0:3|1:2|0:3,0:0:0:0:
|
|
||||||
432,140,123341,1,0,3:0:0:0:
|
|
||||||
412,224,123576,2,0,L|488:228,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
332,256,124045,6,0,P|263:246|208:290,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
286,327,124748,1,0,0:0:0:0:
|
|
||||||
208,290,124982,2,0,L|212:218,1,72,4|0,0:3|3:0,0:0:0:0:
|
|
||||||
135,181,125451,2,0,L|124:252,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
44,204,125920,6,0,L|80:56,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
236,132,126857,2,0,P|304:136|372:104,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
428,40,127560,1,0,0:0:0:0:
|
|
||||||
456,124,127795,6,0,L|460:196,2,72,4|2|2,0:3|0:0|1:2,0:0:0:0:
|
|
||||||
344,256,128732,2,0,L|340:328,2,72,4|2|2,0:3|0:0|1:2,0:0:0:0:
|
|
||||||
268,216,129435,1,0,0:0:0:0:
|
|
||||||
180,220,129670,5,4,2:0:0:0:
|
|
||||||
256,40,130373,1,2,0:0:0:0:
|
|
||||||
64,68,131076,1,2,0:0:0:0:
|
|
||||||
92,136,131310,1,0,0:0:0:0:
|
|
||||||
64,204,131545,6,0,L|60:288,1,72
|
|
||||||
31,343,132248,2,0,P|86:345|127:309,1,108
|
|
||||||
332,220,133420,5,2,0:0:0:0:
|
|
||||||
256,40,134123,1,2,0:0:0:0:
|
|
||||||
448,68,134826,1,2,0:0:0:0:
|
|
||||||
420,136,135060,1,0,0:0:0:0:
|
|
||||||
448,204,135295,6,0,L|452:288,1,72,2|0,0:0|0:0,0:0:0:0:
|
|
||||||
480,343,135998,2,0,P|426:345|385:309,1,108
|
|
||||||
256,192,137170,5,2,0:0:0:0:
|
|
||||||
156,360,137873,1,2,0:0:0:0:
|
|
||||||
356,360,138576,2,0,L|352:308,1,36,2|0,0:0|0:0,0:0:0:0:
|
|
||||||
304,268,139045,6,0,P|336:253|372:252,1,72
|
|
||||||
448,260,139748,2,0,L|444:152,1,108
|
|
||||||
256,192,140920,5,2,0:0:0:0:
|
|
||||||
356,24,141623,1,2,0:0:0:0:
|
|
||||||
156,24,142326,2,0,L|160:72,1,36,2|0,0:0|0:0,0:0:0:0:
|
|
||||||
208,116,142795,6,0,P|176:131|140:132,1,72,2|0,0:0|0:0,0:0:0:0:
|
|
||||||
64,124,143498,2,0,L|68:232,1,108
|
|
||||||
68,232,144670,5,4,0:3:0:0:
|
|
||||||
216,320,145138,1,4,0:3:0:0:
|
|
||||||
304,172,145607,1,4,0:3:0:0:
|
|
||||||
156,84,146075,1,4,0:3:0:0:
|
|
||||||
296,320,146545,5,4,0:3:0:0:
|
|
||||||
208,172,147013,1,4,0:3:0:0:
|
|
||||||
356,84,147482,1,4,0:3:0:0:
|
|
||||||
444,232,147950,1,4,0:3:0:0:
|
|
||||||
296,320,148420,6,0,P|252:328|192:296,2,108.000004119873,4|4|4,0:3|0:3|0:3,0:0:0:0:
|
|
||||||
260,248,149591,1,0,0:0:0:0:
|
|
||||||
320,196,149826,2,0,L|316:140,1,54.0000020599366,4|0,0:3|0:0,0:0:0:0:
|
|
||||||
120,236,159670,6,0,L|176:232,1,54.0000020599366,4|0,0:3|0:0,0:0:0:0:
|
|
||||||
160,152,160138,2,0,L|104:156,1,54.0000020599366,2|0,0:0|0:0,0:0:0:0:
|
|
||||||
240,180,160607,2,0,P|292:188|344:172,1,108.000004119873,4|2,0:3|0:0,3:0:0:0:
|
|
||||||
408,120,161310,1,0,3:0:0:0:
|
|
||||||
424,200,161545,6,0,L|420:256,1,54.0000020599366,4|0,0:3|0:0,0:0:0:0:
|
|
||||||
376,320,162013,2,0,P|396:328|480:304,2,108.000004119873,2|6|2,2:0|0:3|2:0,3:0:0:0:
|
|
||||||
312,268,163185,1,0,0:0:0:0:
|
|
||||||
296,348,163420,6,0,L|240:344,1,54.0000020599366,4|0,3:0|3:0,0:0:0:0:
|
|
||||||
160,320,163888,2,0,L|100:316,1,57.6,4|0,3:0|3:0,0:0:0:0:
|
|
||||||
64,232,164357,6,0,L|128:228,1,61.2000011672974,4|0,3:0|3:0,0:0:0:0:
|
|
||||||
204,200,164825,2,0,L|268:196,1,61.2000011672974,4|0,3:0|3:0,0:0:0:0:
|
|
||||||
232,108,165295,6,0,L|164:104,1,68.399998173523,4|0,3:0|3:0,0:0:0:0:
|
|
||||||
80,84,165763,2,0,L|4:80,1,72,4|0,3:0|3:0,0:0:0:0:
|
|
||||||
324,120,167170,6,0,P|388:128|456:92,1,144,4|2,0:0|1:2,0:0:0:0:
|
|
||||||
496,168,167873,1,0,0:0:0:0:
|
|
||||||
496,168,168107,2,0,P|484:204|488:256,1,72,4|0,0:3|3:0,0:0:0:0:
|
|
||||||
408,296,168576,2,0,P|398:261|378:231,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
296,200,169045,6,0,B|228:228|156:204,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
84,156,169748,1,0,0:0:0:0:
|
|
||||||
80,244,169982,2,0,L|76:316,1,72,4|0,0:3|3:0,0:0:0:0:
|
|
||||||
170,274,170451,2,0,L|156:204,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
216,140,170920,6,0,L|284:276,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
320,344,171623,1,0,0:0:0:0:
|
|
||||||
372,276,171857,2,0,P|366:240|349:207,1,72,4|0,0:3|3:0,0:0:0:0:
|
|
||||||
312,132,172326,2,0,L|276:60,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
208,20,172795,6,0,P|272:36|348:12,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
424,48,173498,2,0,L|412:132,1,72,0|4,0:0|0:3,0:0:0:0:
|
|
||||||
484,168,173966,2,0,L|472:252,1,72,0|2,3:0|1:2,0:0:0:0:
|
|
||||||
400,280,174435,1,0,0:0:0:0:
|
|
||||||
346,348,174670,6,0,P|414:363|472:324,2,144,4|2|4,0:3|1:2|0:3,0:0:0:0:
|
|
||||||
312,268,175841,1,0,3:0:0:0:
|
|
||||||
256,336,176076,2,0,L|184:332,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
80,244,176545,6,0,B|140:248|140:248|164:244|164:244|223:247,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
312,268,177248,1,0,0:0:0:0:
|
|
||||||
224,247,177482,2,0,P|240:215|272:187,1,72,4|0,0:3|3:0,0:0:0:0:
|
|
||||||
204,131,177951,2,0,P|233:111|275:103,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
240,23,178420,6,0,B|280:15|316:35|316:35|376:71,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
399,236,179357,2,0,B|359:244|323:224|323:224|263:188,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
204,132,180060,1,0,0:0:0:0:
|
|
||||||
184,216,180295,6,0,L|188:288,2,72,4|2|2,0:3|0:0|1:2,0:0:0:0:
|
|
||||||
120,156,180998,1,0,0:0:0:0:
|
|
||||||
56,96,181232,2,0,L|60:24,2,72,4|2|0,0:3|0:0|1:0,0:0:0:0:
|
|
||||||
36,180,181935,1,0,0:0:0:0:
|
|
||||||
100,240,182170,6,0,P|144:300|116:380,2,144,4|2|4,0:0|1:2|0:3,0:0:0:0:
|
|
||||||
60,316,183341,1,0,0:0:0:0:
|
|
||||||
220,352,183576,2,0,L|308:348,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
396,264,184045,6,0,B|336:268|336:268|312:264|312:264|253:267,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
253,267,184748,1,0,0:0:0:0:
|
|
||||||
268,180,184982,2,0,L|339:177,1,72,4|0,0:3|0:0,0:0:0:0:
|
|
||||||
164,280,185451,2,0,L|92:282,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
52,208,185920,6,0,P|8:268|32:344,2,144,4|2|4,0:3|1:2|0:3,0:0:0:0:
|
|
||||||
140,212,187091,1,0,0:0:0:0:
|
|
||||||
92,284,187326,2,0,P|104:316|100:368,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
52,208,187795,6,0,P|48:136|76:72,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
160,52,188498,2,0,P|188:28|220:16,1,72,0|4,0:0|0:3,0:0:0:0:
|
|
||||||
232,100,188966,2,0,P|268:93|301:98,1,72,0|2,0:0|1:2,0:0:0:0:
|
|
||||||
372,152,189435,1,0,0:0:0:0:
|
|
||||||
420,224,189670,6,0,P|428:296|400:360,2,144,4|2|4,0:3|1:2|0:3,0:0:0:0:
|
|
||||||
372,152,190841,1,0,0:0:0:0:
|
|
||||||
392,68,191076,2,0,L|465:64,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
304,92,191545,6,0,P|236:104|168:76,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
108,12,192248,1,0,0:0:0:0:
|
|
||||||
168,76,192482,2,0,L|172:152,1,72,4|0,0:3|0:0,0:0:0:0:
|
|
||||||
80,136,192951,2,0,L|101:204,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
12,220,193420,6,0,B|50:279|50:279|80:300|120:292,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
284,232,194357,2,0,B|320:221|352:244|352:244|384:267|420:256,1,144,4|2,0:3|1:2,0:0:0:0:
|
|
||||||
488,200,195060,1,0,0:0:0:0:
|
|
||||||
507,284,195295,6,0,P|492:315|464:338,1,72,4|0,0:0|0:0,0:0:0:0:
|
|
||||||
380,356,195763,2,0,L|236:352,1,144,0|4,1:0|0:3,0:0:0:0:
|
|
||||||
152,328,196466,1,0,3:0:0:0:
|
|
||||||
64,336,196701,2,0,P|29:325|4:300,1,72,0|0,1:0|0:0,0:0:0:0:
|
|
||||||
76,252,197170,6,0,P|108:188|96:116,1,144,4|0,0:0|1:0,0:0:0:0:
|
|
||||||
36,56,197873,1,2,0:0:0:0:
|
|
||||||
120,32,198107,2,0,L|192:28,2,72,4|2|2,0:3|0:0|1:2,0:0:0:0:
|
|
||||||
248,152,199045,6,0,P|280:168|304:196,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
336,277,199513,2,0,P|306:296|269:303,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
183,290,199982,2,0,P|180:254|193:219,2,72,4|2|0,0:3|0:0|1:0,0:0:0:0:
|
|
||||||
436,252,200920,6,0,P|404:188|416:116,1,144,4|0,0:3|1:0,0:0:0:0:
|
|
||||||
476,56,201623,1,2,0:0:0:0:
|
|
||||||
392,32,201857,2,0,L|320:28,2,72,4|0|2,0:3|0:0|1:2,0:0:0:0:
|
|
||||||
264,152,202795,6,0,P|232:168|208:196,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
176,277,203263,2,0,P|205:296|242:303,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
329,290,203732,2,0,P|331:254|318:219,2,72,4|2|0,0:3|0:0|1:0,0:0:0:0:
|
|
||||||
72,324,204670,6,0,B|60:272|60:272|76:180,1,144,4|0,0:0|1:0,0:0:0:0:
|
|
||||||
92,96,205373,1,2,0:0:0:0:
|
|
||||||
8,124,205607,2,0,P|5:88|14:53,2,72,4|2|2,0:3|0:0|1:2,0:0:0:0:
|
|
||||||
168,192,206545,6,0,P|200:174|237:173,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
320,160,207013,2,0,P|318:196|301:229,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
272,307,207482,2,0,P|240:287|221:256,2,72,4|2|0,0:3|0:0|1:0,0:0:0:0:
|
|
||||||
440,324,208420,6,0,B|452:272|452:272|436:180,1,144,4|0,0:3|1:0,0:0:0:0:
|
|
||||||
420,96,209123,1,2,0:0:0:0:
|
|
||||||
504,124,209357,2,0,P|507:88|498:53,2,72,4|0|2,0:3|0:0|1:2,0:0:0:0:
|
|
||||||
344,192,210295,6,0,P|311:174|274:173,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
190,156,210763,2,0,P|191:192|208:225,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
288,256,211232,1,4,0:3:0:0:
|
|
||||||
132,332,211701,1,0,1:0:0:0:
|
|
||||||
28,192,212170,6,0,P|16:120|44:56,1,144,4|0,0:0|1:0,0:0:0:0:
|
|
||||||
120,16,212873,1,2,0:0:0:0:
|
|
||||||
204,32,213107,2,0,L|304:28,2,72,4|2|2,0:3|0:0|1:2,0:0:0:0:
|
|
||||||
192,204,214045,6,0,P|196:240|216:272,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
298,241,214513,2,0,P|327:219|345:186,1,72,6|0,1:2|0:0,0:0:0:0:
|
|
||||||
280,132,214982,2,0,P|246:117|209:118,2,72,4|2|0,0:3|0:0|1:0,0:0:0:0:
|
|
||||||
484,192,215920,6,0,P|496:120|468:56,1,144,4|0,0:3|1:0,0:0:0:0:
|
|
||||||
392,16,216623,1,2,0:0:0:0:
|
|
||||||
308,32,216857,2,0,L|208:28,2,72,4|0|2,0:3|0:0|1:2,0:0:0:0:
|
|
||||||
320,204,217795,6,0,P|316:240|296:272,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
213,241,218263,2,0,P|184:219|166:186,1,72,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
232,132,218732,2,0,B|260:112|300:116|300:116|384:128,1,144,4|0,0:3|1:0,0:0:0:0:
|
|
||||||
348,336,219670,6,0,B|320:356|280:352|280:352|196:340,1,144,4|0,0:0|1:0,0:0:0:0:
|
|
||||||
124,328,220373,1,2,0:0:0:0:
|
|
||||||
54,276,220607,2,0,P|41:308|39:345,2,72,4|2|2,0:3|0:0|1:2,0:0:0:0:
|
|
||||||
156,80,221545,6,0,L|251:94,1,72,4|2,0:3|0:0,0:0:0:0:
|
|
||||||
212,169,222013,2,0,L|148:160,1,64.799998022461,2|0,1:2|0:0,0:0:0:0:
|
|
||||||
140,240,222482,2,0,L|216:252,2,57.6,4|2|0,0:3|0:0|1:0,0:0:0:0:
|
|
||||||
256,192,223420,12,0,227170,0:0:0:0:
|
|
||||||
";
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,21 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Game.Rulesets;
|
|
||||||
using osu.Game.Screens.Play;
|
|
||||||
using System.Linq;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseReplay : TestCasePlayer
|
|
||||||
{
|
|
||||||
public override string Description => @"Testing replay playback.";
|
|
||||||
|
|
||||||
protected override Player CreatePlayer(WorkingBeatmap beatmap, Ruleset ruleset)
|
|
||||||
{
|
|
||||||
beatmap.Mods.Value = beatmap.Mods.Value.Concat(new[] { ruleset.GetAutoplayMod() });
|
|
||||||
return base.CreatePlayer(beatmap, ruleset);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,52 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Game.Graphics.UserInterface;
|
|
||||||
using osu.Game.Screens.Play;
|
|
||||||
using osu.Game.Screens.Play.ReplaySettings;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseReplaySettingsOverlay : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Settings visible in replay/auto";
|
|
||||||
|
|
||||||
public TestCaseReplaySettingsOverlay()
|
|
||||||
{
|
|
||||||
ExampleContainer container;
|
|
||||||
|
|
||||||
Add(new ReplaySettingsOverlay
|
|
||||||
{
|
|
||||||
Anchor = Anchor.TopRight,
|
|
||||||
Origin = Anchor.TopRight,
|
|
||||||
});
|
|
||||||
|
|
||||||
Add(container = new ExampleContainer());
|
|
||||||
|
|
||||||
AddStep(@"Add button", () => container.Add(new OsuButton
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.X,
|
|
||||||
Text = @"Button",
|
|
||||||
}));
|
|
||||||
|
|
||||||
AddStep(@"Add checkbox", () => container.Add(new ReplayCheckbox
|
|
||||||
{
|
|
||||||
LabelText = "Checkbox",
|
|
||||||
}));
|
|
||||||
|
|
||||||
AddStep(@"Add textbox", () => container.Add(new FocusedTextBox
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.X,
|
|
||||||
Height = 30,
|
|
||||||
PlaceholderText = "Textbox",
|
|
||||||
HoldFocus = false,
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
|
|
||||||
private class ExampleContainer : ReplayGroup
|
|
||||||
{
|
|
||||||
protected override string Title => @"example";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,63 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Game.Rulesets.Scoring;
|
|
||||||
using osu.Game.Screens.Ranking;
|
|
||||||
using osu.Game.Users;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseResults : OsuTestCase
|
|
||||||
{
|
|
||||||
private BeatmapManager beatmaps;
|
|
||||||
|
|
||||||
public override string Description => @"Results after playing.";
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load(BeatmapManager beatmaps)
|
|
||||||
{
|
|
||||||
this.beatmaps = beatmaps;
|
|
||||||
}
|
|
||||||
|
|
||||||
private WorkingBeatmap beatmap;
|
|
||||||
|
|
||||||
protected override void LoadComplete()
|
|
||||||
{
|
|
||||||
base.LoadComplete();
|
|
||||||
|
|
||||||
if (beatmap == null)
|
|
||||||
{
|
|
||||||
var beatmapInfo = beatmaps.QueryBeatmap(b => b.RulesetID == 0);
|
|
||||||
if (beatmapInfo != null)
|
|
||||||
beatmap = beatmaps.GetWorkingBeatmap(beatmapInfo);
|
|
||||||
}
|
|
||||||
|
|
||||||
Add(new Results(new Score
|
|
||||||
{
|
|
||||||
TotalScore = 2845370,
|
|
||||||
Accuracy = 0.98,
|
|
||||||
MaxCombo = 123,
|
|
||||||
Rank = ScoreRank.A,
|
|
||||||
Date = DateTimeOffset.Now,
|
|
||||||
Statistics = new Dictionary<string, dynamic>
|
|
||||||
{
|
|
||||||
{ "300", 50 },
|
|
||||||
{ "100", 20 },
|
|
||||||
{ "50", 50 },
|
|
||||||
{ "x", 1 }
|
|
||||||
},
|
|
||||||
User = new User
|
|
||||||
{
|
|
||||||
Username = "peppy",
|
|
||||||
}
|
|
||||||
})
|
|
||||||
{
|
|
||||||
InitialBeatmap = beatmap
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,143 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Game.Online.Multiplayer;
|
|
||||||
using osu.Game.Rulesets;
|
|
||||||
using osu.Game.Screens.Multiplayer;
|
|
||||||
using osu.Game.Users;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseRoomInspector : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"from the multiplayer lobby";
|
|
||||||
|
|
||||||
private RulesetStore rulesets;
|
|
||||||
|
|
||||||
protected override void LoadComplete()
|
|
||||||
{
|
|
||||||
base.LoadComplete();
|
|
||||||
|
|
||||||
var room = new Room
|
|
||||||
{
|
|
||||||
Name = { Value = @"My Awesome Room" },
|
|
||||||
Host = { Value = new User { Username = @"flyte", Id = 3103765, Country = new Country { FlagName = @"JP" } } },
|
|
||||||
Status = { Value = new RoomStatusOpen() },
|
|
||||||
Type = { Value = new GameTypeTeamVersus() },
|
|
||||||
Beatmap =
|
|
||||||
{
|
|
||||||
Value = new BeatmapInfo
|
|
||||||
{
|
|
||||||
StarDifficulty = 3.7,
|
|
||||||
Ruleset = rulesets.GetRuleset(3),
|
|
||||||
Metadata = new BeatmapMetadata
|
|
||||||
{
|
|
||||||
Title = @"Platina",
|
|
||||||
Artist = @"Maaya Sakamoto",
|
|
||||||
Author = @"uwutm8",
|
|
||||||
},
|
|
||||||
BeatmapSet = new BeatmapSetInfo
|
|
||||||
{
|
|
||||||
OnlineInfo = new BeatmapSetOnlineInfo
|
|
||||||
{
|
|
||||||
Covers = new BeatmapSetOnlineCovers
|
|
||||||
{
|
|
||||||
Cover = @"https://assets.ppy.sh/beatmaps/560573/covers/cover.jpg?1492722343",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
MaxParticipants = { Value = 200 },
|
|
||||||
Participants =
|
|
||||||
{
|
|
||||||
Value = new[]
|
|
||||||
{
|
|
||||||
new User { Username = @"flyte", Id = 3103765, GlobalRank = 1425 },
|
|
||||||
new User { Username = @"Cookiezi", Id = 124493, GlobalRank = 5466 },
|
|
||||||
new User { Username = @"Angelsim", Id = 1777162, GlobalRank = 2873 },
|
|
||||||
new User { Username = @"Rafis", Id = 2558286, GlobalRank = 4687 },
|
|
||||||
new User { Username = @"hvick225", Id = 50265, GlobalRank = 3258 },
|
|
||||||
new User { Username = @"peppy", Id = 2, GlobalRank = 6251 }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
RoomInspector inspector;
|
|
||||||
Add(inspector = new RoomInspector
|
|
||||||
{
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
Room = room,
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep(@"change title", () => room.Name.Value = @"A Better Room Than The Above");
|
|
||||||
AddStep(@"change host", () => room.Host.Value = new User { Username = @"DrabWeb", Id = 6946022, Country = new Country { FlagName = @"CA" } });
|
|
||||||
AddStep(@"change status", () => room.Status.Value = new RoomStatusPlaying());
|
|
||||||
AddStep(@"change type", () => room.Type.Value = new GameTypeTag());
|
|
||||||
AddStep(@"change beatmap", () => room.Beatmap.Value = null);
|
|
||||||
AddStep(@"change max participants", () => room.MaxParticipants.Value = null);
|
|
||||||
AddStep(@"change participants", () => room.Participants.Value = new[]
|
|
||||||
{
|
|
||||||
new User { Username = @"filsdelama", Id = 2831793, GlobalRank = 8542 },
|
|
||||||
new User { Username = @"_index", Id = 652457, GlobalRank = 15024 }
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep(@"change room", () =>
|
|
||||||
{
|
|
||||||
var newRoom = new Room
|
|
||||||
{
|
|
||||||
Name = { Value = @"My New, Better Than Ever Room" },
|
|
||||||
Host = { Value = new User { Username = @"Angelsim", Id = 1777162, Country = new Country { FlagName = @"KR" } } },
|
|
||||||
Status = { Value = new RoomStatusOpen() },
|
|
||||||
Type = { Value = new GameTypeTagTeam() },
|
|
||||||
Beatmap =
|
|
||||||
{
|
|
||||||
Value = new BeatmapInfo
|
|
||||||
{
|
|
||||||
StarDifficulty = 7.07,
|
|
||||||
Ruleset = rulesets.GetRuleset(0),
|
|
||||||
Metadata = new BeatmapMetadata
|
|
||||||
{
|
|
||||||
Title = @"FREEDOM DIVE",
|
|
||||||
Artist = @"xi",
|
|
||||||
Author = @"Nakagawa-Kanon",
|
|
||||||
},
|
|
||||||
BeatmapSet = new BeatmapSetInfo
|
|
||||||
{
|
|
||||||
OnlineInfo = new BeatmapSetOnlineInfo
|
|
||||||
{
|
|
||||||
Covers = new BeatmapSetOnlineCovers
|
|
||||||
{
|
|
||||||
Cover = @"https://assets.ppy.sh/beatmaps/39804/covers/cover.jpg?1456506845",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
MaxParticipants = { Value = 10 },
|
|
||||||
Participants =
|
|
||||||
{
|
|
||||||
Value = new[]
|
|
||||||
{
|
|
||||||
new User { Username = @"Angelsim", Id = 1777162, GlobalRank = 4 },
|
|
||||||
new User { Username = @"HappyStick", Id = 256802, GlobalRank = 752 },
|
|
||||||
new User { Username = @"-Konpaku-", Id = 2258797, GlobalRank = 571 }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
inspector.Room = newRoom;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load(RulesetStore rulesets)
|
|
||||||
{
|
|
||||||
this.rulesets = rulesets;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,106 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Graphics.Sprites;
|
|
||||||
using osu.Framework.MathUtils;
|
|
||||||
using osu.Game.Graphics.UserInterface;
|
|
||||||
using osu.Game.Screens.Play.HUD;
|
|
||||||
using OpenTK;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseScoreCounter : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Tests multiple counters";
|
|
||||||
|
|
||||||
public TestCaseScoreCounter()
|
|
||||||
{
|
|
||||||
int numerator = 0, denominator = 0;
|
|
||||||
|
|
||||||
ScoreCounter score = new ScoreCounter(7)
|
|
||||||
{
|
|
||||||
Origin = Anchor.TopRight,
|
|
||||||
Anchor = Anchor.TopRight,
|
|
||||||
TextSize = 40,
|
|
||||||
Margin = new MarginPadding(20),
|
|
||||||
};
|
|
||||||
Add(score);
|
|
||||||
|
|
||||||
ComboCounter comboCounter = new StandardComboCounter
|
|
||||||
{
|
|
||||||
Origin = Anchor.BottomLeft,
|
|
||||||
Anchor = Anchor.BottomLeft,
|
|
||||||
Margin = new MarginPadding(10),
|
|
||||||
TextSize = 40,
|
|
||||||
};
|
|
||||||
Add(comboCounter);
|
|
||||||
|
|
||||||
PercentageCounter accuracyCounter = new PercentageCounter
|
|
||||||
{
|
|
||||||
Origin = Anchor.TopRight,
|
|
||||||
Anchor = Anchor.TopRight,
|
|
||||||
Position = new Vector2(-20, 60),
|
|
||||||
};
|
|
||||||
Add(accuracyCounter);
|
|
||||||
|
|
||||||
StarCounter stars = new StarCounter
|
|
||||||
{
|
|
||||||
Origin = Anchor.BottomLeft,
|
|
||||||
Anchor = Anchor.BottomLeft,
|
|
||||||
Position = new Vector2(20, -160),
|
|
||||||
CountStars = 5,
|
|
||||||
};
|
|
||||||
Add(stars);
|
|
||||||
|
|
||||||
SpriteText starsLabel = new SpriteText
|
|
||||||
{
|
|
||||||
Origin = Anchor.BottomLeft,
|
|
||||||
Anchor = Anchor.BottomLeft,
|
|
||||||
Position = new Vector2(20, -190),
|
|
||||||
Text = stars.CountStars.ToString("0.00"),
|
|
||||||
};
|
|
||||||
Add(starsLabel);
|
|
||||||
|
|
||||||
AddStep(@"Reset all", delegate
|
|
||||||
{
|
|
||||||
score.Current.Value = 0;
|
|
||||||
comboCounter.Current.Value = 0;
|
|
||||||
numerator = denominator = 0;
|
|
||||||
accuracyCounter.SetFraction(0, 0);
|
|
||||||
stars.CountStars = 0;
|
|
||||||
starsLabel.Text = stars.CountStars.ToString("0.00");
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep(@"Hit! :D", delegate
|
|
||||||
{
|
|
||||||
score.Current.Value += 300 + (ulong)(300.0 * (comboCounter.Current > 0 ? comboCounter.Current - 1 : 0) / 25.0);
|
|
||||||
comboCounter.Increment();
|
|
||||||
numerator++;
|
|
||||||
denominator++;
|
|
||||||
accuracyCounter.SetFraction(numerator, denominator);
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep(@"miss...", delegate
|
|
||||||
{
|
|
||||||
comboCounter.Current.Value = 0;
|
|
||||||
denominator++;
|
|
||||||
accuracyCounter.SetFraction(numerator, denominator);
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep(@"Alter stars", delegate
|
|
||||||
{
|
|
||||||
stars.CountStars = RNG.NextSingle() * (stars.StarCount + 1);
|
|
||||||
starsLabel.Text = stars.CountStars.ToString("0.00");
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep(@"Stop counters", delegate
|
|
||||||
{
|
|
||||||
score.StopRolling();
|
|
||||||
comboCounter.StopRolling();
|
|
||||||
accuracyCounter.StopRolling();
|
|
||||||
stars.StopAnimation();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,220 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using NUnit.Framework;
|
|
||||||
using OpenTK;
|
|
||||||
using osu.Desktop.Tests.Beatmaps;
|
|
||||||
using osu.Framework.Extensions.IEnumerableExtensions;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Framework.Graphics.Shapes;
|
|
||||||
using osu.Framework.Input;
|
|
||||||
using osu.Framework.Timing;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Game.Beatmaps.ControlPoints;
|
|
||||||
using osu.Game.Rulesets.Beatmaps;
|
|
||||||
using osu.Game.Rulesets.Judgements;
|
|
||||||
using osu.Game.Rulesets.Objects;
|
|
||||||
using osu.Game.Rulesets.Objects.Drawables;
|
|
||||||
using osu.Game.Rulesets.Scoring;
|
|
||||||
using osu.Game.Rulesets.Timing;
|
|
||||||
using osu.Game.Rulesets.UI;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// The most minimal implementation of a playfield with scrolling hit objects.
|
|
||||||
/// </summary>
|
|
||||||
[TestFixture]
|
|
||||||
public class TestCaseScrollingPlayfield : OsuTestCase
|
|
||||||
{
|
|
||||||
public TestCaseScrollingPlayfield()
|
|
||||||
{
|
|
||||||
Clock = new FramedClock();
|
|
||||||
|
|
||||||
var objects = new List<HitObject>();
|
|
||||||
|
|
||||||
int time = 1500;
|
|
||||||
for (int i = 0; i < 50; i++)
|
|
||||||
{
|
|
||||||
objects.Add(new TestHitObject { StartTime = time });
|
|
||||||
|
|
||||||
time += 500;
|
|
||||||
}
|
|
||||||
|
|
||||||
Beatmap b = new Beatmap
|
|
||||||
{
|
|
||||||
HitObjects = objects,
|
|
||||||
BeatmapInfo = new BeatmapInfo
|
|
||||||
{
|
|
||||||
Difficulty = new BeatmapDifficulty(),
|
|
||||||
Metadata = new BeatmapMetadata()
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
WorkingBeatmap beatmap = new TestWorkingBeatmap(b);
|
|
||||||
|
|
||||||
TestRulesetContainer horizontalRulesetContainer;
|
|
||||||
Add(horizontalRulesetContainer = new TestRulesetContainer(Axes.X, beatmap, true));
|
|
||||||
|
|
||||||
TestRulesetContainer verticalRulesetContainer;
|
|
||||||
Add(verticalRulesetContainer = new TestRulesetContainer(Axes.Y, beatmap, true));
|
|
||||||
|
|
||||||
AddStep("Reverse direction", () =>
|
|
||||||
{
|
|
||||||
horizontalRulesetContainer.Playfield.Reverse();
|
|
||||||
verticalRulesetContainer.Playfield.Reverse();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
[Test]
|
|
||||||
public void TestSpeedAdjustmentOrdering()
|
|
||||||
{
|
|
||||||
var hitObjectContainer = new ScrollingPlayfield.ScrollingHitObjectContainer(Axes.X);
|
|
||||||
|
|
||||||
var speedAdjustments = new[]
|
|
||||||
{
|
|
||||||
new SpeedAdjustmentContainer(new MultiplierControlPoint()),
|
|
||||||
new SpeedAdjustmentContainer(new MultiplierControlPoint(1000)
|
|
||||||
{
|
|
||||||
TimingPoint = new TimingControlPoint { BeatLength = 500 }
|
|
||||||
}),
|
|
||||||
new SpeedAdjustmentContainer(new MultiplierControlPoint(2000)
|
|
||||||
{
|
|
||||||
TimingPoint = new TimingControlPoint { BeatLength = 1000 },
|
|
||||||
DifficultyPoint = new DifficultyControlPoint { SpeedMultiplier = 2}
|
|
||||||
}),
|
|
||||||
new SpeedAdjustmentContainer(new MultiplierControlPoint(3000)
|
|
||||||
{
|
|
||||||
TimingPoint = new TimingControlPoint { BeatLength = 1000 },
|
|
||||||
DifficultyPoint = new DifficultyControlPoint { SpeedMultiplier = 1}
|
|
||||||
}),
|
|
||||||
};
|
|
||||||
|
|
||||||
var hitObjects = new[]
|
|
||||||
{
|
|
||||||
new DrawableTestHitObject(Axes.X, new TestHitObject { StartTime = -1000 }),
|
|
||||||
new DrawableTestHitObject(Axes.X, new TestHitObject()),
|
|
||||||
new DrawableTestHitObject(Axes.X, new TestHitObject { StartTime = 1000 }),
|
|
||||||
new DrawableTestHitObject(Axes.X, new TestHitObject { StartTime = 2000 }),
|
|
||||||
new DrawableTestHitObject(Axes.X, new TestHitObject { StartTime = 3000 }),
|
|
||||||
new DrawableTestHitObject(Axes.X, new TestHitObject { StartTime = 4000 }),
|
|
||||||
};
|
|
||||||
|
|
||||||
hitObjects.ForEach(h => hitObjectContainer.Add(h));
|
|
||||||
speedAdjustments.ForEach(hitObjectContainer.AddSpeedAdjustment);
|
|
||||||
|
|
||||||
// The 0th index in hitObjectContainer.SpeedAdjustments is the "default" control point
|
|
||||||
// Check multiplier of the default speed adjustment
|
|
||||||
Assert.AreEqual(1, hitObjectContainer.SpeedAdjustments[0].ControlPoint.Multiplier);
|
|
||||||
Assert.AreEqual(1, speedAdjustments[0].ControlPoint.Multiplier);
|
|
||||||
Assert.AreEqual(2, speedAdjustments[1].ControlPoint.Multiplier);
|
|
||||||
Assert.AreEqual(2, speedAdjustments[2].ControlPoint.Multiplier);
|
|
||||||
Assert.AreEqual(1, speedAdjustments[3].ControlPoint.Multiplier);
|
|
||||||
|
|
||||||
// Check insertion of hit objects
|
|
||||||
Assert.IsTrue(hitObjectContainer.SpeedAdjustments[4].Contains(hitObjects[0]));
|
|
||||||
Assert.IsTrue(hitObjectContainer.SpeedAdjustments[3].Contains(hitObjects[1]));
|
|
||||||
Assert.IsTrue(hitObjectContainer.SpeedAdjustments[2].Contains(hitObjects[2]));
|
|
||||||
Assert.IsTrue(hitObjectContainer.SpeedAdjustments[1].Contains(hitObjects[3]));
|
|
||||||
Assert.IsTrue(hitObjectContainer.SpeedAdjustments[0].Contains(hitObjects[4]));
|
|
||||||
Assert.IsTrue(hitObjectContainer.SpeedAdjustments[0].Contains(hitObjects[5]));
|
|
||||||
|
|
||||||
hitObjectContainer.RemoveSpeedAdjustment(hitObjectContainer.SpeedAdjustments[3]);
|
|
||||||
|
|
||||||
// The hit object contained in this speed adjustment should be resorted into the one occuring before it
|
|
||||||
|
|
||||||
Assert.IsTrue(hitObjectContainer.SpeedAdjustments[3].Contains(hitObjects[1]));
|
|
||||||
}
|
|
||||||
|
|
||||||
private class TestRulesetContainer : ScrollingRulesetContainer<TestPlayfield, TestHitObject>
|
|
||||||
{
|
|
||||||
private readonly Axes scrollingAxes;
|
|
||||||
|
|
||||||
public TestRulesetContainer(Axes scrollingAxes, WorkingBeatmap beatmap, bool isForCurrentRuleset)
|
|
||||||
: base(null, beatmap, isForCurrentRuleset)
|
|
||||||
{
|
|
||||||
this.scrollingAxes = scrollingAxes;
|
|
||||||
}
|
|
||||||
|
|
||||||
public new TestPlayfield Playfield => base.Playfield;
|
|
||||||
|
|
||||||
public override ScoreProcessor CreateScoreProcessor() => new TestScoreProcessor();
|
|
||||||
|
|
||||||
public override PassThroughInputManager CreateInputManager() => new PassThroughInputManager();
|
|
||||||
|
|
||||||
protected override BeatmapConverter<TestHitObject> CreateBeatmapConverter() => new TestBeatmapConverter();
|
|
||||||
|
|
||||||
protected override Playfield CreatePlayfield() => new TestPlayfield(scrollingAxes);
|
|
||||||
|
|
||||||
protected override DrawableHitObject<TestHitObject> GetVisualRepresentation(TestHitObject h) => new DrawableTestHitObject(scrollingAxes, h);
|
|
||||||
}
|
|
||||||
|
|
||||||
private class TestScoreProcessor : ScoreProcessor<TestHitObject>
|
|
||||||
{
|
|
||||||
protected override void OnNewJudgement(Judgement judgement)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private class TestBeatmapConverter : BeatmapConverter<TestHitObject>
|
|
||||||
{
|
|
||||||
protected override IEnumerable<Type> ValidConversionTypes => new[] { typeof(HitObject) };
|
|
||||||
|
|
||||||
protected override IEnumerable<TestHitObject> ConvertHitObject(HitObject original, Beatmap beatmap)
|
|
||||||
{
|
|
||||||
yield return original as TestHitObject;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private class DrawableTestHitObject : DrawableScrollingHitObject<TestHitObject>
|
|
||||||
{
|
|
||||||
public DrawableTestHitObject(Axes scrollingAxes, TestHitObject hitObject)
|
|
||||||
: base(hitObject)
|
|
||||||
{
|
|
||||||
Anchor = scrollingAxes == Axes.Y ? Anchor.TopCentre : Anchor.CentreLeft;
|
|
||||||
Origin = Anchor.Centre;
|
|
||||||
|
|
||||||
AutoSizeAxes = Axes.Both;
|
|
||||||
|
|
||||||
Add(new Circle
|
|
||||||
{
|
|
||||||
Size = new Vector2(50)
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void UpdateState(ArmedState state)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private class TestPlayfield : ScrollingPlayfield
|
|
||||||
{
|
|
||||||
protected override Container<Drawable> Content => content;
|
|
||||||
private readonly Container<Drawable> content;
|
|
||||||
|
|
||||||
public TestPlayfield(Axes scrollingAxes)
|
|
||||||
: base(scrollingAxes)
|
|
||||||
{
|
|
||||||
InternalChildren = new Drawable[]
|
|
||||||
{
|
|
||||||
new Box
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Alpha = 0.2f
|
|
||||||
},
|
|
||||||
content = new Container { RelativeSizeAxes = Axes.Both }
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
public void Reverse() => Reversed.Toggle();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
private class TestHitObject : HitObject
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,25 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Game.Overlays;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseSettings : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Tests the settings overlay";
|
|
||||||
|
|
||||||
private readonly SettingsOverlay settings;
|
|
||||||
|
|
||||||
public TestCaseSettings()
|
|
||||||
{
|
|
||||||
Children = new[] { settings = new MainSettings() };
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void LoadComplete()
|
|
||||||
{
|
|
||||||
base.LoadComplete();
|
|
||||||
settings.ToggleVisibility();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,19 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Game.Screens.Play;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseSkipButton : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Skip skip skippediskip";
|
|
||||||
|
|
||||||
protected override void LoadComplete()
|
|
||||||
{
|
|
||||||
base.LoadComplete();
|
|
||||||
|
|
||||||
Add(new SkipButton(Clock.CurrentTime + 5000));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,82 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Game.Overlays;
|
|
||||||
using osu.Game.Users;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
public class TestCaseSocial : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"social browser overlay";
|
|
||||||
|
|
||||||
public TestCaseSocial()
|
|
||||||
{
|
|
||||||
SocialOverlay s = new SocialOverlay
|
|
||||||
{
|
|
||||||
Users = new[]
|
|
||||||
{
|
|
||||||
new User
|
|
||||||
{
|
|
||||||
Username = @"flyte",
|
|
||||||
Id = 3103765,
|
|
||||||
Country = new Country { FlagName = @"JP" },
|
|
||||||
CoverUrl = @"https://osu.ppy.sh/images/headers/profile-covers/c1.jpg",
|
|
||||||
},
|
|
||||||
new User
|
|
||||||
{
|
|
||||||
Username = @"Cookiezi",
|
|
||||||
Id = 124493,
|
|
||||||
Country = new Country { FlagName = @"KR" },
|
|
||||||
CoverUrl = @"https://osu.ppy.sh/images/headers/profile-covers/c2.jpg",
|
|
||||||
},
|
|
||||||
new User
|
|
||||||
{
|
|
||||||
Username = @"Angelsim",
|
|
||||||
Id = 1777162,
|
|
||||||
Country = new Country { FlagName = @"KR" },
|
|
||||||
CoverUrl = @"https://osu.ppy.sh/images/headers/profile-covers/c3.jpg",
|
|
||||||
},
|
|
||||||
new User
|
|
||||||
{
|
|
||||||
Username = @"Rafis",
|
|
||||||
Id = 2558286,
|
|
||||||
Country = new Country { FlagName = @"PL" },
|
|
||||||
CoverUrl = @"https://osu.ppy.sh/images/headers/profile-covers/c4.jpg",
|
|
||||||
},
|
|
||||||
new User
|
|
||||||
{
|
|
||||||
Username = @"hvick225",
|
|
||||||
Id = 50265,
|
|
||||||
Country = new Country { FlagName = @"TW" },
|
|
||||||
CoverUrl = @"https://osu.ppy.sh/images/headers/profile-covers/c5.jpg",
|
|
||||||
},
|
|
||||||
new User
|
|
||||||
{
|
|
||||||
Username = @"peppy",
|
|
||||||
Id = 2,
|
|
||||||
Country = new Country { FlagName = @"AU" },
|
|
||||||
CoverUrl = @"https://osu.ppy.sh/images/headers/profile-covers/c6.jpg"
|
|
||||||
},
|
|
||||||
new User
|
|
||||||
{
|
|
||||||
Username = @"filsdelama",
|
|
||||||
Id = 2831793,
|
|
||||||
Country = new Country { FlagName = @"FR" },
|
|
||||||
CoverUrl = @"https://osu.ppy.sh/images/headers/profile-covers/c7.jpg"
|
|
||||||
},
|
|
||||||
new User
|
|
||||||
{
|
|
||||||
Username = @"_index",
|
|
||||||
Id = 652457,
|
|
||||||
Country = new Country { FlagName = @"RU" },
|
|
||||||
CoverUrl = @"https://osu.ppy.sh/images/headers/profile-covers/c8.jpg"
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
Add(s);
|
|
||||||
|
|
||||||
AddStep(@"toggle", s.ToggleVisibility);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,64 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.MathUtils;
|
|
||||||
using osu.Framework.Timing;
|
|
||||||
using osu.Game.Rulesets.Objects;
|
|
||||||
using osu.Game.Screens.Play;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseSongProgress : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"With fake data";
|
|
||||||
|
|
||||||
private readonly SongProgress progress;
|
|
||||||
private readonly SongProgressGraph graph;
|
|
||||||
|
|
||||||
private readonly StopwatchClock clock;
|
|
||||||
|
|
||||||
public TestCaseSongProgress()
|
|
||||||
{
|
|
||||||
clock = new StopwatchClock(true);
|
|
||||||
|
|
||||||
Add(progress = new SongProgress
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.X,
|
|
||||||
AudioClock = new StopwatchClock(true),
|
|
||||||
Anchor = Anchor.BottomLeft,
|
|
||||||
Origin = Anchor.BottomLeft,
|
|
||||||
});
|
|
||||||
|
|
||||||
Add(graph = new SongProgressGraph
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.X,
|
|
||||||
Height = 200,
|
|
||||||
Anchor = Anchor.TopLeft,
|
|
||||||
Origin = Anchor.TopLeft,
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep("Toggle Bar", () => progress.AllowSeeking = !progress.AllowSeeking);
|
|
||||||
AddWaitStep(5);
|
|
||||||
AddStep("Toggle Bar", () => progress.AllowSeeking = !progress.AllowSeeking);
|
|
||||||
AddWaitStep(2);
|
|
||||||
AddRepeatStep("New Values", displayNewValues, 5);
|
|
||||||
|
|
||||||
displayNewValues();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void displayNewValues()
|
|
||||||
{
|
|
||||||
List<HitObject> objects = new List<HitObject>();
|
|
||||||
for (double i = 0; i < 5000; i += RNG.NextDouble() * 10 + i / 1000)
|
|
||||||
objects.Add(new HitObject { StartTime = i });
|
|
||||||
|
|
||||||
progress.Objects = objects;
|
|
||||||
graph.Objects = objects;
|
|
||||||
|
|
||||||
progress.AudioClock = clock;
|
|
||||||
progress.OnSeek = pos => clock.Seek(pos);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,90 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using OpenTK.Graphics;
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Framework.Configuration;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Framework.Graphics.Shapes;
|
|
||||||
using osu.Framework.Timing;
|
|
||||||
using osu.Game;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Game.Overlays;
|
|
||||||
using osu.Game.Storyboards.Drawables;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseStoryboard : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Tests storyboards.";
|
|
||||||
|
|
||||||
private readonly Bindable<WorkingBeatmap> beatmapBacking = new Bindable<WorkingBeatmap>();
|
|
||||||
|
|
||||||
private readonly Container<DrawableStoryboard> storyboardContainer;
|
|
||||||
private DrawableStoryboard storyboard;
|
|
||||||
|
|
||||||
public TestCaseStoryboard()
|
|
||||||
{
|
|
||||||
Clock = new FramedClock();
|
|
||||||
|
|
||||||
Add(new Container
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Children = new Drawable[]
|
|
||||||
{
|
|
||||||
new Box
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Colour = Color4.Black,
|
|
||||||
},
|
|
||||||
storyboardContainer = new Container<DrawableStoryboard>
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
});
|
|
||||||
Add(new MusicController
|
|
||||||
{
|
|
||||||
Origin = Anchor.TopRight,
|
|
||||||
Anchor = Anchor.TopRight,
|
|
||||||
State = Visibility.Visible,
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep("Restart", restart);
|
|
||||||
AddToggleStep("Passing", passing => { if (storyboard != null) storyboard.Passing = passing; });
|
|
||||||
}
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load(OsuGameBase game)
|
|
||||||
{
|
|
||||||
beatmapBacking.BindTo(game.Beatmap);
|
|
||||||
beatmapBacking.ValueChanged += beatmapChanged;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void beatmapChanged(WorkingBeatmap working)
|
|
||||||
=> loadStoryboard(working);
|
|
||||||
|
|
||||||
private void restart()
|
|
||||||
{
|
|
||||||
var track = beatmapBacking.Value.Track;
|
|
||||||
|
|
||||||
track.Reset();
|
|
||||||
loadStoryboard(beatmapBacking.Value);
|
|
||||||
track.Start();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void loadStoryboard(WorkingBeatmap working)
|
|
||||||
{
|
|
||||||
if (storyboard != null)
|
|
||||||
storyboardContainer.Remove(storyboard);
|
|
||||||
|
|
||||||
var decoupledClock = new DecoupleableInterpolatingFramedClock { IsCoupled = true };
|
|
||||||
decoupledClock.ChangeSource(working.Track);
|
|
||||||
storyboardContainer.Clock = decoupledClock;
|
|
||||||
|
|
||||||
storyboardContainer.Add(storyboard = working.Beatmap.Storyboard.CreateDrawable());
|
|
||||||
storyboard.Passing = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,42 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Game.Graphics.Sprites;
|
|
||||||
using osu.Game.Graphics.UserInterface;
|
|
||||||
using osu.Game.Screens.Select.Filter;
|
|
||||||
using OpenTK;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
public class TestCaseTabControl : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Filter for song select";
|
|
||||||
|
|
||||||
public TestCaseTabControl()
|
|
||||||
{
|
|
||||||
OsuSpriteText text;
|
|
||||||
OsuTabControl<GroupMode> filter;
|
|
||||||
Add(filter = new OsuTabControl<GroupMode>
|
|
||||||
{
|
|
||||||
Margin = new MarginPadding(4),
|
|
||||||
Size = new Vector2(229, 24),
|
|
||||||
AutoSort = true
|
|
||||||
});
|
|
||||||
Add(text = new OsuSpriteText
|
|
||||||
{
|
|
||||||
Text = "None",
|
|
||||||
Margin = new MarginPadding(4),
|
|
||||||
Position = new Vector2(275, 5)
|
|
||||||
});
|
|
||||||
|
|
||||||
filter.PinItem(GroupMode.All);
|
|
||||||
filter.PinItem(GroupMode.RecentlyPlayed);
|
|
||||||
|
|
||||||
filter.Current.ValueChanged += newFilter =>
|
|
||||||
{
|
|
||||||
text.Text = "Currently Selected: " + newFilter.ToString();
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,229 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Framework.MathUtils;
|
|
||||||
using osu.Framework.Timing;
|
|
||||||
using osu.Game.Rulesets.Objects.Drawables;
|
|
||||||
using osu.Game.Rulesets.Taiko.Judgements;
|
|
||||||
using osu.Game.Rulesets.Taiko.Objects;
|
|
||||||
using osu.Game.Rulesets.Taiko.Objects.Drawables;
|
|
||||||
using osu.Game.Rulesets.Taiko.UI;
|
|
||||||
using OpenTK;
|
|
||||||
using osu.Game.Beatmaps.ControlPoints;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Desktop.Tests.Beatmaps;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Game.Rulesets;
|
|
||||||
using osu.Game.Rulesets.Objects;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseTaikoPlayfield : OsuTestCase
|
|
||||||
{
|
|
||||||
private const double default_duration = 1000;
|
|
||||||
private const float scroll_time = 1000;
|
|
||||||
|
|
||||||
public override string Description => "Taiko playfield";
|
|
||||||
|
|
||||||
protected override double TimePerAction => default_duration * 2;
|
|
||||||
|
|
||||||
private readonly Random rng = new Random(1337);
|
|
||||||
private TaikoRulesetContainer rulesetContainer;
|
|
||||||
private Container playfieldContainer;
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load(RulesetStore rulesets)
|
|
||||||
{
|
|
||||||
AddStep("Hit!", () => addHitJudgement(false));
|
|
||||||
AddStep("Kiai hit", () => addHitJudgement(true));
|
|
||||||
AddStep("Miss :(", addMissJudgement);
|
|
||||||
AddStep("DrumRoll", () => addDrumRoll(false));
|
|
||||||
AddStep("Strong DrumRoll", () => addDrumRoll(true));
|
|
||||||
AddStep("Swell", () => addSwell());
|
|
||||||
AddStep("Centre", () => addCentreHit(false));
|
|
||||||
AddStep("Strong Centre", () => addCentreHit(true));
|
|
||||||
AddStep("Rim", () => addRimHit(false));
|
|
||||||
AddStep("Strong Rim", () => addRimHit(true));
|
|
||||||
AddStep("Add bar line", () => addBarLine(false));
|
|
||||||
AddStep("Add major bar line", () => addBarLine(true));
|
|
||||||
AddStep("Height test 1", () => changePlayfieldSize(1));
|
|
||||||
AddStep("Height test 2", () => changePlayfieldSize(2));
|
|
||||||
AddStep("Height test 3", () => changePlayfieldSize(3));
|
|
||||||
AddStep("Height test 4", () => changePlayfieldSize(4));
|
|
||||||
AddStep("Height test 5", () => changePlayfieldSize(5));
|
|
||||||
AddStep("Reset height", () => changePlayfieldSize(6));
|
|
||||||
|
|
||||||
var controlPointInfo = new ControlPointInfo();
|
|
||||||
controlPointInfo.TimingPoints.Add(new TimingControlPoint());
|
|
||||||
|
|
||||||
WorkingBeatmap beatmap = new TestWorkingBeatmap(new Beatmap
|
|
||||||
{
|
|
||||||
HitObjects = new List<HitObject> { new CentreHit() },
|
|
||||||
BeatmapInfo = new BeatmapInfo
|
|
||||||
{
|
|
||||||
Difficulty = new BeatmapDifficulty(),
|
|
||||||
Metadata = new BeatmapMetadata
|
|
||||||
{
|
|
||||||
Artist = @"Unknown",
|
|
||||||
Title = @"Sample Beatmap",
|
|
||||||
Author = @"peppy",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
ControlPointInfo = controlPointInfo
|
|
||||||
});
|
|
||||||
|
|
||||||
var rateAdjustClock = new StopwatchClock(true) { Rate = 1 };
|
|
||||||
|
|
||||||
Add(playfieldContainer = new Container
|
|
||||||
{
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
RelativeSizeAxes = Axes.X,
|
|
||||||
Height = 768,
|
|
||||||
Clock = new FramedClock(rateAdjustClock),
|
|
||||||
Children = new[] { rulesetContainer = new TaikoRulesetContainer(rulesets.GetRuleset(1).CreateInstance(), beatmap, true) }
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private void changePlayfieldSize(int step)
|
|
||||||
{
|
|
||||||
double delay = 0;
|
|
||||||
|
|
||||||
// Add new hits
|
|
||||||
switch (step)
|
|
||||||
{
|
|
||||||
case 1:
|
|
||||||
addCentreHit(false);
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
addCentreHit(true);
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
addDrumRoll(false);
|
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
addDrumRoll(true);
|
|
||||||
break;
|
|
||||||
case 5:
|
|
||||||
addSwell();
|
|
||||||
delay = scroll_time - 100;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tween playfield height
|
|
||||||
switch (step)
|
|
||||||
{
|
|
||||||
default:
|
|
||||||
playfieldContainer.Delay(delay).ResizeTo(new Vector2(1, rng.Next(25, 400)), 500);
|
|
||||||
break;
|
|
||||||
case 6:
|
|
||||||
playfieldContainer.Delay(delay).ResizeTo(new Vector2(1, TaikoPlayfield.DEFAULT_HEIGHT), 500);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void addHitJudgement(bool kiai)
|
|
||||||
{
|
|
||||||
HitResult hitResult = RNG.Next(2) == 0 ? HitResult.Good : HitResult.Great;
|
|
||||||
|
|
||||||
var cpi = new ControlPointInfo();
|
|
||||||
cpi.EffectPoints.Add(new EffectControlPoint
|
|
||||||
{
|
|
||||||
KiaiMode = kiai
|
|
||||||
});
|
|
||||||
|
|
||||||
Hit hit = new Hit();
|
|
||||||
hit.ApplyDefaults(cpi, new BeatmapDifficulty());
|
|
||||||
|
|
||||||
var h = new DrawableTestHit(hit) { X = RNG.NextSingle(hitResult == HitResult.Good ? -0.1f : -0.05f, hitResult == HitResult.Good ? 0.1f : 0.05f) };
|
|
||||||
|
|
||||||
rulesetContainer.Playfield.OnJudgement(h, new TaikoJudgement { Result = hitResult });
|
|
||||||
|
|
||||||
if (RNG.Next(10) == 0)
|
|
||||||
{
|
|
||||||
rulesetContainer.Playfield.OnJudgement(h, new TaikoJudgement { Result = hitResult });
|
|
||||||
rulesetContainer.Playfield.OnJudgement(h, new TaikoStrongHitJudgement());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void addMissJudgement()
|
|
||||||
{
|
|
||||||
rulesetContainer.Playfield.OnJudgement(new DrawableTestHit(new Hit()), new TaikoJudgement { Result = HitResult.Miss });
|
|
||||||
}
|
|
||||||
|
|
||||||
private void addBarLine(bool major, double delay = scroll_time)
|
|
||||||
{
|
|
||||||
BarLine bl = new BarLine { StartTime = rulesetContainer.Playfield.Time.Current + delay };
|
|
||||||
|
|
||||||
rulesetContainer.Playfield.Add(major ? new DrawableBarLineMajor(bl) : new DrawableBarLine(bl));
|
|
||||||
}
|
|
||||||
|
|
||||||
private void addSwell(double duration = default_duration)
|
|
||||||
{
|
|
||||||
rulesetContainer.Playfield.Add(new DrawableSwell(new Swell
|
|
||||||
{
|
|
||||||
StartTime = rulesetContainer.Playfield.Time.Current + scroll_time,
|
|
||||||
Duration = duration,
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
|
|
||||||
private void addDrumRoll(bool strong, double duration = default_duration)
|
|
||||||
{
|
|
||||||
addBarLine(true);
|
|
||||||
addBarLine(true, scroll_time + duration);
|
|
||||||
|
|
||||||
var d = new DrumRoll
|
|
||||||
{
|
|
||||||
StartTime = rulesetContainer.Playfield.Time.Current + scroll_time,
|
|
||||||
IsStrong = strong,
|
|
||||||
Duration = duration,
|
|
||||||
};
|
|
||||||
|
|
||||||
rulesetContainer.Playfield.Add(new DrawableDrumRoll(d));
|
|
||||||
}
|
|
||||||
|
|
||||||
private void addCentreHit(bool strong)
|
|
||||||
{
|
|
||||||
Hit h = new Hit
|
|
||||||
{
|
|
||||||
StartTime = rulesetContainer.Playfield.Time.Current + scroll_time,
|
|
||||||
IsStrong = strong
|
|
||||||
};
|
|
||||||
|
|
||||||
if (strong)
|
|
||||||
rulesetContainer.Playfield.Add(new DrawableCentreHitStrong(h));
|
|
||||||
else
|
|
||||||
rulesetContainer.Playfield.Add(new DrawableCentreHit(h));
|
|
||||||
}
|
|
||||||
|
|
||||||
private void addRimHit(bool strong)
|
|
||||||
{
|
|
||||||
Hit h = new Hit
|
|
||||||
{
|
|
||||||
StartTime = rulesetContainer.Playfield.Time.Current + scroll_time,
|
|
||||||
IsStrong = strong
|
|
||||||
};
|
|
||||||
|
|
||||||
if (strong)
|
|
||||||
rulesetContainer.Playfield.Add(new DrawableRimHitStrong(h));
|
|
||||||
else
|
|
||||||
rulesetContainer.Playfield.Add(new DrawableRimHit(h));
|
|
||||||
}
|
|
||||||
|
|
||||||
private class DrawableTestHit : DrawableHitObject<TaikoHitObject>
|
|
||||||
{
|
|
||||||
public DrawableTestHit(TaikoHitObject hitObject)
|
|
||||||
: base(hitObject)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void UpdateState(ArmedState state)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,48 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Framework.MathUtils;
|
|
||||||
using osu.Game.Graphics;
|
|
||||||
using OpenTK;
|
|
||||||
using OpenTK.Graphics;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseTextAwesome : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Tests display of icons";
|
|
||||||
|
|
||||||
public TestCaseTextAwesome()
|
|
||||||
{
|
|
||||||
FillFlowContainer flow;
|
|
||||||
|
|
||||||
Add(flow = new FillFlowContainer
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Size = new Vector2(0.5f),
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Origin = Anchor.Centre
|
|
||||||
});
|
|
||||||
|
|
||||||
int i = 50;
|
|
||||||
foreach (FontAwesome fa in Enum.GetValues(typeof(FontAwesome)))
|
|
||||||
{
|
|
||||||
flow.Add(new SpriteIcon
|
|
||||||
{
|
|
||||||
Icon = fa,
|
|
||||||
Size = new Vector2(60),
|
|
||||||
Colour = new Color4(
|
|
||||||
Math.Max(0.5f, RNG.NextSingle()),
|
|
||||||
Math.Max(0.5f, RNG.NextSingle()),
|
|
||||||
Math.Max(0.5f, RNG.NextSingle()),
|
|
||||||
1)
|
|
||||||
});
|
|
||||||
|
|
||||||
if (i-- == 0) break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,17 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Game.Graphics.UserInterface;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseTwoLayerButton : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Mostly back button";
|
|
||||||
|
|
||||||
public TestCaseTwoLayerButton()
|
|
||||||
{
|
|
||||||
Add(new BackButton());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,54 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Game.Users;
|
|
||||||
using OpenTK;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseUserPanel : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => @"Panels for displaying a user's status";
|
|
||||||
|
|
||||||
public TestCaseUserPanel()
|
|
||||||
{
|
|
||||||
UserPanel flyte;
|
|
||||||
UserPanel peppy;
|
|
||||||
Add(new FillFlowContainer
|
|
||||||
{
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
AutoSizeAxes = Axes.Both,
|
|
||||||
Spacing = new Vector2(10f),
|
|
||||||
Children = new[]
|
|
||||||
{
|
|
||||||
flyte = new UserPanel(new User
|
|
||||||
{
|
|
||||||
Username = @"flyte",
|
|
||||||
Id = 3103765,
|
|
||||||
Country = new Country { FlagName = @"JP" },
|
|
||||||
CoverUrl = @"https://osu.ppy.sh/images/headers/profile-covers/c6.jpg"
|
|
||||||
}) { Width = 300 },
|
|
||||||
peppy = new UserPanel(new User
|
|
||||||
{
|
|
||||||
Username = @"peppy",
|
|
||||||
Id = 2,
|
|
||||||
Country = new Country { FlagName = @"AU" },
|
|
||||||
CoverUrl = @"https://osu.ppy.sh/images/headers/profile-covers/c3.jpg"
|
|
||||||
}) { Width = 300 },
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
flyte.Status.Value = new UserStatusOnline();
|
|
||||||
peppy.Status.Value = new UserStatusSoloGame();
|
|
||||||
|
|
||||||
AddStep(@"spectating", () => { flyte.Status.Value = new UserStatusSpectating(); });
|
|
||||||
AddStep(@"multiplaying", () => { flyte.Status.Value = new UserStatusMultiplayerGame(); });
|
|
||||||
AddStep(@"modding", () => { flyte.Status.Value = new UserStatusModding(); });
|
|
||||||
AddStep(@"offline", () => { flyte.Status.Value = new UserStatusOffline(); });
|
|
||||||
AddStep(@"null status", () => { flyte.Status.Value = null; });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,60 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Linq;
|
|
||||||
using osu.Game.Overlays;
|
|
||||||
using osu.Game.Users;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Tests.Visual
|
|
||||||
{
|
|
||||||
internal class TestCaseUserProfile : OsuTestCase
|
|
||||||
{
|
|
||||||
public override string Description => "Tests user's profile page.";
|
|
||||||
|
|
||||||
public TestCaseUserProfile()
|
|
||||||
{
|
|
||||||
var profile = new UserProfileOverlay();
|
|
||||||
Add(profile);
|
|
||||||
|
|
||||||
AddStep("Show offline dummy", () => profile.ShowUser(new User
|
|
||||||
{
|
|
||||||
Username = @"Somebody",
|
|
||||||
Id = 1,
|
|
||||||
Country = new Country { FullName = @"Alien" },
|
|
||||||
CoverUrl = @"https://osu.ppy.sh/images/headers/profile-covers/c1.jpg",
|
|
||||||
JoinDate = DateTimeOffset.Now.AddDays(-1),
|
|
||||||
LastVisit = DateTimeOffset.Now,
|
|
||||||
Age = 1,
|
|
||||||
ProfileOrder = new[] { "me" },
|
|
||||||
CountryRank = 1,
|
|
||||||
Statistics = new UserStatistics
|
|
||||||
{
|
|
||||||
Rank = 2148,
|
|
||||||
PP = 4567.89m
|
|
||||||
},
|
|
||||||
RankHistory = new User.RankHistoryData
|
|
||||||
{
|
|
||||||
Mode = @"osu",
|
|
||||||
Data = Enumerable.Range(2345, 45).Concat(Enumerable.Range(2109, 40)).ToArray()
|
|
||||||
}
|
|
||||||
}, false));
|
|
||||||
AddStep("Show ppy", () => profile.ShowUser(new User
|
|
||||||
{
|
|
||||||
Username = @"peppy",
|
|
||||||
Id = 2,
|
|
||||||
Country = new Country { FullName = @"Australia", FlagName = @"AU" },
|
|
||||||
CoverUrl = @"https://osu.ppy.sh/images/headers/profile-covers/c3.jpg"
|
|
||||||
}));
|
|
||||||
AddStep("Show flyte", () => profile.ShowUser(new User
|
|
||||||
{
|
|
||||||
Username = @"flyte",
|
|
||||||
Id = 3103765,
|
|
||||||
Country = new Country { FullName = @"Japan", FlagName = @"JP" },
|
|
||||||
CoverUrl = @"https://osu.ppy.sh/images/headers/profile-covers/c6.jpg"
|
|
||||||
}));
|
|
||||||
AddStep("Hide", profile.Hide);
|
|
||||||
AddStep("Show without reload", profile.Show);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,11 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<configuration>
|
|
||||||
<runtime>
|
|
||||||
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
|
|
||||||
<dependentAssembly>
|
|
||||||
<assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
|
|
||||||
<bindingRedirect oldVersion="0.0.0.0-10.0.0.0" newVersion="10.0.0.0" />
|
|
||||||
</dependentAssembly>
|
|
||||||
</assemblyBinding>
|
|
||||||
</runtime>
|
|
||||||
</configuration>
|
|
@ -1,173 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<Project ToolsVersion="14.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
|
||||||
<Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
|
|
||||||
<PropertyGroup>
|
|
||||||
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
|
|
||||||
<Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
|
|
||||||
<ProjectGuid>{230AC4F3-7783-49FB-9AEC-B83CDA3B9F3D}</ProjectGuid>
|
|
||||||
<OutputType>WinExe</OutputType>
|
|
||||||
<AppDesignerFolder>Properties</AppDesignerFolder>
|
|
||||||
<RootNamespace>osu.Desktop.Tests</RootNamespace>
|
|
||||||
<AssemblyName>osu.Desktop.Tests</AssemblyName>
|
|
||||||
<TargetFrameworkVersion>v4.6.1</TargetFrameworkVersion>
|
|
||||||
<FileAlignment>512</FileAlignment>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
|
|
||||||
<DebugSymbols>true</DebugSymbols>
|
|
||||||
<DebugType>full</DebugType>
|
|
||||||
<Optimize>false</Optimize>
|
|
||||||
<OutputPath>bin\Debug\</OutputPath>
|
|
||||||
<DefineConstants>DEBUG;TRACE</DefineConstants>
|
|
||||||
<ErrorReport>prompt</ErrorReport>
|
|
||||||
<WarningLevel>4</WarningLevel>
|
|
||||||
<TreatWarningsAsErrors>false</TreatWarningsAsErrors>
|
|
||||||
<LangVersion>6</LangVersion>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
|
|
||||||
<DebugType>pdbonly</DebugType>
|
|
||||||
<Optimize>true</Optimize>
|
|
||||||
<OutputPath>bin\Release\</OutputPath>
|
|
||||||
<DefineConstants>TRACE</DefineConstants>
|
|
||||||
<ErrorReport>prompt</ErrorReport>
|
|
||||||
<WarningLevel>4</WarningLevel>
|
|
||||||
<TreatWarningsAsErrors>false</TreatWarningsAsErrors>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup>
|
|
||||||
<StartupObject />
|
|
||||||
</PropertyGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<Reference Include="mscorlib" />
|
|
||||||
<Reference Include="Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed, processorArchitecture=MSIL">
|
|
||||||
<HintPath>$(SolutionDir)\packages\Newtonsoft.Json.10.0.3\lib\net45\Newtonsoft.Json.dll</HintPath>
|
|
||||||
<Private>True</Private>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="nunit.framework, Version=3.8.1.0, Culture=neutral, PublicKeyToken=2638cd05610744eb, processorArchitecture=MSIL">
|
|
||||||
<HintPath>$(SolutionDir)\packages\NUnit.3.8.1\lib\net45\nunit.framework.dll</HintPath>
|
|
||||||
<Private>True</Private>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="OpenTK, Version=3.0.0.0, Culture=neutral, PublicKeyToken=bad199fe84eb3df4, processorArchitecture=MSIL">
|
|
||||||
<HintPath>$(SolutionDir)\packages\OpenTK.3.0.0-git00009\lib\net20\OpenTK.dll</HintPath>
|
|
||||||
<Private>True</Private>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="SQLite.Net, Version=3.1.0.0, Culture=neutral, processorArchitecture=MSIL">
|
|
||||||
<SpecificVersion>False</SpecificVersion>
|
|
||||||
<HintPath>$(SolutionDir)\packages\SQLite.Net.Core-PCL.3.1.1\lib\portable-win8+net45+wp8+wpa81+MonoAndroid1+MonoTouch1\SQLite.Net.dll</HintPath>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="System" />
|
|
||||||
<Reference Include="SQLiteNetExtensions">
|
|
||||||
<HintPath>$(SolutionDir)\packages\SQLiteNetExtensions.1.3.0\lib\portable-net45+netcore45+wpa81+wp8+MonoAndroid1+MonoTouch1\SQLiteNetExtensions.dll</HintPath>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="SQLite.Net.Platform.Win32">
|
|
||||||
<HintPath>$(SolutionDir)\packages\SQLite.Net-PCL.3.1.1\lib\net4\SQLite.Net.Platform.Win32.dll</HintPath>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="SQLite.Net.Platform.Generic">
|
|
||||||
<HintPath>$(SolutionDir)\packages\SQLite.Net-PCL.3.1.1\lib\net40\SQLite.Net.Platform.Generic.dll</HintPath>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="System.Drawing" />
|
|
||||||
<Reference Include="System.Xml" />
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<Compile Include="Beatmaps\TestWorkingBeatmap.cs" />
|
|
||||||
<Compile Include="Platform\TestStorage.cs" />
|
|
||||||
<Compile Include="Visual\OsuTestCase.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseBeatmapDetailArea.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseBeatmapDetails.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseBeatmapOptionsOverlay.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseBeatSyncedContainer.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseBreadcrumbs.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseCatcher.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseChatDisplay.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseContextMenu.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseDialogOverlay.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseDirect.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseDrawableRoom.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseDrawings.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseGamefield.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseGraph.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseHitObjects.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseKeyConfiguration.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseKeyCounter.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseLeaderboard.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseManiaHitObjects.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseManiaPlayfield.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseMedalOverlay.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseEditorMenuBar.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseMenuButtonSystem.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseMenuOverlays.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseMods.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseStoryboard.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseMusicController.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseNotificationOverlay.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseOnScreenDisplay.cs" />
|
|
||||||
<Compile Include="Visual\TestCasePlayer.cs" />
|
|
||||||
<Compile Include="Visual\TestCasePlaySongSelect.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseReplay.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseReplaySettingsOverlay.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseResults.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseRoomInspector.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseScoreCounter.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseScrollingPlayfield.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseSettings.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseSkipButton.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseSocial.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseSongProgress.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseTabControl.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseTaikoPlayfield.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseTextAwesome.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseTwoLayerButton.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseUserPanel.cs" />
|
|
||||||
<Compile Include="Visual\TestCaseUserProfile.cs" />
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<ProjectReference Include="..\osu-framework\osu.Framework\osu.Framework.csproj">
|
|
||||||
<Project>{C76BF5B3-985E-4D39-95FE-97C9C879B83A}</Project>
|
|
||||||
<Name>osu.Framework</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu-resources\osu.Game.Resources\osu.Game.Resources.csproj">
|
|
||||||
<Project>{d9a367c9-4c1a-489f-9b05-a0cea2b53b58}</Project>
|
|
||||||
<Name>osu.Game.Resources</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu.Game.Rulesets.Catch\osu.Game.Rulesets.Catch.csproj">
|
|
||||||
<Project>{58F6C80C-1253-4A0E-A465-B8C85EBEADF3}</Project>
|
|
||||||
<Name>osu.Game.Rulesets.Catch</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu.Game.Rulesets.Mania\osu.Game.Rulesets.Mania.csproj">
|
|
||||||
<Project>{48F4582B-7687-4621-9CBE-5C24197CB536}</Project>
|
|
||||||
<Name>osu.Game.Rulesets.Mania</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu.Game.Rulesets.Osu\osu.Game.Rulesets.Osu.csproj">
|
|
||||||
<Project>{C92A607B-1FDD-4954-9F92-03FF547D9080}</Project>
|
|
||||||
<Name>osu.Game.Rulesets.Osu</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu.Game.Rulesets.Taiko\osu.Game.Rulesets.Taiko.csproj">
|
|
||||||
<Project>{F167E17A-7DE6-4AF5-B920-A5112296C695}</Project>
|
|
||||||
<Name>osu.Game.Rulesets.Taiko</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu.Game\osu.Game.csproj">
|
|
||||||
<Project>{2a66dd92-adb1-4994-89e2-c94e04acda0d}</Project>
|
|
||||||
<Name>osu.Game</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<None Include="..\osu.licenseheader">
|
|
||||||
<Link>osu.licenseheader</Link>
|
|
||||||
</None>
|
|
||||||
<None Include="app.config" />
|
|
||||||
<None Include="OpenTK.dll.config" />
|
|
||||||
<None Include="packages.config" />
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<Folder Include="Properties\" />
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<Service Include="{82A7F48D-3B50-4B1E-B82E-3ADA8210C358}" />
|
|
||||||
</ItemGroup>
|
|
||||||
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
|
|
||||||
<!-- To modify your build process, add your task inside one of the targets below and uncomment it.
|
|
||||||
Other similar extension points exist, see Microsoft.Common.targets.
|
|
||||||
<Target Name="BeforeBuild">
|
|
||||||
</Target>
|
|
||||||
<Target Name="AfterBuild">
|
|
||||||
</Target>
|
|
||||||
-->
|
|
||||||
</Project>
|
|
@ -1,13 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!--
|
|
||||||
Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
-->
|
|
||||||
<packages>
|
|
||||||
<package id="Newtonsoft.Json" version="10.0.3" targetFramework="net461" />
|
|
||||||
<package id="NUnit" version="3.8.1" targetFramework="net461" />
|
|
||||||
<package id="OpenTK" version="3.0.0-git00009" targetFramework="net461" />
|
|
||||||
<package id="SQLite.Net.Core-PCL" version="3.1.1" targetFramework="net45" />
|
|
||||||
<package id="SQLite.Net-PCL" version="3.1.1" targetFramework="net45" />
|
|
||||||
<package id="SQLiteNetExtensions" version="1.3.0" targetFramework="net45" />
|
|
||||||
</packages>
|
|
@ -1,29 +0,0 @@
|
|||||||
<!--
|
|
||||||
Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
-->
|
|
||||||
<configuration>
|
|
||||||
<dllmap os="linux" dll="opengl32.dll" target="libGL.so.1"/>
|
|
||||||
<dllmap os="linux" dll="glu32.dll" target="libGLU.so.1"/>
|
|
||||||
<dllmap os="linux" dll="openal32.dll" target="libopenal.so.1"/>
|
|
||||||
<dllmap os="linux" dll="alut.dll" target="libalut.so.0"/>
|
|
||||||
<dllmap os="linux" dll="opencl.dll" target="libOpenCL.so"/>
|
|
||||||
<dllmap os="linux" dll="libX11" target="libX11.so.6"/>
|
|
||||||
<dllmap os="linux" dll="libXi" target="libXi.so.6"/>
|
|
||||||
<dllmap os="linux" dll="SDL2.dll" target="libSDL2-2.0.so.0"/>
|
|
||||||
<dllmap os="osx" dll="opengl32.dll" target="/System/Library/Frameworks/OpenGL.framework/OpenGL"/>
|
|
||||||
<dllmap os="osx" dll="openal32.dll" target="/System/Library/Frameworks/OpenAL.framework/OpenAL" />
|
|
||||||
<dllmap os="osx" dll="alut.dll" target="/System/Library/Frameworks/OpenAL.framework/OpenAL" />
|
|
||||||
<dllmap os="osx" dll="libGLES.dll" target="/System/Library/Frameworks/OpenGLES.framework/OpenGLES" />
|
|
||||||
<dllmap os="osx" dll="libGLESv1_CM.dll" target="/System/Library/Frameworks/OpenGLES.framework/OpenGLES" />
|
|
||||||
<dllmap os="osx" dll="libGLESv2.dll" target="/System/Library/Frameworks/OpenGLES.framework/OpenGLES" />
|
|
||||||
<dllmap os="osx" dll="opencl.dll" target="/System/Library/Frameworks/OpenCL.framework/OpenCL"/>
|
|
||||||
<dllmap os="osx" dll="SDL2.dll" target="libSDL2.dylib"/>
|
|
||||||
<!-- XQuartz compatibility (X11 on Mac) -->
|
|
||||||
<dllmap os="osx" dll="libGL.so.1" target="/usr/X11/lib/libGL.dylib"/>
|
|
||||||
<dllmap os="osx" dll="libX11" target="/usr/X11/lib/libX11.dylib"/>
|
|
||||||
<dllmap os="osx" dll="libXcursor.so.1" target="/usr/X11/lib/libXcursor.dylib"/>
|
|
||||||
<dllmap os="osx" dll="libXi" target="/usr/X11/lib/libXi.dylib"/>
|
|
||||||
<dllmap os="osx" dll="libXinerama" target="/usr/X11/lib/libXinerama.dylib"/>
|
|
||||||
<dllmap os="osx" dll="libXrandr.so.2" target="/usr/X11/lib/libXrandr.dylib"/>
|
|
||||||
</configuration>
|
|
@ -1,27 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using osu.Framework.Desktop;
|
|
||||||
using osu.Framework.Platform;
|
|
||||||
using osu.Framework.VisualTests;
|
|
||||||
|
|
||||||
namespace osu.Desktop.VisualTests
|
|
||||||
{
|
|
||||||
public static class Program
|
|
||||||
{
|
|
||||||
[STAThread]
|
|
||||||
public static void Main(string[] args)
|
|
||||||
{
|
|
||||||
bool benchmark = args.Length > 0 && args[0] == @"-benchmark";
|
|
||||||
|
|
||||||
using (GameHost host = Host.GetSuitableHost(@"osu"))
|
|
||||||
{
|
|
||||||
if (benchmark)
|
|
||||||
host.Run(new AutomatedVisualTestGame());
|
|
||||||
else
|
|
||||||
host.Run(new VisualTestGame());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,35 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Framework.Platform;
|
|
||||||
using osu.Framework.VisualTests;
|
|
||||||
using osu.Game;
|
|
||||||
using osu.Game.Screens.Backgrounds;
|
|
||||||
|
|
||||||
namespace osu.Desktop.VisualTests
|
|
||||||
{
|
|
||||||
internal class VisualTestGame : OsuGameBase
|
|
||||||
{
|
|
||||||
protected override void LoadComplete()
|
|
||||||
{
|
|
||||||
base.LoadComplete();
|
|
||||||
|
|
||||||
LoadComponentAsync(new BackgroundScreenDefault { Depth = 10 }, AddInternal);
|
|
||||||
|
|
||||||
// Have to construct this here, rather than in the constructor, because
|
|
||||||
// we depend on some dependencies to be loaded within OsuGameBase.load().
|
|
||||||
Add(new TestBrowser());
|
|
||||||
}
|
|
||||||
|
|
||||||
public override void SetHost(GameHost host)
|
|
||||||
{
|
|
||||||
base.SetHost(host);
|
|
||||||
|
|
||||||
host.UpdateThread.InactiveHz = host.UpdateThread.ActiveHz;
|
|
||||||
host.DrawThread.InactiveHz = host.DrawThread.ActiveHz;
|
|
||||||
host.InputThread.InactiveHz = host.InputThread.ActiveHz;
|
|
||||||
|
|
||||||
host.Window.CursorState |= CursorState.Hidden;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,214 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<Project DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003" ToolsVersion="4.0">
|
|
||||||
<PropertyGroup>
|
|
||||||
<ProjectGuid>{69051C69-12AE-4E7D-A3E6-460D2E282312}</ProjectGuid>
|
|
||||||
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
|
|
||||||
<Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
|
|
||||||
<OutputType>WinExe</OutputType>
|
|
||||||
<AppDesignerFolder>Properties</AppDesignerFolder>
|
|
||||||
<RootNamespace>osu.Desktop.VisualTests</RootNamespace>
|
|
||||||
<AssemblyName>osu!</AssemblyName>
|
|
||||||
<ManifestCertificateThumbprint>3CF060CD28877D0E3112948951A64B2A7CEEC909</ManifestCertificateThumbprint>
|
|
||||||
<ManifestKeyFile>codesigning.pfx</ManifestKeyFile>
|
|
||||||
<GenerateManifests>false</GenerateManifests>
|
|
||||||
<SignManifests>false</SignManifests>
|
|
||||||
<IsWebBootstrapper>false</IsWebBootstrapper>
|
|
||||||
<FileUpgradeFlags>
|
|
||||||
</FileUpgradeFlags>
|
|
||||||
<OldToolsVersion>3.5</OldToolsVersion>
|
|
||||||
<UpgradeBackupLocation>
|
|
||||||
</UpgradeBackupLocation>
|
|
||||||
<StartupObject>osu.Desktop.VisualTests.Program</StartupObject>
|
|
||||||
<RunPostBuildEvent>OnOutputUpdated</RunPostBuildEvent>
|
|
||||||
<SignAssembly>false</SignAssembly>
|
|
||||||
<TargetZone>LocalIntranet</TargetZone>
|
|
||||||
<TargetFrameworkVersion>v4.6.1</TargetFrameworkVersion>
|
|
||||||
<AutoGenerateBindingRedirects>true</AutoGenerateBindingRedirects>
|
|
||||||
<PublishUrl>publish\</PublishUrl>
|
|
||||||
<Install>true</Install>
|
|
||||||
<InstallFrom>Disk</InstallFrom>
|
|
||||||
<UpdateEnabled>false</UpdateEnabled>
|
|
||||||
<UpdateMode>Foreground</UpdateMode>
|
|
||||||
<UpdateInterval>7</UpdateInterval>
|
|
||||||
<UpdateIntervalUnits>Days</UpdateIntervalUnits>
|
|
||||||
<UpdatePeriodically>false</UpdatePeriodically>
|
|
||||||
<UpdateRequired>false</UpdateRequired>
|
|
||||||
<MapFileExtensions>true</MapFileExtensions>
|
|
||||||
<ApplicationRevision>2</ApplicationRevision>
|
|
||||||
<ApplicationVersion>1.0.0.%2a</ApplicationVersion>
|
|
||||||
<UseApplicationTrust>false</UseApplicationTrust>
|
|
||||||
<BootstrapperEnabled>true</BootstrapperEnabled>
|
|
||||||
<ProductVersion>12.0.0</ProductVersion>
|
|
||||||
<SchemaVersion>2.0</SchemaVersion>
|
|
||||||
<TargetFrameworkProfile>
|
|
||||||
</TargetFrameworkProfile>
|
|
||||||
<NuGetPackageImportStamp>
|
|
||||||
</NuGetPackageImportStamp>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
|
|
||||||
<DebugSymbols>true</DebugSymbols>
|
|
||||||
<DebugType>full</DebugType>
|
|
||||||
<Optimize>false</Optimize>
|
|
||||||
<OutputPath>bin\Debug\</OutputPath>
|
|
||||||
<DefineConstants>DEBUG</DefineConstants>
|
|
||||||
<ErrorReport>prompt</ErrorReport>
|
|
||||||
<WarningLevel>0</WarningLevel>
|
|
||||||
<NoStdLib>true</NoStdLib>
|
|
||||||
<UseVSHostingProcess>false</UseVSHostingProcess>
|
|
||||||
<PlatformTarget>AnyCPU</PlatformTarget>
|
|
||||||
<AllowUnsafeBlocks>true</AllowUnsafeBlocks>
|
|
||||||
<CodeAnalysisRuleSet>AllRules.ruleset</CodeAnalysisRuleSet>
|
|
||||||
<RunCodeAnalysis>false</RunCodeAnalysis>
|
|
||||||
<Prefer32Bit>false</Prefer32Bit>
|
|
||||||
<TreatWarningsAsErrors>false</TreatWarningsAsErrors>
|
|
||||||
<LangVersion>6</LangVersion>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
|
|
||||||
<DebugType>none</DebugType>
|
|
||||||
<Optimize>true</Optimize>
|
|
||||||
<OutputPath>bin\Release\</OutputPath>
|
|
||||||
<DefineConstants>CuttingEdge NoUpdate</DefineConstants>
|
|
||||||
<ErrorReport>prompt</ErrorReport>
|
|
||||||
<WarningLevel>4</WarningLevel>
|
|
||||||
<NoStdLib>true</NoStdLib>
|
|
||||||
<UseVSHostingProcess>false</UseVSHostingProcess>
|
|
||||||
<PlatformTarget>AnyCPU</PlatformTarget>
|
|
||||||
<AllowUnsafeBlocks>true</AllowUnsafeBlocks>
|
|
||||||
<CodeAnalysisRuleSet>AllRules.ruleset</CodeAnalysisRuleSet>
|
|
||||||
<Prefer32Bit>false</Prefer32Bit>
|
|
||||||
<TreatWarningsAsErrors>false</TreatWarningsAsErrors>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup>
|
|
||||||
<Win32Resource>
|
|
||||||
</Win32Resource>
|
|
||||||
</PropertyGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<Reference Include="mscorlib" />
|
|
||||||
<Reference Include="Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed, processorArchitecture=MSIL">
|
|
||||||
<HintPath>$(SolutionDir)\packages\Newtonsoft.Json.10.0.2\lib\net45\Newtonsoft.Json.dll</HintPath>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="OpenTK, Version=3.0.0.0, Culture=neutral, PublicKeyToken=bad199fe84eb3df4, processorArchitecture=MSIL">
|
|
||||||
<HintPath>$(SolutionDir)\packages\ppy.OpenTK.3.0\lib\net45\OpenTK.dll</HintPath>
|
|
||||||
<Private>True</Private>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="SharpCompress, Version=0.17.1.0, Culture=neutral, PublicKeyToken=afb0a02973931d96, processorArchitecture=MSIL">
|
|
||||||
<HintPath>$(SolutionDir)\packages\SharpCompress.0.17.1\lib\net45\SharpCompress.dll</HintPath>
|
|
||||||
<Private>True</Private>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="SQLite.Net, Version=3.1.0.0, Culture=neutral, processorArchitecture=MSIL">
|
|
||||||
<SpecificVersion>False</SpecificVersion>
|
|
||||||
<HintPath>$(SolutionDir)\packages\SQLite.Net.Core-PCL.3.1.1\lib\portable-win8+net45+wp8+wpa81+MonoAndroid1+MonoTouch1\SQLite.Net.dll</HintPath>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="System" />
|
|
||||||
<Reference Include="SQLiteNetExtensions">
|
|
||||||
<HintPath>$(SolutionDir)\packages\SQLiteNetExtensions.1.3.0\lib\portable-net45+netcore45+wpa81+wp8+MonoAndroid1+MonoTouch1\SQLiteNetExtensions.dll</HintPath>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="SQLite.Net.Platform.Win32">
|
|
||||||
<HintPath>$(SolutionDir)\packages\SQLite.Net-PCL.3.1.1\lib\net4\SQLite.Net.Platform.Win32.dll</HintPath>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="SQLite.Net.Platform.Generic">
|
|
||||||
<HintPath>$(SolutionDir)\packages\SQLite.Net-PCL.3.1.1\lib\net40\SQLite.Net.Platform.Generic.dll</HintPath>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="System.Drawing" />
|
|
||||||
<Reference Include="System.Xml" />
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<None Include="..\osu.licenseheader">
|
|
||||||
<Link>osu.licenseheader</Link>
|
|
||||||
</None>
|
|
||||||
<None Include="packages.config" />
|
|
||||||
<None Include="OpenTK.dll.config" />
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<BootstrapperPackage Include="Microsoft.Net.Client.3.5">
|
|
||||||
<Visible>False</Visible>
|
|
||||||
<ProductName>.NET Framework 3.5 SP1 Client Profile</ProductName>
|
|
||||||
<Install>false</Install>
|
|
||||||
</BootstrapperPackage>
|
|
||||||
<BootstrapperPackage Include="Microsoft.Net.Framework.2.0">
|
|
||||||
<Visible>False</Visible>
|
|
||||||
<ProductName>.NET Framework 2.0 %28x86%29</ProductName>
|
|
||||||
<Install>true</Install>
|
|
||||||
</BootstrapperPackage>
|
|
||||||
<BootstrapperPackage Include="Microsoft.Net.Framework.3.0">
|
|
||||||
<Visible>False</Visible>
|
|
||||||
<ProductName>.NET Framework 3.0 %28x86%29</ProductName>
|
|
||||||
<Install>false</Install>
|
|
||||||
</BootstrapperPackage>
|
|
||||||
<BootstrapperPackage Include="Microsoft.Net.Framework.3.5">
|
|
||||||
<Visible>False</Visible>
|
|
||||||
<ProductName>.NET Framework 3.5</ProductName>
|
|
||||||
<Install>false</Install>
|
|
||||||
</BootstrapperPackage>
|
|
||||||
<BootstrapperPackage Include="Microsoft.Net.Framework.3.5.SP1">
|
|
||||||
<Visible>False</Visible>
|
|
||||||
<ProductName>.NET Framework 3.5 SP1</ProductName>
|
|
||||||
<Install>false</Install>
|
|
||||||
</BootstrapperPackage>
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<ProjectReference Include="..\osu-framework\osu.Framework.Desktop\osu.Framework.Desktop.csproj">
|
|
||||||
<Project>{65dc628f-a640-4111-ab35-3a5652bc1e17}</Project>
|
|
||||||
<Name>osu.Framework.Desktop</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu-framework\osu.Framework.Testing\osu.Framework.Testing.csproj">
|
|
||||||
<Project>{007b2356-ab6f-4bd9-96d5-116fc2dce69a}</Project>
|
|
||||||
<Name>osu.Framework.Testing</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu-framework\osu.Framework\osu.Framework.csproj">
|
|
||||||
<Project>{c76bf5b3-985e-4d39-95fe-97c9c879b83a}</Project>
|
|
||||||
<Name>osu.Framework</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu-resources\osu.Game.Resources\osu.Game.Resources.csproj">
|
|
||||||
<Project>{d9a367c9-4c1a-489f-9b05-a0cea2b53b58}</Project>
|
|
||||||
<Name>osu.Game.Resources</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu.Game.Rulesets.Osu\osu.Game.Rulesets.Osu.csproj">
|
|
||||||
<Project>{c92a607b-1fdd-4954-9f92-03ff547d9080}</Project>
|
|
||||||
<Name>osu.Game.Rulesets.Osu</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu.Game.Rulesets.Catch\osu.Game.Rulesets.Catch.csproj">
|
|
||||||
<Project>{58f6c80c-1253-4a0e-a465-b8c85ebeadf3}</Project>
|
|
||||||
<Name>osu.Game.Rulesets.Catch</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu.Game.Rulesets.Mania\osu.Game.Rulesets.Mania.csproj">
|
|
||||||
<Project>{48f4582b-7687-4621-9cbe-5c24197cb536}</Project>
|
|
||||||
<Name>osu.Game.Rulesets.Mania</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu.Game.Rulesets.Taiko\osu.Game.Rulesets.Taiko.csproj">
|
|
||||||
<Project>{f167e17a-7de6-4af5-b920-a5112296c695}</Project>
|
|
||||||
<Name>osu.Game.Rulesets.Taiko</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu.Game\osu.Game.csproj">
|
|
||||||
<Project>{0d3fbf8a-7464-4cf7-8c90-3e7886df2d4d}</Project>
|
|
||||||
<Name>osu.Game</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<Compile Include="Program.cs" />
|
|
||||||
<Compile Include="VisualTestGame.cs" />
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup />
|
|
||||||
<ItemGroup />
|
|
||||||
<ItemGroup />
|
|
||||||
<Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />
|
|
||||||
<!-- To modify your build process, add your task inside one of the targets below and uncomment it.
|
|
||||||
Other similar extension points exist, see Microsoft.Common.targets.
|
|
||||||
<Target Name="BeforeBuild">
|
|
||||||
</Target>
|
|
||||||
<Target Name="AfterBuild">
|
|
||||||
</Target>
|
|
||||||
-->
|
|
||||||
<ProjectExtensions>
|
|
||||||
<VisualStudio>
|
|
||||||
</VisualStudio>
|
|
||||||
</ProjectExtensions>
|
|
||||||
<PropertyGroup>
|
|
||||||
<PreBuildEvent>
|
|
||||||
</PreBuildEvent>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup>
|
|
||||||
<PostBuildEvent>
|
|
||||||
</PostBuildEvent>
|
|
||||||
</PropertyGroup>
|
|
||||||
</Project>
|
|
@ -1,13 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!--
|
|
||||||
Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
-->
|
|
||||||
<packages>
|
|
||||||
<package id="Newtonsoft.Json" version="10.0.2" targetFramework="net45" />
|
|
||||||
<package id="ppy.OpenTK" version="3.0" targetFramework="net45" />
|
|
||||||
<package id="SharpCompress" version="0.17.1" targetFramework="net45" />
|
|
||||||
<package id="SQLite.Net.Core-PCL" version="3.1.1" targetFramework="net45" />
|
|
||||||
<package id="SQLite.Net-PCL" version="3.1.1" targetFramework="net45" />
|
|
||||||
<package id="SQLiteNetExtensions" version="1.3.0" targetFramework="net45" />
|
|
||||||
</packages>
|
|
@ -1,146 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System.IO;
|
|
||||||
using NUnit.Framework;
|
|
||||||
using OpenTK;
|
|
||||||
using OpenTK.Graphics;
|
|
||||||
using osu.Game.Beatmaps.Formats;
|
|
||||||
using osu.Game.Tests.Resources;
|
|
||||||
using System.Linq;
|
|
||||||
using osu.Game.Audio;
|
|
||||||
using osu.Game.Rulesets.Objects.Types;
|
|
||||||
|
|
||||||
namespace osu.Game.Tests.Beatmaps.Formats
|
|
||||||
{
|
|
||||||
[TestFixture]
|
|
||||||
public class OsuLegacyDecoderTest
|
|
||||||
{
|
|
||||||
[Test]
|
|
||||||
public void TestDecodeMetadata()
|
|
||||||
{
|
|
||||||
var decoder = new OsuLegacyDecoder();
|
|
||||||
using (var stream = Resource.OpenResource("Soleily - Renatus (Gamu) [Insane].osu"))
|
|
||||||
{
|
|
||||||
var beatmap = decoder.Decode(new StreamReader(stream));
|
|
||||||
var meta = beatmap.BeatmapInfo.Metadata;
|
|
||||||
Assert.AreEqual(241526, meta.OnlineBeatmapSetID);
|
|
||||||
Assert.AreEqual("Soleily", meta.Artist);
|
|
||||||
Assert.AreEqual("Soleily", meta.ArtistUnicode);
|
|
||||||
Assert.AreEqual("03. Renatus - Soleily 192kbps.mp3", meta.AudioFile);
|
|
||||||
Assert.AreEqual("Gamu", meta.Author);
|
|
||||||
Assert.AreEqual("machinetop_background.jpg", meta.BackgroundFile);
|
|
||||||
Assert.AreEqual(164471, meta.PreviewTime);
|
|
||||||
Assert.AreEqual(string.Empty, meta.Source);
|
|
||||||
Assert.AreEqual("MBC7 Unisphere 地球ヤバイEP Chikyu Yabai", meta.Tags);
|
|
||||||
Assert.AreEqual("Renatus", meta.Title);
|
|
||||||
Assert.AreEqual("Renatus", meta.TitleUnicode);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
[Test]
|
|
||||||
public void TestDecodeGeneral()
|
|
||||||
{
|
|
||||||
var decoder = new OsuLegacyDecoder();
|
|
||||||
using (var stream = Resource.OpenResource("Soleily - Renatus (Gamu) [Insane].osu"))
|
|
||||||
{
|
|
||||||
var beatmapInfo = decoder.Decode(new StreamReader(stream)).BeatmapInfo;
|
|
||||||
Assert.AreEqual(0, beatmapInfo.AudioLeadIn);
|
|
||||||
Assert.AreEqual(false, beatmapInfo.Countdown);
|
|
||||||
Assert.AreEqual(0.7f, beatmapInfo.StackLeniency);
|
|
||||||
Assert.AreEqual(false, beatmapInfo.SpecialStyle);
|
|
||||||
Assert.IsTrue(beatmapInfo.RulesetID == 0);
|
|
||||||
Assert.AreEqual(false, beatmapInfo.LetterboxInBreaks);
|
|
||||||
Assert.AreEqual(false, beatmapInfo.WidescreenStoryboard);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
[Test]
|
|
||||||
public void TestDecodeEditor()
|
|
||||||
{
|
|
||||||
var decoder = new OsuLegacyDecoder();
|
|
||||||
using (var stream = Resource.OpenResource("Soleily - Renatus (Gamu) [Insane].osu"))
|
|
||||||
{
|
|
||||||
var beatmap = decoder.Decode(new StreamReader(stream)).BeatmapInfo;
|
|
||||||
int[] expectedBookmarks =
|
|
||||||
{
|
|
||||||
11505, 22054, 32604, 43153, 53703, 64252, 74802, 85351,
|
|
||||||
95901, 106450, 116999, 119637, 130186, 140735, 151285,
|
|
||||||
161834, 164471, 175020, 185570, 196119, 206669, 209306
|
|
||||||
};
|
|
||||||
Assert.AreEqual(expectedBookmarks.Length, beatmap.Bookmarks.Length);
|
|
||||||
for (int i = 0; i < expectedBookmarks.Length; i++)
|
|
||||||
Assert.AreEqual(expectedBookmarks[i], beatmap.Bookmarks[i]);
|
|
||||||
Assert.AreEqual(1.8, beatmap.DistanceSpacing);
|
|
||||||
Assert.AreEqual(4, beatmap.BeatDivisor);
|
|
||||||
Assert.AreEqual(4, beatmap.GridSize);
|
|
||||||
Assert.AreEqual(2, beatmap.TimelineZoom);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
[Test]
|
|
||||||
public void TestDecodeDifficulty()
|
|
||||||
{
|
|
||||||
var decoder = new OsuLegacyDecoder();
|
|
||||||
using (var stream = Resource.OpenResource("Soleily - Renatus (Gamu) [Insane].osu"))
|
|
||||||
{
|
|
||||||
var beatmap = decoder.Decode(new StreamReader(stream));
|
|
||||||
var difficulty = beatmap.BeatmapInfo.Difficulty;
|
|
||||||
Assert.AreEqual(6.5f, difficulty.DrainRate);
|
|
||||||
Assert.AreEqual(4, difficulty.CircleSize);
|
|
||||||
Assert.AreEqual(8, difficulty.OverallDifficulty);
|
|
||||||
Assert.AreEqual(9, difficulty.ApproachRate);
|
|
||||||
Assert.AreEqual(1.8f, difficulty.SliderMultiplier);
|
|
||||||
Assert.AreEqual(2, difficulty.SliderTickRate);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
[Test]
|
|
||||||
public void TestDecodeColors()
|
|
||||||
{
|
|
||||||
var decoder = new OsuLegacyDecoder();
|
|
||||||
using (var stream = Resource.OpenResource("Soleily - Renatus (Gamu) [Insane].osu"))
|
|
||||||
{
|
|
||||||
var beatmap = decoder.Decode(new StreamReader(stream));
|
|
||||||
Color4[] expected =
|
|
||||||
{
|
|
||||||
new Color4(142, 199, 255, 255),
|
|
||||||
new Color4(255, 128, 128, 255),
|
|
||||||
new Color4(128, 255, 255, 255),
|
|
||||||
new Color4(128, 255, 128, 255),
|
|
||||||
new Color4(255, 187, 255, 255),
|
|
||||||
new Color4(255, 177, 140, 255),
|
|
||||||
};
|
|
||||||
Assert.AreEqual(expected.Length, beatmap.ComboColors.Count);
|
|
||||||
for (int i = 0; i < expected.Length; i++)
|
|
||||||
Assert.AreEqual(expected[i], beatmap.ComboColors[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
[Test]
|
|
||||||
public void TestDecodeHitObjects()
|
|
||||||
{
|
|
||||||
var decoder = new OsuLegacyDecoder();
|
|
||||||
using (var stream = Resource.OpenResource("Soleily - Renatus (Gamu) [Insane].osu"))
|
|
||||||
{
|
|
||||||
var beatmap = decoder.Decode(new StreamReader(stream));
|
|
||||||
|
|
||||||
var curveData = beatmap.HitObjects[0] as IHasCurve;
|
|
||||||
var positionData = beatmap.HitObjects[0] as IHasPosition;
|
|
||||||
|
|
||||||
Assert.IsNotNull(positionData);
|
|
||||||
Assert.IsNotNull(curveData);
|
|
||||||
Assert.AreEqual(new Vector2(192, 168), positionData.Position);
|
|
||||||
Assert.AreEqual(956, beatmap.HitObjects[0].StartTime);
|
|
||||||
Assert.IsTrue(beatmap.HitObjects[0].Samples.Any(s => s.Name == SampleInfo.HIT_NORMAL));
|
|
||||||
|
|
||||||
positionData = beatmap.HitObjects[1] as IHasPosition;
|
|
||||||
|
|
||||||
Assert.IsNotNull(positionData);
|
|
||||||
Assert.AreEqual(new Vector2(304, 56), positionData.Position);
|
|
||||||
Assert.AreEqual(1285, beatmap.HitObjects[1].StartTime);
|
|
||||||
Assert.IsTrue(beatmap.HitObjects[1].Samples.Any(s => s.Name == SampleInfo.HIT_CLAP));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,165 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.IO;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Threading;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using NUnit.Framework;
|
|
||||||
using osu.Framework.Desktop.Platform;
|
|
||||||
using osu.Framework.Platform;
|
|
||||||
using osu.Game.IPC;
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
|
|
||||||
namespace osu.Game.Tests.Beatmaps.IO
|
|
||||||
{
|
|
||||||
[TestFixture]
|
|
||||||
public class ImportBeatmapTest
|
|
||||||
{
|
|
||||||
private const string osz_path = @"../../../osu-resources/osu.Game.Resources/Beatmaps/241526 Soleily - Renatus.osz";
|
|
||||||
|
|
||||||
[Test]
|
|
||||||
public void TestImportWhenClosed()
|
|
||||||
{
|
|
||||||
//unfortunately for the time being we need to reference osu.Framework.Desktop for a game host here.
|
|
||||||
using (HeadlessGameHost host = new HeadlessGameHost())
|
|
||||||
{
|
|
||||||
var osu = loadOsu(host);
|
|
||||||
|
|
||||||
var temp = prepareTempCopy(osz_path);
|
|
||||||
|
|
||||||
Assert.IsTrue(File.Exists(temp));
|
|
||||||
|
|
||||||
osu.Dependencies.Get<BeatmapManager>().Import(temp);
|
|
||||||
|
|
||||||
ensureLoaded(osu);
|
|
||||||
|
|
||||||
Assert.IsFalse(File.Exists(temp));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
[Test]
|
|
||||||
public void TestImportOverIPC()
|
|
||||||
{
|
|
||||||
using (HeadlessGameHost host = new HeadlessGameHost("host", true))
|
|
||||||
using (HeadlessGameHost client = new HeadlessGameHost("client", true))
|
|
||||||
{
|
|
||||||
Assert.IsTrue(host.IsPrimaryInstance);
|
|
||||||
Assert.IsTrue(!client.IsPrimaryInstance);
|
|
||||||
|
|
||||||
var osu = loadOsu(host);
|
|
||||||
|
|
||||||
var temp = prepareTempCopy(osz_path);
|
|
||||||
|
|
||||||
Assert.IsTrue(File.Exists(temp));
|
|
||||||
|
|
||||||
var importer = new BeatmapIPCChannel(client);
|
|
||||||
if (!importer.ImportAsync(temp).Wait(10000))
|
|
||||||
Assert.Fail(@"IPC took too long to send");
|
|
||||||
|
|
||||||
ensureLoaded(osu);
|
|
||||||
|
|
||||||
Assert.IsFalse(File.Exists(temp));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
[Test]
|
|
||||||
public void TestImportWhenFileOpen()
|
|
||||||
{
|
|
||||||
//unfortunately for the time being we need to reference osu.Framework.Desktop for a game host here.
|
|
||||||
using (HeadlessGameHost host = new HeadlessGameHost())
|
|
||||||
{
|
|
||||||
var osu = loadOsu(host);
|
|
||||||
|
|
||||||
var temp = prepareTempCopy(osz_path);
|
|
||||||
|
|
||||||
Assert.IsTrue(File.Exists(temp), "Temporary file copy never substantiated");
|
|
||||||
|
|
||||||
using (File.OpenRead(temp))
|
|
||||||
osu.Dependencies.Get<BeatmapManager>().Import(temp);
|
|
||||||
|
|
||||||
ensureLoaded(osu);
|
|
||||||
|
|
||||||
File.Delete(temp);
|
|
||||||
|
|
||||||
Assert.IsFalse(File.Exists(temp), "We likely held a read lock on the file when we shouldn't");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private string prepareTempCopy(string path)
|
|
||||||
{
|
|
||||||
var temp = Path.GetTempFileName();
|
|
||||||
return new FileInfo(path).CopyTo(temp, true).FullName;
|
|
||||||
}
|
|
||||||
|
|
||||||
private OsuGameBase loadOsu(GameHost host)
|
|
||||||
{
|
|
||||||
host.Storage.DeleteDatabase(@"client");
|
|
||||||
|
|
||||||
var osu = new OsuGameBase();
|
|
||||||
Task.Run(() => host.Run(osu));
|
|
||||||
|
|
||||||
while (!osu.IsLoaded)
|
|
||||||
Thread.Sleep(1);
|
|
||||||
|
|
||||||
return osu;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void ensureLoaded(OsuGameBase osu, int timeout = 60000)
|
|
||||||
{
|
|
||||||
IEnumerable<BeatmapSetInfo> resultSets = null;
|
|
||||||
|
|
||||||
var store = osu.Dependencies.Get<BeatmapManager>();
|
|
||||||
|
|
||||||
Action waitAction = () =>
|
|
||||||
{
|
|
||||||
while (!(resultSets = store.QueryBeatmapSets(s => s.OnlineBeatmapSetID == 241526)).Any())
|
|
||||||
Thread.Sleep(50);
|
|
||||||
};
|
|
||||||
|
|
||||||
Assert.IsTrue(waitAction.BeginInvoke(null, null).AsyncWaitHandle.WaitOne(timeout),
|
|
||||||
@"BeatmapSet did not import to the database in allocated time.");
|
|
||||||
|
|
||||||
//ensure we were stored to beatmap database backing...
|
|
||||||
|
|
||||||
Assert.IsTrue(resultSets.Count() == 1, $@"Incorrect result count found ({resultSets.Count()} but should be 1).");
|
|
||||||
|
|
||||||
IEnumerable<BeatmapInfo> resultBeatmaps = null;
|
|
||||||
|
|
||||||
//if we don't re-check here, the set will be inserted but the beatmaps won't be present yet.
|
|
||||||
waitAction = () =>
|
|
||||||
{
|
|
||||||
while ((resultBeatmaps = store.QueryBeatmaps(s => s.OnlineBeatmapSetID == 241526 && s.BaseDifficultyID > 0)).Count() != 12)
|
|
||||||
Thread.Sleep(50);
|
|
||||||
};
|
|
||||||
|
|
||||||
Assert.IsTrue(waitAction.BeginInvoke(null, null).AsyncWaitHandle.WaitOne(timeout),
|
|
||||||
@"Beatmaps did not import to the database in allocated time");
|
|
||||||
|
|
||||||
var set = store.QueryBeatmapSets(s => s.OnlineBeatmapSetID == 241526).First();
|
|
||||||
|
|
||||||
Assert.IsTrue(set.Beatmaps.Count == resultBeatmaps.Count(),
|
|
||||||
$@"Incorrect database beatmap count post-import ({resultBeatmaps.Count()} but should be {set.Beatmaps.Count}).");
|
|
||||||
|
|
||||||
foreach (BeatmapInfo b in resultBeatmaps)
|
|
||||||
Assert.IsTrue(set.Beatmaps.Any(c => c.OnlineBeatmapID == b.OnlineBeatmapID));
|
|
||||||
|
|
||||||
Assert.IsTrue(set.Beatmaps.Count > 0);
|
|
||||||
|
|
||||||
var beatmap = store.GetWorkingBeatmap(set.Beatmaps.First(b => b.RulesetID == 0))?.Beatmap;
|
|
||||||
Assert.IsTrue(beatmap?.HitObjects.Count > 0);
|
|
||||||
|
|
||||||
beatmap = store.GetWorkingBeatmap(set.Beatmaps.First(b => b.RulesetID == 1))?.Beatmap;
|
|
||||||
Assert.IsTrue(beatmap?.HitObjects.Count > 0);
|
|
||||||
|
|
||||||
beatmap = store.GetWorkingBeatmap(set.Beatmaps.First(b => b.RulesetID == 2))?.Beatmap;
|
|
||||||
Assert.IsTrue(beatmap?.HitObjects.Count > 0);
|
|
||||||
|
|
||||||
beatmap = store.GetWorkingBeatmap(set.Beatmaps.First(b => b.RulesetID == 3))?.Beatmap;
|
|
||||||
Assert.IsTrue(beatmap?.HitObjects.Count > 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,83 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System.IO;
|
|
||||||
using System.Linq;
|
|
||||||
using NUnit.Framework;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Game.Beatmaps.IO;
|
|
||||||
using osu.Game.Tests.Resources;
|
|
||||||
using osu.Game.Beatmaps.Formats;
|
|
||||||
|
|
||||||
namespace osu.Game.Tests.Beatmaps.IO
|
|
||||||
{
|
|
||||||
[TestFixture]
|
|
||||||
public class OszArchiveReaderTest
|
|
||||||
{
|
|
||||||
[Test]
|
|
||||||
public void TestReadBeatmaps()
|
|
||||||
{
|
|
||||||
using (var osz = Resource.OpenResource("Beatmaps.241526 Soleily - Renatus.osz"))
|
|
||||||
{
|
|
||||||
var reader = new OszArchiveReader(osz);
|
|
||||||
string[] expected =
|
|
||||||
{
|
|
||||||
"Soleily - Renatus (Deif) [Platter].osu",
|
|
||||||
"Soleily - Renatus (Deif) [Rain].osu",
|
|
||||||
"Soleily - Renatus (Deif) [Salad].osu",
|
|
||||||
"Soleily - Renatus (ExPew) [Another].osu",
|
|
||||||
"Soleily - Renatus (ExPew) [Hyper].osu",
|
|
||||||
"Soleily - Renatus (ExPew) [Normal].osu",
|
|
||||||
"Soleily - Renatus (Gamu) [Hard].osu",
|
|
||||||
"Soleily - Renatus (Gamu) [Insane].osu",
|
|
||||||
"Soleily - Renatus (Gamu) [Normal].osu",
|
|
||||||
"Soleily - Renatus (MMzz) [Futsuu].osu",
|
|
||||||
"Soleily - Renatus (MMzz) [Muzukashii].osu",
|
|
||||||
"Soleily - Renatus (MMzz) [Oni].osu"
|
|
||||||
};
|
|
||||||
var maps = reader.Filenames.ToArray();
|
|
||||||
foreach (var map in expected)
|
|
||||||
Assert.Contains(map, maps);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
[Test]
|
|
||||||
public void TestReadMetadata()
|
|
||||||
{
|
|
||||||
using (var osz = Resource.OpenResource("Beatmaps.241526 Soleily - Renatus.osz"))
|
|
||||||
{
|
|
||||||
var reader = new OszArchiveReader(osz);
|
|
||||||
|
|
||||||
BeatmapMetadata meta;
|
|
||||||
using (var stream = new StreamReader(reader.GetStream("Soleily - Renatus (Deif) [Platter].osu")))
|
|
||||||
meta = BeatmapDecoder.GetDecoder(stream).Decode(stream).Metadata;
|
|
||||||
|
|
||||||
Assert.AreEqual(241526, meta.OnlineBeatmapSetID);
|
|
||||||
Assert.AreEqual("Soleily", meta.Artist);
|
|
||||||
Assert.AreEqual("Soleily", meta.ArtistUnicode);
|
|
||||||
Assert.AreEqual("03. Renatus - Soleily 192kbps.mp3", meta.AudioFile);
|
|
||||||
Assert.AreEqual("Deif", meta.Author);
|
|
||||||
Assert.AreEqual("machinetop_background.jpg", meta.BackgroundFile);
|
|
||||||
Assert.AreEqual(164471, meta.PreviewTime);
|
|
||||||
Assert.AreEqual(string.Empty, meta.Source);
|
|
||||||
Assert.AreEqual("MBC7 Unisphere 地球ヤバイEP Chikyu Yabai", meta.Tags);
|
|
||||||
Assert.AreEqual("Renatus", meta.Title);
|
|
||||||
Assert.AreEqual("Renatus", meta.TitleUnicode);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
[Test]
|
|
||||||
public void TestReadFile()
|
|
||||||
{
|
|
||||||
using (var osz = Resource.OpenResource("Beatmaps.241526 Soleily - Renatus.osz"))
|
|
||||||
{
|
|
||||||
var reader = new OszArchiveReader(osz);
|
|
||||||
using (var stream = new StreamReader(
|
|
||||||
reader.GetStream("Soleily - Renatus (Deif) [Platter].osu")))
|
|
||||||
{
|
|
||||||
Assert.AreEqual("osu file format v13", stream.ReadLine()?.Trim());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,25 +0,0 @@
|
|||||||
<configuration>
|
|
||||||
<dllmap os="linux" dll="opengl32.dll" target="libGL.so.1"/>
|
|
||||||
<dllmap os="linux" dll="glu32.dll" target="libGLU.so.1"/>
|
|
||||||
<dllmap os="linux" dll="openal32.dll" target="libopenal.so.1"/>
|
|
||||||
<dllmap os="linux" dll="alut.dll" target="libalut.so.0"/>
|
|
||||||
<dllmap os="linux" dll="opencl.dll" target="libOpenCL.so"/>
|
|
||||||
<dllmap os="linux" dll="libX11" target="libX11.so.6"/>
|
|
||||||
<dllmap os="linux" dll="libXi" target="libXi.so.6"/>
|
|
||||||
<dllmap os="linux" dll="SDL2.dll" target="libSDL2-2.0.so.0"/>
|
|
||||||
<dllmap os="osx" dll="opengl32.dll" target="/System/Library/Frameworks/OpenGL.framework/OpenGL"/>
|
|
||||||
<dllmap os="osx" dll="openal32.dll" target="/System/Library/Frameworks/OpenAL.framework/OpenAL" />
|
|
||||||
<dllmap os="osx" dll="alut.dll" target="/System/Library/Frameworks/OpenAL.framework/OpenAL" />
|
|
||||||
<dllmap os="osx" dll="libGLES.dll" target="/System/Library/Frameworks/OpenGLES.framework/OpenGLES" />
|
|
||||||
<dllmap os="osx" dll="libGLESv1_CM.dll" target="/System/Library/Frameworks/OpenGLES.framework/OpenGLES" />
|
|
||||||
<dllmap os="osx" dll="libGLESv2.dll" target="/System/Library/Frameworks/OpenGLES.framework/OpenGLES" />
|
|
||||||
<dllmap os="osx" dll="opencl.dll" target="/System/Library/Frameworks/OpenCL.framework/OpenCL"/>
|
|
||||||
<dllmap os="osx" dll="SDL2.dll" target="libSDL2.dylib"/>
|
|
||||||
<!-- XQuartz compatibility (X11 on Mac) -->
|
|
||||||
<dllmap os="osx" dll="libGL.so.1" target="/usr/X11/lib/libGL.dylib"/>
|
|
||||||
<dllmap os="osx" dll="libX11" target="/usr/X11/lib/libX11.dylib"/>
|
|
||||||
<dllmap os="osx" dll="libXcursor.so.1" target="/usr/X11/lib/libXcursor.dylib"/>
|
|
||||||
<dllmap os="osx" dll="libXi" target="/usr/X11/lib/libXi.dylib"/>
|
|
||||||
<dllmap os="osx" dll="libXinerama" target="/usr/X11/lib/libXinerama.dylib"/>
|
|
||||||
<dllmap os="osx" dll="libXrandr.so.2" target="/usr/X11/lib/libXrandr.dylib"/>
|
|
||||||
</configuration>
|
|
@ -1,20 +0,0 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.IO;
|
|
||||||
using System.Reflection;
|
|
||||||
|
|
||||||
namespace osu.Game.Tests.Resources
|
|
||||||
{
|
|
||||||
public static class Resource
|
|
||||||
{
|
|
||||||
public static Stream OpenResource(string name)
|
|
||||||
{
|
|
||||||
var localPath = Path.GetDirectoryName(Uri.UnescapeDataString(new UriBuilder(Assembly.GetExecutingAssembly().CodeBase).Path));
|
|
||||||
|
|
||||||
return Assembly.GetExecutingAssembly().GetManifestResourceStream($@"osu.Game.Tests.Resources.{name}") ??
|
|
||||||
Assembly.LoadFrom(Path.Combine(localPath, @"osu.Game.Resources.dll")).GetManifestResourceStream($@"osu.Game.Resources.{name}");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
File diff suppressed because it is too large
Load Diff
@ -1,11 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<configuration>
|
|
||||||
<runtime>
|
|
||||||
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
|
|
||||||
<dependentAssembly>
|
|
||||||
<assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
|
|
||||||
<bindingRedirect oldVersion="0.0.0.0-10.0.0.0" newVersion="10.0.0.0" />
|
|
||||||
</dependentAssembly>
|
|
||||||
</assemblyBinding>
|
|
||||||
</runtime>
|
|
||||||
</configuration>
|
|
@ -1,99 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
|
||||||
<PropertyGroup>
|
|
||||||
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
|
|
||||||
<Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
|
|
||||||
<ProjectGuid>{54377672-20B1-40AF-8087-5CF73BF3953A}</ProjectGuid>
|
|
||||||
<OutputType>Library</OutputType>
|
|
||||||
<RootNamespace>osu.Game.Tests</RootNamespace>
|
|
||||||
<AssemblyName>osu.Game.Tests</AssemblyName>
|
|
||||||
<TargetFrameworkVersion>v4.6.1</TargetFrameworkVersion>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
|
|
||||||
<DebugSymbols>true</DebugSymbols>
|
|
||||||
<DebugType>full</DebugType>
|
|
||||||
<Optimize>false</Optimize>
|
|
||||||
<OutputPath>bin\Debug</OutputPath>
|
|
||||||
<DefineConstants>DEBUG;</DefineConstants>
|
|
||||||
<ErrorReport>prompt</ErrorReport>
|
|
||||||
<WarningLevel>4</WarningLevel>
|
|
||||||
<ConsolePause>false</ConsolePause>
|
|
||||||
<TreatWarningsAsErrors>false</TreatWarningsAsErrors>
|
|
||||||
<LangVersion>6</LangVersion>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
|
|
||||||
<Optimize>true</Optimize>
|
|
||||||
<OutputPath>bin\Release</OutputPath>
|
|
||||||
<ErrorReport>prompt</ErrorReport>
|
|
||||||
<WarningLevel>4</WarningLevel>
|
|
||||||
<ConsolePause>false</ConsolePause>
|
|
||||||
<TreatWarningsAsErrors>false</TreatWarningsAsErrors>
|
|
||||||
</PropertyGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<Reference Include="nunit.framework, Version=3.8.1.0, Culture=neutral, PublicKeyToken=2638cd05610744eb, processorArchitecture=MSIL">
|
|
||||||
<HintPath>$(SolutionDir)\packages\NUnit.3.8.1\lib\net45\nunit.framework.dll</HintPath>
|
|
||||||
<Private>True</Private>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="OpenTK, Version=3.0.0.0, Culture=neutral, PublicKeyToken=bad199fe84eb3df4, processorArchitecture=MSIL">
|
|
||||||
<HintPath>$(SolutionDir)\packages\OpenTK.3.0.0-git00009\lib\net20\OpenTK.dll</HintPath>
|
|
||||||
<Private>True</Private>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="System" />
|
|
||||||
<Reference Include="SQLite.Net">
|
|
||||||
<HintPath>$(SolutionDir)\packages\SQLite.Net.Core-PCL.3.1.1\lib\portable-win8+net45+wp8+wpa81+MonoAndroid1+MonoTouch1\SQLite.Net.dll</HintPath>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="SQLite.Net.Platform.Win32">
|
|
||||||
<HintPath>$(SolutionDir)\packages\SQLite.Net-PCL.3.1.1\lib\net4\SQLite.Net.Platform.Win32.dll</HintPath>
|
|
||||||
</Reference>
|
|
||||||
<Reference Include="SQLite.Net.Platform.Generic">
|
|
||||||
<HintPath>$(SolutionDir)\packages\SQLite.Net-PCL.3.1.1\lib\net40\SQLite.Net.Platform.Generic.dll</HintPath>
|
|
||||||
</Reference>
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<None Include="..\osu.licenseheader">
|
|
||||||
<Link>osu.licenseheader</Link>
|
|
||||||
</None>
|
|
||||||
<None Include="app.config" />
|
|
||||||
<None Include="packages.config" />
|
|
||||||
<None Include="OpenTK.dll.config" />
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<ProjectReference Include="..\osu-framework\osu.Framework\osu.Framework.csproj">
|
|
||||||
<Project>{c76bf5b3-985e-4d39-95fe-97c9c879b83a}</Project>
|
|
||||||
<Name>osu.Framework</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu.Game.Rulesets.Osu\osu.Game.Rulesets.Osu.csproj">
|
|
||||||
<Project>{c92a607b-1fdd-4954-9f92-03ff547d9080}</Project>
|
|
||||||
<Name>osu.Game.Rulesets.Osu</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu.Game.Rulesets.Catch\osu.Game.Rulesets.Catch.csproj">
|
|
||||||
<Project>{58f6c80c-1253-4a0e-a465-b8c85ebeadf3}</Project>
|
|
||||||
<Name>osu.Game.Rulesets.Catch</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu.Game.Rulesets.Mania\osu.Game.Rulesets.Mania.csproj">
|
|
||||||
<Project>{48f4582b-7687-4621-9cbe-5c24197cb536}</Project>
|
|
||||||
<Name>osu.Game.Rulesets.Mania</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu.Game.Rulesets.Taiko\osu.Game.Rulesets.Taiko.csproj">
|
|
||||||
<Project>{f167e17a-7de6-4af5-b920-a5112296c695}</Project>
|
|
||||||
<Name>osu.Game.Rulesets.Taiko</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
<ProjectReference Include="..\osu-resources\osu.Game.Resources\osu.Game.Resources.csproj">
|
|
||||||
<Project>{D9A367C9-4C1A-489F-9B05-A0CEA2B53B58}</Project>
|
|
||||||
<Name>osu.Game.Resources</Name>
|
|
||||||
</ProjectReference>
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<Service Include="{82A7F48D-3B50-4B1E-B82E-3ADA8210C358}" />
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<Compile Include="Beatmaps\IO\OszArchiveReaderTest.cs" />
|
|
||||||
<Compile Include="Beatmaps\IO\ImportBeatmapTest.cs" />
|
|
||||||
<Compile Include="Resources\Resource.cs" />
|
|
||||||
<Compile Include="Beatmaps\Formats\OsuLegacyDecoderTest.cs" />
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<EmbeddedResource Include="Resources\Soleily - Renatus %28Gamu%29 [Insane].osu" />
|
|
||||||
</ItemGroup>
|
|
||||||
<Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />
|
|
||||||
</Project>
|
|
@ -1,11 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!--
|
|
||||||
Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
-->
|
|
||||||
<packages>
|
|
||||||
<package id="NUnit" version="3.8.1" targetFramework="net461" />
|
|
||||||
<package id="OpenTK" version="3.0.0-git00009" targetFramework="net461" />
|
|
||||||
<package id="SQLite.Net.Core-PCL" version="3.1.1" targetFramework="net45" />
|
|
||||||
<package id="SQLite.Net-PCL" version="3.1.1" targetFramework="net45" />
|
|
||||||
</packages>
|
|
Loading…
Reference in New Issue
Block a user