1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-08 05:52:54 +08:00

General cleanup per PR feedback

This commit is contained in:
Drew DeVault 2016-10-26 10:52:04 -04:00
parent fd867b2eb7
commit 55e5ec6fae
6 changed files with 107 additions and 185 deletions

View File

@ -13,7 +13,7 @@ namespace osu.Desktop.VisualTests
[STAThread] [STAThread]
public static void Main(string[] args) public static void Main(string[] args)
{ {
BasicGameHost host = Host.GetSuitableHost(@"osu"); BasicGameHost host = Host.GetSuitableHost(@"osu-visual-tests");
host.Add(new VisualTestGame()); host.Add(new VisualTestGame());
host.Run(); host.Run();
} }

View File

@ -1,49 +0,0 @@
using System;
using System.Collections.Generic;
using System.IO;
using osu.Framework.IO.Stores;
using osu.Game.Database;
namespace osu.Game.Beatmaps.IO
{
public class BeatmapResourceStore : IResourceStore<byte[]>, IDisposable
{
private Dictionary<int, ArchiveReader> beatmaps = new Dictionary<int, ArchiveReader>();
private BeatmapDatabase database;
public BeatmapResourceStore(BeatmapDatabase database)
{
this.database = database;
}
public void AddBeatmap(BeatmapSetInfo setInfo)
{
beatmaps.Add(setInfo.BeatmapSetID, database.GetReader(setInfo));
}
public void RemoveBeatmap(BeatmapSetInfo setInfo)
{
beatmaps[setInfo.BeatmapSetID].Dispose();
beatmaps.Remove(setInfo.BeatmapSetID);
}
public void Dispose()
{
foreach (var b in beatmaps.Values)
b.Dispose();
}
public byte[] Get(string name)
{
throw new NotImplementedException();
}
public Stream GetStream(string name)
{
string id = name.Remove(name.IndexOf(':'));
string path = name.Substring(name.IndexOf(':') + 1);
var reader = beatmaps[int.Parse(id)];
return reader.ReadFile(path);
}
}
}

View File

@ -35,8 +35,8 @@ namespace osu.Game.GameModes.Play
} }
} }
public event Action<BeatmapSetInfo> SetSelected; public Action<BeatmapSetInfo> SetSelected;
public event Action<BeatmapSetInfo, BeatmapInfo> BeatmapSelected; public Action<BeatmapSetInfo, BeatmapInfo> BeatmapSelected;
public BeatmapSetInfo BeatmapSet; public BeatmapSetInfo BeatmapSet;
private BeatmapSetBox setBox; private BeatmapSetBox setBox;
private FlowContainer topContainer; private FlowContainer topContainer;
@ -50,19 +50,13 @@ namespace osu.Game.GameModes.Play
if (collapsed == value) if (collapsed == value)
return; return;
collapsed = value; collapsed = value;
this.ClearTransformations(); ClearTransformations();
const float uncollapsedAlpha = 1; const float uncollapsedAlpha = 1;
Transforms.Add(new TransformAlpha(Clock) FadeTo(collapsed ? collapsedAlpha : uncollapsedAlpha, 250);
{
StartValue = collapsed ? uncollapsedAlpha : collapsedAlpha,
EndValue = collapsed ? collapsedAlpha : uncollapsedAlpha,
StartTime = Time,
EndTime = Time + 250,
});
if (collapsed) if (collapsed)
topContainer.Remove(difficulties); difficulties.Hide();
else else
topContainer.Add(difficulties); difficulties.Show();
setBox.ClearTransformations(); setBox.ClearTransformations();
setBox.Width = collapsed ? collapsedWidth : 1; // TODO: Transform setBox.Width = collapsed ? collapsedWidth : 1; // TODO: Transform
setBox.BorderColour = new Color4( setBox.BorderColour = new Color4(
@ -74,21 +68,6 @@ namespace osu.Game.GameModes.Play
} }
} }
private void updateSelected(BeatmapInfo map)
{
int selected = BeatmapSet.Beatmaps.IndexOf(map);
var buttons = difficulties.Children.ToList();
for (int i = 0; i < buttons.Count; i++)
{
var button = buttons[i] as BeatmapButton;
float targetWidth = 1 - Math.Abs((selected - i) * 0.025f);
targetWidth = MathHelper.Clamp(targetWidth, 0.8f, 1);
button.Width = targetWidth; // TODO: Transform
button.Selected = selected == i;
}
BeatmapSelected?.Invoke(BeatmapSet, map);
}
public BeatmapGroup(BeatmapSetInfo beatmapSet) public BeatmapGroup(BeatmapSetInfo beatmapSet)
{ {
BeatmapSet = beatmapSet; BeatmapSet = beatmapSet;
@ -104,7 +83,7 @@ namespace osu.Game.GameModes.Play
RelativeSizeAxes = Axes.X, RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y, AutoSizeAxes = Axes.Y,
Direction = FlowDirection.VerticalOnly, Direction = FlowDirection.VerticalOnly,
Children = new[] Children = new Drawable[]
{ {
setBox = new BeatmapSetBox(beatmapSet) setBox = new BeatmapSetBox(beatmapSet)
{ {
@ -112,11 +91,8 @@ namespace osu.Game.GameModes.Play
Width = collapsedWidth, Width = collapsedWidth,
Anchor = Anchor.TopRight, Anchor = Anchor.TopRight,
Origin = Anchor.TopRight, Origin = Anchor.TopRight,
} },
} difficulties = new FlowContainer
}
};
difficulties = new FlowContainer // Deliberately not added to children
{ {
RelativeSizeAxes = Axes.X, RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y, AutoSizeAxes = Axes.Y,
@ -124,13 +100,14 @@ namespace osu.Game.GameModes.Play
Padding = new MarginPadding { Left = 75 }, Padding = new MarginPadding { Left = 75 },
Spacing = new Vector2(0, 5), Spacing = new Vector2(0, 5),
Direction = FlowDirection.VerticalOnly, Direction = FlowDirection.VerticalOnly,
Children = this.BeatmapSet.Beatmaps.Select( Alpha = 0,
Children = BeatmapSet.Beatmaps.Select(
b => { b => {
float width = difficultyWidth; float width = difficultyWidth;
if (difficultyWidth > 0.8f) difficultyWidth -= 0.025f; if (difficultyWidth > 0.8f) difficultyWidth -= 0.025f;
return new BeatmapButton(this.BeatmapSet, b) return new BeatmapPanel(BeatmapSet, b)
{ {
MapSelected = beatmap => updateSelected(beatmap), MapSelected = updateSelected,
Selected = width == 1, Selected = width == 1,
Anchor = Anchor.TopRight, Anchor = Anchor.TopRight,
Origin = Anchor.TopRight, Origin = Anchor.TopRight,
@ -138,10 +115,21 @@ namespace osu.Game.GameModes.Play
Width = width, Width = width,
}; };
}) })
}
}
}
}; };
collapsed = true; collapsed = true;
} }
private void updateSelected(BeatmapInfo map)
{
foreach (BeatmapPanel panel in difficulties.Children)
panel.Selected = panel.Beatmap == map;
BeatmapSelected?.Invoke(BeatmapSet, map);
}
protected override bool OnClick(InputState state) protected override bool OnClick(InputState state)
{ {
SetSelected?.Invoke(BeatmapSet); SetSelected?.Invoke(BeatmapSet);
@ -151,12 +139,8 @@ namespace osu.Game.GameModes.Play
class BeatmapSetBox : Container class BeatmapSetBox : Container
{ {
private BeatmapSetInfo beatmapSet;
private Sprite backgroundImage;
public BeatmapSetBox(BeatmapSetInfo beatmapSet) public BeatmapSetBox(BeatmapSetInfo beatmapSet)
{ {
this.beatmapSet = beatmapSet;
AutoSizeAxes = Axes.Y; AutoSizeAxes = Axes.Y;
Masking = true; Masking = true;
CornerRadius = 5; CornerRadius = 5;
@ -177,12 +161,6 @@ namespace osu.Game.GameModes.Play
Size = Vector2.One, Size = Vector2.One,
Children = new Drawable[] Children = new Drawable[]
{ {
backgroundImage = new Sprite
{
RelativeSizeAxes = Axes.X,
Anchor = Anchor.Centre,
Origin = Anchor.Centre,
},
new Box // TODO: Gradient new Box // TODO: Gradient
{ {
Colour = new Color4(0, 0, 0, 100), Colour = new Color4(0, 0, 0, 100),
@ -202,12 +180,12 @@ namespace osu.Game.GameModes.Play
// TODO: Make these italic // TODO: Make these italic
new SpriteText new SpriteText
{ {
Text = this.beatmapSet.Metadata.Title ?? this.beatmapSet.Metadata.TitleUnicode, Text = beatmapSet.Metadata.Title ?? beatmapSet.Metadata.TitleUnicode,
TextSize = 20 TextSize = 20
}, },
new SpriteText new SpriteText
{ {
Text = this.beatmapSet.Metadata.Artist ?? this.beatmapSet.Metadata.ArtistUnicode, Text = beatmapSet.Metadata.Artist ?? beatmapSet.Metadata.ArtistUnicode,
TextSize = 16 TextSize = 16
}, },
new FlowContainer new FlowContainer

View File

@ -2,29 +2,22 @@
//Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE //Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
using System; using System;
using System.Collections.Generic;
using osu.Framework.Configuration;
using osu.Framework.Graphics; using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers; using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Sprites; using osu.Framework.Graphics.Sprites;
using osu.Framework.Input; using osu.Framework.Input;
using osu.Game.Beatmaps;
using osu.Game.GameModes.Backgrounds;
using osu.Framework;
using osu.Game.Database; using osu.Game.Database;
using osu.Framework.Graphics.Primitives; using osu.Framework.Graphics.Primitives;
using OpenTK.Graphics; using OpenTK.Graphics;
using OpenTK; using OpenTK;
using osu.Game.Graphics; using osu.Game.Graphics;
using osu.Framework.Graphics.Transformations;
using osu.Game.Graphics.UserInterface; using osu.Game.Graphics.UserInterface;
namespace osu.Game.GameModes.Play namespace osu.Game.GameModes.Play
{ {
class BeatmapButton : Container class BeatmapPanel : Container
{ {
private BeatmapSetInfo beatmapSet; public BeatmapInfo Beatmap;
private BeatmapInfo beatmap;
public Action<BeatmapInfo> MapSelected; public Action<BeatmapInfo> MapSelected;
@ -47,10 +40,9 @@ namespace osu.Game.GameModes.Play
} }
} }
public BeatmapButton(BeatmapSetInfo set, BeatmapInfo beatmap) public BeatmapPanel(BeatmapSetInfo set, BeatmapInfo beatmap)
{ {
this.beatmapSet = set; Beatmap = beatmap;
this.beatmap = beatmap;
AutoSizeAxes = Axes.Y; AutoSizeAxes = Axes.Y;
Masking = true; Masking = true;
CornerRadius = 5; CornerRadius = 5;
@ -109,7 +101,7 @@ namespace osu.Game.GameModes.Play
protected override bool OnClick(InputState state) protected override bool OnClick(InputState state)
{ {
MapSelected?.Invoke(beatmap); MapSelected?.Invoke(Beatmap);
return true; return true;
} }
} }

View File

@ -34,59 +34,6 @@ namespace osu.Game.GameModes.Play
private ScrollContainer scrollContainer; private ScrollContainer scrollContainer;
private FlowContainer setList; private FlowContainer setList;
private void selectBeatmapSet(BeatmapSetInfo beatmapSet)
{
selectedBeatmapSet = beatmapSet;
foreach (var child in setList.Children)
{
var childGroup = child as BeatmapGroup;
if (childGroup.BeatmapSet == beatmapSet)
{
childGroup.Collapsed = false;
selectedBeatmap = childGroup.SelectedBeatmap;
}
else
childGroup.Collapsed = true;
}
}
private void selectBeatmap(BeatmapSetInfo set, BeatmapInfo beatmap)
{
selectBeatmapSet(set);
selectedBeatmap = beatmap;
}
private Stopwatch watch = new Stopwatch();
private void addBeatmapSet(BeatmapSetInfo beatmapSet)
{
watch.Reset();
watch.Start();
beatmapSet = beatmaps.GetWithChildren<BeatmapSetInfo>(beatmapSet.BeatmapSetID);
beatmapSet.Beatmaps.ForEach(b => beatmaps.GetChildren(b));
beatmapSet.Beatmaps = beatmapSet.Beatmaps.OrderBy(b => b.BaseDifficulty.OverallDifficulty)
.ToList();
Scheduler.Add(() =>
{
var group = new BeatmapGroup(beatmapSet);
group.SetSelected += selectBeatmapSet;
group.BeatmapSelected += selectBeatmap;
setList.Add(group);
if (setList.Children.Count() == 1)
{
selectedBeatmapSet = group.BeatmapSet;
selectedBeatmap = group.SelectedBeatmap;
group.Collapsed = false;
}
});
}
private void addBeatmapSets()
{
foreach (var beatmapSet in beatmaps.Query<BeatmapSetInfo>())
addBeatmapSet(beatmapSet);
}
public PlaySongSelect() public PlaySongSelect()
{ {
const float scrollWidth = 640; const float scrollWidth = 640;
@ -169,13 +116,13 @@ namespace osu.Game.GameModes.Play
{ {
base.Load(game); base.Load(game);
OsuGame osu = game as OsuGame; OsuGame osuGame = game as OsuGame;
if (osu != null) if (osuGame != null)
{ {
playMode = osu.PlayMode; playMode = osuGame.PlayMode;
playMode.ValueChanged += PlayMode_ValueChanged; playMode.ValueChanged += PlayMode_ValueChanged;
// Temporary: // Temporary:
scrollContainer.Padding = new MarginPadding { Top = osu.Toolbar.Height }; scrollContainer.Padding = new MarginPadding { Top = osuGame.Toolbar.Height };
} }
beatmaps = (game as OsuGameBase).Beatmaps; beatmaps = (game as OsuGameBase).Beatmaps;
@ -193,5 +140,60 @@ namespace osu.Game.GameModes.Play
private void PlayMode_ValueChanged(object sender, EventArgs e) private void PlayMode_ValueChanged(object sender, EventArgs e)
{ {
} }
private void selectBeatmapSet(BeatmapSetInfo beatmapSet)
{
if (selectedBeatmapSet == beatmapSet)
return;
selectedBeatmapSet = beatmapSet;
foreach (var child in setList.Children)
{
var childGroup = child as BeatmapGroup;
if (childGroup.BeatmapSet == beatmapSet)
{
childGroup.Collapsed = false;
selectedBeatmap = childGroup.SelectedBeatmap;
}
else
childGroup.Collapsed = true;
}
}
private void selectBeatmap(BeatmapSetInfo set, BeatmapInfo beatmap)
{
if (selectedBeatmap == beatmap)
return;
selectBeatmapSet(set);
selectedBeatmap = beatmap;
}
private void addBeatmapSet(BeatmapSetInfo beatmapSet)
{
beatmapSet = beatmaps.GetWithChildren<BeatmapSetInfo>(beatmapSet.BeatmapSetID);
beatmapSet.Beatmaps.ForEach(b => beatmaps.GetChildren(b));
beatmapSet.Beatmaps = beatmapSet.Beatmaps.OrderBy(b => b.BaseDifficulty.OverallDifficulty)
.ToList();
Scheduler.Add(() =>
{
var group = new BeatmapGroup(beatmapSet)
{
SetSelected = selectBeatmapSet,
BeatmapSelected = selectBeatmap,
};
setList.Add(group);
if (setList.Children.Count() == 1)
{
selectedBeatmapSet = group.BeatmapSet;
selectedBeatmap = group.SelectedBeatmap;
group.Collapsed = false;
}
});
}
private void addBeatmapSets()
{
foreach (var beatmapSet in beatmaps.Query<BeatmapSetInfo>())
addBeatmapSet(beatmapSet);
}
} }
} }

View File

@ -117,7 +117,7 @@
<Compile Include="GameModes\Play\ModSelect.cs" /> <Compile Include="GameModes\Play\ModSelect.cs" />
<Compile Include="GameModes\Play\Osu\ScoreOverlayOsu.cs" /> <Compile Include="GameModes\Play\Osu\ScoreOverlayOsu.cs" />
<Compile Include="GameModes\Play\BeatmapGroup.cs" /> <Compile Include="GameModes\Play\BeatmapGroup.cs" />
<Compile Include="GameModes\Play\BeatmapButton.cs" /> <Compile Include="GameModes\Play\BeatmapPanel.cs" />
<Compile Include="GameModes\Play\Player.cs" /> <Compile Include="GameModes\Play\Player.cs" />
<Compile Include="GameModes\Charts\ChartListing.cs" /> <Compile Include="GameModes\Charts\ChartListing.cs" />
<Compile Include="GameModes\Play\PlayMode.cs" /> <Compile Include="GameModes\Play\PlayMode.cs" />
@ -191,7 +191,6 @@
<Compile Include="Database\BeatmapMetadata.cs" /> <Compile Include="Database\BeatmapMetadata.cs" />
<Compile Include="Database\BeatmapInfo.cs" /> <Compile Include="Database\BeatmapInfo.cs" />
<Compile Include="Database\BaseDifficulty.cs" /> <Compile Include="Database\BaseDifficulty.cs" />
<Compile Include="Beatmaps\IO\BeatmapResourceStore.cs" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="$(SolutionDir)\osu-framework\osu.Framework\osu.Framework.csproj"> <ProjectReference Include="$(SolutionDir)\osu-framework\osu.Framework\osu.Framework.csproj">