mirror of
https://github.com/ppy/osu.git
synced 2025-01-28 08:02:55 +08:00
Merge pull request #13804 from bdach/migrate-directory-selector
Migrate file/directory selectors to use framework component instead of local implementation
This commit is contained in:
commit
f7dc689832
@ -12,7 +12,7 @@ namespace osu.Game.Tests.Visual.Settings
|
|||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load()
|
private void load()
|
||||||
{
|
{
|
||||||
Add(new DirectorySelector { RelativeSizeAxes = Axes.Both });
|
Add(new OsuDirectorySelector { RelativeSizeAxes = Axes.Both });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -12,13 +12,13 @@ namespace osu.Game.Tests.Visual.Settings
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestAllFiles()
|
public void TestAllFiles()
|
||||||
{
|
{
|
||||||
AddStep("create", () => Child = new FileSelector { RelativeSizeAxes = Axes.Both });
|
AddStep("create", () => Child = new OsuFileSelector { RelativeSizeAxes = Axes.Both });
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestJpgFilesOnly()
|
public void TestJpgFilesOnly()
|
||||||
{
|
{
|
||||||
AddStep("create", () => Child = new FileSelector(validFileExtensions: new[] { ".jpg" }) { RelativeSizeAxes = Axes.Both });
|
AddStep("create", () => Child = new OsuFileSelector(validFileExtensions: new[] { ".jpg" }) { RelativeSizeAxes = Axes.Both });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,7 +30,7 @@ namespace osu.Game.Tournament.Screens.Setup
|
|||||||
[Resolved]
|
[Resolved]
|
||||||
private MatchIPCInfo ipc { get; set; }
|
private MatchIPCInfo ipc { get; set; }
|
||||||
|
|
||||||
private DirectorySelector directorySelector;
|
private OsuDirectorySelector directorySelector;
|
||||||
private DialogOverlay overlay;
|
private DialogOverlay overlay;
|
||||||
|
|
||||||
[BackgroundDependencyLoader(true)]
|
[BackgroundDependencyLoader(true)]
|
||||||
@ -79,7 +79,7 @@ namespace osu.Game.Tournament.Screens.Setup
|
|||||||
},
|
},
|
||||||
new Drawable[]
|
new Drawable[]
|
||||||
{
|
{
|
||||||
directorySelector = new DirectorySelector(initialPath)
|
directorySelector = new OsuDirectorySelector(initialPath)
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.Both,
|
RelativeSizeAxes = Axes.Both,
|
||||||
}
|
}
|
||||||
|
@ -1,297 +0,0 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
|
||||||
// See the LICENCE file in the repository root for full licence text.
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.IO;
|
|
||||||
using System.Linq;
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Framework.Bindables;
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Framework.Graphics.Shapes;
|
|
||||||
using osu.Framework.Graphics.Sprites;
|
|
||||||
using osu.Framework.Input.Events;
|
|
||||||
using osu.Framework.Platform;
|
|
||||||
using osu.Game.Graphics.Containers;
|
|
||||||
using osu.Game.Graphics.Sprites;
|
|
||||||
using osuTK;
|
|
||||||
using osuTK.Graphics;
|
|
||||||
|
|
||||||
namespace osu.Game.Graphics.UserInterfaceV2
|
|
||||||
{
|
|
||||||
public class DirectorySelector : CompositeDrawable
|
|
||||||
{
|
|
||||||
private FillFlowContainer directoryFlow;
|
|
||||||
|
|
||||||
[Resolved]
|
|
||||||
private GameHost host { get; set; }
|
|
||||||
|
|
||||||
[Cached]
|
|
||||||
public readonly Bindable<DirectoryInfo> CurrentPath = new Bindable<DirectoryInfo>();
|
|
||||||
|
|
||||||
public DirectorySelector(string initialPath = null)
|
|
||||||
{
|
|
||||||
CurrentPath.Value = new DirectoryInfo(initialPath ?? Environment.GetFolderPath(Environment.SpecialFolder.UserProfile));
|
|
||||||
}
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load()
|
|
||||||
{
|
|
||||||
Padding = new MarginPadding(10);
|
|
||||||
|
|
||||||
InternalChild = new GridContainer
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
RowDimensions = new[]
|
|
||||||
{
|
|
||||||
new Dimension(GridSizeMode.Absolute, 50),
|
|
||||||
new Dimension(),
|
|
||||||
},
|
|
||||||
Content = new[]
|
|
||||||
{
|
|
||||||
new Drawable[]
|
|
||||||
{
|
|
||||||
new CurrentDirectoryDisplay
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
new Drawable[]
|
|
||||||
{
|
|
||||||
new OsuScrollContainer
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Child = directoryFlow = new FillFlowContainer
|
|
||||||
{
|
|
||||||
AutoSizeAxes = Axes.Y,
|
|
||||||
RelativeSizeAxes = Axes.X,
|
|
||||||
Direction = FillDirection.Vertical,
|
|
||||||
Spacing = new Vector2(2),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
CurrentPath.BindValueChanged(updateDisplay, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void updateDisplay(ValueChangedEvent<DirectoryInfo> directory)
|
|
||||||
{
|
|
||||||
directoryFlow.Clear();
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
if (directory.NewValue == null)
|
|
||||||
{
|
|
||||||
var drives = DriveInfo.GetDrives();
|
|
||||||
|
|
||||||
foreach (var drive in drives)
|
|
||||||
directoryFlow.Add(new DirectoryPiece(drive.RootDirectory));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
directoryFlow.Add(new ParentDirectoryPiece(CurrentPath.Value.Parent));
|
|
||||||
|
|
||||||
directoryFlow.AddRange(GetEntriesForPath(CurrentPath.Value));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (Exception)
|
|
||||||
{
|
|
||||||
CurrentPath.Value = directory.OldValue;
|
|
||||||
this.FlashColour(Color4.Red, 300);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected virtual IEnumerable<DisplayPiece> GetEntriesForPath(DirectoryInfo path)
|
|
||||||
{
|
|
||||||
foreach (var dir in path.GetDirectories().OrderBy(d => d.Name))
|
|
||||||
{
|
|
||||||
if ((dir.Attributes & FileAttributes.Hidden) == 0)
|
|
||||||
yield return new DirectoryPiece(dir);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private class CurrentDirectoryDisplay : CompositeDrawable
|
|
||||||
{
|
|
||||||
[Resolved]
|
|
||||||
private Bindable<DirectoryInfo> currentDirectory { get; set; }
|
|
||||||
|
|
||||||
private FillFlowContainer flow;
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load()
|
|
||||||
{
|
|
||||||
InternalChildren = new Drawable[]
|
|
||||||
{
|
|
||||||
flow = new FillFlowContainer
|
|
||||||
{
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
RelativeSizeAxes = Axes.X,
|
|
||||||
Spacing = new Vector2(5),
|
|
||||||
Height = DisplayPiece.HEIGHT,
|
|
||||||
Direction = FillDirection.Horizontal,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
currentDirectory.BindValueChanged(updateDisplay, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void updateDisplay(ValueChangedEvent<DirectoryInfo> dir)
|
|
||||||
{
|
|
||||||
flow.Clear();
|
|
||||||
|
|
||||||
List<DirectoryPiece> pathPieces = new List<DirectoryPiece>();
|
|
||||||
|
|
||||||
DirectoryInfo ptr = dir.NewValue;
|
|
||||||
|
|
||||||
while (ptr != null)
|
|
||||||
{
|
|
||||||
pathPieces.Insert(0, new CurrentDisplayPiece(ptr));
|
|
||||||
ptr = ptr.Parent;
|
|
||||||
}
|
|
||||||
|
|
||||||
flow.ChildrenEnumerable = new Drawable[]
|
|
||||||
{
|
|
||||||
new OsuSpriteText { Text = "Current Directory: ", Font = OsuFont.Default.With(size: DisplayPiece.HEIGHT), },
|
|
||||||
new ComputerPiece(),
|
|
||||||
}.Concat(pathPieces);
|
|
||||||
}
|
|
||||||
|
|
||||||
private class ComputerPiece : CurrentDisplayPiece
|
|
||||||
{
|
|
||||||
protected override IconUsage? Icon => null;
|
|
||||||
|
|
||||||
public ComputerPiece()
|
|
||||||
: base(null, "Computer")
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private class CurrentDisplayPiece : DirectoryPiece
|
|
||||||
{
|
|
||||||
public CurrentDisplayPiece(DirectoryInfo directory, string displayName = null)
|
|
||||||
: base(directory, displayName)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load()
|
|
||||||
{
|
|
||||||
Flow.Add(new SpriteIcon
|
|
||||||
{
|
|
||||||
Anchor = Anchor.CentreLeft,
|
|
||||||
Origin = Anchor.CentreLeft,
|
|
||||||
Icon = FontAwesome.Solid.ChevronRight,
|
|
||||||
Size = new Vector2(FONT_SIZE / 2)
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override IconUsage? Icon => Directory.Name.Contains(Path.DirectorySeparatorChar) ? base.Icon : null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private class ParentDirectoryPiece : DirectoryPiece
|
|
||||||
{
|
|
||||||
protected override IconUsage? Icon => FontAwesome.Solid.Folder;
|
|
||||||
|
|
||||||
public ParentDirectoryPiece(DirectoryInfo directory)
|
|
||||||
: base(directory, "..")
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected class DirectoryPiece : DisplayPiece
|
|
||||||
{
|
|
||||||
protected readonly DirectoryInfo Directory;
|
|
||||||
|
|
||||||
[Resolved]
|
|
||||||
private Bindable<DirectoryInfo> currentDirectory { get; set; }
|
|
||||||
|
|
||||||
public DirectoryPiece(DirectoryInfo directory, string displayName = null)
|
|
||||||
: base(displayName)
|
|
||||||
{
|
|
||||||
Directory = directory;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override bool OnClick(ClickEvent e)
|
|
||||||
{
|
|
||||||
currentDirectory.Value = Directory;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override string FallbackName => Directory.Name;
|
|
||||||
|
|
||||||
protected override IconUsage? Icon => Directory.Name.Contains(Path.DirectorySeparatorChar)
|
|
||||||
? FontAwesome.Solid.Database
|
|
||||||
: FontAwesome.Regular.Folder;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected abstract class DisplayPiece : CompositeDrawable
|
|
||||||
{
|
|
||||||
public const float HEIGHT = 20;
|
|
||||||
|
|
||||||
protected const float FONT_SIZE = 16;
|
|
||||||
|
|
||||||
private readonly string displayName;
|
|
||||||
|
|
||||||
protected FillFlowContainer Flow;
|
|
||||||
|
|
||||||
protected DisplayPiece(string displayName = null)
|
|
||||||
{
|
|
||||||
this.displayName = displayName;
|
|
||||||
}
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load(OsuColour colours)
|
|
||||||
{
|
|
||||||
AutoSizeAxes = Axes.Both;
|
|
||||||
|
|
||||||
Masking = true;
|
|
||||||
CornerRadius = 5;
|
|
||||||
|
|
||||||
InternalChildren = new Drawable[]
|
|
||||||
{
|
|
||||||
new Box
|
|
||||||
{
|
|
||||||
Colour = colours.GreySeafoamDarker,
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
},
|
|
||||||
Flow = new FillFlowContainer
|
|
||||||
{
|
|
||||||
AutoSizeAxes = Axes.X,
|
|
||||||
Height = 20,
|
|
||||||
Margin = new MarginPadding { Vertical = 2, Horizontal = 5 },
|
|
||||||
Direction = FillDirection.Horizontal,
|
|
||||||
Spacing = new Vector2(5),
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
if (Icon.HasValue)
|
|
||||||
{
|
|
||||||
Flow.Add(new SpriteIcon
|
|
||||||
{
|
|
||||||
Anchor = Anchor.CentreLeft,
|
|
||||||
Origin = Anchor.CentreLeft,
|
|
||||||
Icon = Icon.Value,
|
|
||||||
Size = new Vector2(FONT_SIZE)
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
Flow.Add(new OsuSpriteText
|
|
||||||
{
|
|
||||||
Anchor = Anchor.CentreLeft,
|
|
||||||
Origin = Anchor.CentreLeft,
|
|
||||||
Text = displayName ?? FallbackName,
|
|
||||||
Font = OsuFont.Default.With(size: FONT_SIZE)
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
protected abstract string FallbackName { get; }
|
|
||||||
|
|
||||||
protected abstract IconUsage? Icon { get; }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,94 +0,0 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
|
||||||
// See the LICENCE file in the repository root for full licence text.
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.IO;
|
|
||||||
using System.Linq;
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Framework.Bindables;
|
|
||||||
using osu.Framework.Graphics.Sprites;
|
|
||||||
using osu.Framework.Input.Events;
|
|
||||||
|
|
||||||
namespace osu.Game.Graphics.UserInterfaceV2
|
|
||||||
{
|
|
||||||
public class FileSelector : DirectorySelector
|
|
||||||
{
|
|
||||||
private readonly string[] validFileExtensions;
|
|
||||||
|
|
||||||
[Cached]
|
|
||||||
public readonly Bindable<FileInfo> CurrentFile = new Bindable<FileInfo>();
|
|
||||||
|
|
||||||
public FileSelector(string initialPath = null, string[] validFileExtensions = null)
|
|
||||||
: base(initialPath)
|
|
||||||
{
|
|
||||||
this.validFileExtensions = validFileExtensions ?? Array.Empty<string>();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override IEnumerable<DisplayPiece> GetEntriesForPath(DirectoryInfo path)
|
|
||||||
{
|
|
||||||
foreach (var dir in base.GetEntriesForPath(path))
|
|
||||||
yield return dir;
|
|
||||||
|
|
||||||
IEnumerable<FileInfo> files = path.GetFiles();
|
|
||||||
|
|
||||||
if (validFileExtensions.Length > 0)
|
|
||||||
files = files.Where(f => validFileExtensions.Contains(f.Extension));
|
|
||||||
|
|
||||||
foreach (var file in files.OrderBy(d => d.Name))
|
|
||||||
{
|
|
||||||
if ((file.Attributes & FileAttributes.Hidden) == 0)
|
|
||||||
yield return new FilePiece(file);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected class FilePiece : DisplayPiece
|
|
||||||
{
|
|
||||||
private readonly FileInfo file;
|
|
||||||
|
|
||||||
[Resolved]
|
|
||||||
private Bindable<FileInfo> currentFile { get; set; }
|
|
||||||
|
|
||||||
public FilePiece(FileInfo file)
|
|
||||||
{
|
|
||||||
this.file = file;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override bool OnClick(ClickEvent e)
|
|
||||||
{
|
|
||||||
currentFile.Value = file;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override string FallbackName => file.Name;
|
|
||||||
|
|
||||||
protected override IconUsage? Icon
|
|
||||||
{
|
|
||||||
get
|
|
||||||
{
|
|
||||||
switch (file.Extension)
|
|
||||||
{
|
|
||||||
case ".ogg":
|
|
||||||
case ".mp3":
|
|
||||||
case ".wav":
|
|
||||||
return FontAwesome.Regular.FileAudio;
|
|
||||||
|
|
||||||
case ".jpg":
|
|
||||||
case ".jpeg":
|
|
||||||
case ".png":
|
|
||||||
return FontAwesome.Regular.FileImage;
|
|
||||||
|
|
||||||
case ".mp4":
|
|
||||||
case ".avi":
|
|
||||||
case ".mov":
|
|
||||||
case ".flv":
|
|
||||||
return FontAwesome.Regular.FileVideo;
|
|
||||||
|
|
||||||
default:
|
|
||||||
return FontAwesome.Regular.File;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
38
osu.Game/Graphics/UserInterfaceV2/OsuDirectorySelector.cs
Normal file
38
osu.Game/Graphics/UserInterfaceV2/OsuDirectorySelector.cs
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
||||||
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
|
using System.IO;
|
||||||
|
using osu.Framework.Allocation;
|
||||||
|
using osu.Framework.Graphics;
|
||||||
|
using osu.Framework.Graphics.Containers;
|
||||||
|
using osu.Framework.Graphics.UserInterface;
|
||||||
|
using osu.Game.Graphics.Containers;
|
||||||
|
|
||||||
|
namespace osu.Game.Graphics.UserInterfaceV2
|
||||||
|
{
|
||||||
|
public class OsuDirectorySelector : DirectorySelector
|
||||||
|
{
|
||||||
|
public const float ITEM_HEIGHT = 20;
|
||||||
|
|
||||||
|
public OsuDirectorySelector(string initialPath = null)
|
||||||
|
: base(initialPath)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load()
|
||||||
|
{
|
||||||
|
Padding = new MarginPadding(10);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override ScrollContainer<Drawable> CreateScrollContainer() => new OsuScrollContainer();
|
||||||
|
|
||||||
|
protected override DirectorySelectorBreadcrumbDisplay CreateBreadcrumb() => new OsuDirectorySelectorBreadcrumbDisplay();
|
||||||
|
|
||||||
|
protected override DirectorySelectorDirectory CreateParentDirectoryItem(DirectoryInfo directory) => new OsuDirectorySelectorParentDirectory(directory);
|
||||||
|
|
||||||
|
protected override DirectorySelectorDirectory CreateDirectoryItem(DirectoryInfo directory, string displayName = null) => new OsuDirectorySelectorDirectory(directory, displayName);
|
||||||
|
|
||||||
|
protected override void NotifySelectionError() => this.FlashColour(Colour4.Red, 300);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,64 @@
|
|||||||
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
||||||
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
|
using System.IO;
|
||||||
|
using osu.Framework.Allocation;
|
||||||
|
using osu.Framework.Graphics;
|
||||||
|
using osu.Framework.Graphics.Sprites;
|
||||||
|
using osu.Framework.Graphics.UserInterface;
|
||||||
|
using osu.Game.Graphics.Sprites;
|
||||||
|
using osuTK;
|
||||||
|
|
||||||
|
namespace osu.Game.Graphics.UserInterfaceV2
|
||||||
|
{
|
||||||
|
internal class OsuDirectorySelectorBreadcrumbDisplay : DirectorySelectorBreadcrumbDisplay
|
||||||
|
{
|
||||||
|
protected override Drawable CreateCaption() => new OsuSpriteText
|
||||||
|
{
|
||||||
|
Text = "Current Directory: ",
|
||||||
|
Font = OsuFont.Default.With(size: OsuDirectorySelector.ITEM_HEIGHT),
|
||||||
|
};
|
||||||
|
|
||||||
|
protected override DirectorySelectorDirectory CreateRootDirectoryItem() => new OsuBreadcrumbDisplayComputer();
|
||||||
|
|
||||||
|
protected override DirectorySelectorDirectory CreateDirectoryItem(DirectoryInfo directory, string displayName = null) => new OsuBreadcrumbDisplayDirectory(directory, displayName);
|
||||||
|
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load()
|
||||||
|
{
|
||||||
|
Height = 50;
|
||||||
|
}
|
||||||
|
|
||||||
|
private class OsuBreadcrumbDisplayComputer : OsuBreadcrumbDisplayDirectory
|
||||||
|
{
|
||||||
|
protected override IconUsage? Icon => null;
|
||||||
|
|
||||||
|
public OsuBreadcrumbDisplayComputer()
|
||||||
|
: base(null, "Computer")
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private class OsuBreadcrumbDisplayDirectory : OsuDirectorySelectorDirectory
|
||||||
|
{
|
||||||
|
public OsuBreadcrumbDisplayDirectory(DirectoryInfo directory, string displayName = null)
|
||||||
|
: base(directory, displayName)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load()
|
||||||
|
{
|
||||||
|
Flow.Add(new SpriteIcon
|
||||||
|
{
|
||||||
|
Anchor = Anchor.CentreLeft,
|
||||||
|
Origin = Anchor.CentreLeft,
|
||||||
|
Icon = FontAwesome.Solid.ChevronRight,
|
||||||
|
Size = new Vector2(FONT_SIZE / 2)
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override IconUsage? Icon => Directory.Name.Contains(Path.DirectorySeparatorChar) ? base.Icon : null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,58 @@
|
|||||||
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
||||||
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
|
using System.IO;
|
||||||
|
using osu.Framework.Allocation;
|
||||||
|
using osu.Framework.Graphics;
|
||||||
|
using osu.Framework.Graphics.Containers;
|
||||||
|
using osu.Framework.Graphics.Shapes;
|
||||||
|
using osu.Framework.Graphics.Sprites;
|
||||||
|
using osu.Framework.Graphics.UserInterface;
|
||||||
|
using osu.Game.Graphics.Sprites;
|
||||||
|
|
||||||
|
namespace osu.Game.Graphics.UserInterfaceV2
|
||||||
|
{
|
||||||
|
internal class OsuDirectorySelectorDirectory : DirectorySelectorDirectory
|
||||||
|
{
|
||||||
|
public OsuDirectorySelectorDirectory(DirectoryInfo directory, string displayName = null)
|
||||||
|
: base(directory, displayName)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load()
|
||||||
|
{
|
||||||
|
Flow.AutoSizeAxes = Axes.X;
|
||||||
|
Flow.Height = OsuDirectorySelector.ITEM_HEIGHT;
|
||||||
|
|
||||||
|
AddInternal(new Background
|
||||||
|
{
|
||||||
|
Depth = 1
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override SpriteText CreateSpriteText() => new OsuSpriteText();
|
||||||
|
|
||||||
|
protected override IconUsage? Icon => Directory.Name.Contains(Path.DirectorySeparatorChar)
|
||||||
|
? FontAwesome.Solid.Database
|
||||||
|
: FontAwesome.Regular.Folder;
|
||||||
|
|
||||||
|
internal class Background : CompositeDrawable
|
||||||
|
{
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load(OsuColour colours)
|
||||||
|
{
|
||||||
|
RelativeSizeAxes = Axes.Both;
|
||||||
|
|
||||||
|
Masking = true;
|
||||||
|
CornerRadius = 5;
|
||||||
|
|
||||||
|
InternalChild = new Box
|
||||||
|
{
|
||||||
|
Colour = colours.GreySeafoamDarker,
|
||||||
|
RelativeSizeAxes = Axes.Both,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,18 @@
|
|||||||
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
||||||
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
|
using System.IO;
|
||||||
|
using osu.Framework.Graphics.Sprites;
|
||||||
|
|
||||||
|
namespace osu.Game.Graphics.UserInterfaceV2
|
||||||
|
{
|
||||||
|
internal class OsuDirectorySelectorParentDirectory : OsuDirectorySelectorDirectory
|
||||||
|
{
|
||||||
|
protected override IconUsage? Icon => FontAwesome.Solid.Folder;
|
||||||
|
|
||||||
|
public OsuDirectorySelectorParentDirectory(DirectoryInfo directory)
|
||||||
|
: base(directory, "..")
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
90
osu.Game/Graphics/UserInterfaceV2/OsuFileSelector.cs
Normal file
90
osu.Game/Graphics/UserInterfaceV2/OsuFileSelector.cs
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
||||||
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
|
using System.IO;
|
||||||
|
using osu.Framework.Allocation;
|
||||||
|
using osu.Framework.Graphics;
|
||||||
|
using osu.Framework.Graphics.Containers;
|
||||||
|
using osu.Framework.Graphics.Sprites;
|
||||||
|
using osu.Framework.Graphics.UserInterface;
|
||||||
|
using osu.Game.Graphics.Containers;
|
||||||
|
using osu.Game.Graphics.Sprites;
|
||||||
|
|
||||||
|
namespace osu.Game.Graphics.UserInterfaceV2
|
||||||
|
{
|
||||||
|
public class OsuFileSelector : FileSelector
|
||||||
|
{
|
||||||
|
public OsuFileSelector(string initialPath = null, string[] validFileExtensions = null)
|
||||||
|
: base(initialPath, validFileExtensions)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load()
|
||||||
|
{
|
||||||
|
Padding = new MarginPadding(10);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override ScrollContainer<Drawable> CreateScrollContainer() => new OsuScrollContainer();
|
||||||
|
|
||||||
|
protected override DirectorySelectorBreadcrumbDisplay CreateBreadcrumb() => new OsuDirectorySelectorBreadcrumbDisplay();
|
||||||
|
|
||||||
|
protected override DirectorySelectorDirectory CreateParentDirectoryItem(DirectoryInfo directory) => new OsuDirectorySelectorParentDirectory(directory);
|
||||||
|
|
||||||
|
protected override DirectorySelectorDirectory CreateDirectoryItem(DirectoryInfo directory, string displayName = null) => new OsuDirectorySelectorDirectory(directory, displayName);
|
||||||
|
|
||||||
|
protected override DirectoryListingFile CreateFileItem(FileInfo file) => new OsuDirectoryListingFile(file);
|
||||||
|
|
||||||
|
protected override void NotifySelectionError() => this.FlashColour(Colour4.Red, 300);
|
||||||
|
|
||||||
|
protected class OsuDirectoryListingFile : DirectoryListingFile
|
||||||
|
{
|
||||||
|
public OsuDirectoryListingFile(FileInfo file)
|
||||||
|
: base(file)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load()
|
||||||
|
{
|
||||||
|
Flow.AutoSizeAxes = Axes.X;
|
||||||
|
Flow.Height = OsuDirectorySelector.ITEM_HEIGHT;
|
||||||
|
|
||||||
|
AddInternal(new OsuDirectorySelectorDirectory.Background
|
||||||
|
{
|
||||||
|
Depth = 1
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override IconUsage? Icon
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
switch (File.Extension)
|
||||||
|
{
|
||||||
|
case @".ogg":
|
||||||
|
case @".mp3":
|
||||||
|
case @".wav":
|
||||||
|
return FontAwesome.Regular.FileAudio;
|
||||||
|
|
||||||
|
case @".jpg":
|
||||||
|
case @".jpeg":
|
||||||
|
case @".png":
|
||||||
|
return FontAwesome.Regular.FileImage;
|
||||||
|
|
||||||
|
case @".mp4":
|
||||||
|
case @".avi":
|
||||||
|
case @".mov":
|
||||||
|
case @".flv":
|
||||||
|
return FontAwesome.Regular.FileVideo;
|
||||||
|
|
||||||
|
default:
|
||||||
|
return FontAwesome.Regular.File;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override SpriteText CreateSpriteText() => new OsuSpriteText();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -21,7 +21,7 @@ namespace osu.Game.Overlays.Settings.Sections.Maintenance
|
|||||||
{
|
{
|
||||||
private TriangleButton selectionButton;
|
private TriangleButton selectionButton;
|
||||||
|
|
||||||
private DirectorySelector directorySelector;
|
private OsuDirectorySelector directorySelector;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Text to display in the header to inform the user of what they are selecting.
|
/// Text to display in the header to inform the user of what they are selecting.
|
||||||
@ -91,7 +91,7 @@ namespace osu.Game.Overlays.Settings.Sections.Maintenance
|
|||||||
},
|
},
|
||||||
new Drawable[]
|
new Drawable[]
|
||||||
{
|
{
|
||||||
directorySelector = new DirectorySelector
|
directorySelector = new OsuDirectorySelector
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.Both,
|
RelativeSizeAxes = Axes.Both,
|
||||||
}
|
}
|
||||||
|
@ -56,9 +56,9 @@ namespace osu.Game.Screens.Edit.Setup
|
|||||||
|
|
||||||
public void DisplayFileChooser()
|
public void DisplayFileChooser()
|
||||||
{
|
{
|
||||||
FileSelector fileSelector;
|
OsuFileSelector fileSelector;
|
||||||
|
|
||||||
Target.Child = fileSelector = new FileSelector(currentFile.Value?.DirectoryName, handledExtensions)
|
Target.Child = fileSelector = new OsuFileSelector(currentFile.Value?.DirectoryName, handledExtensions)
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.X,
|
RelativeSizeAxes = Axes.X,
|
||||||
Height = 400,
|
Height = 400,
|
||||||
|
@ -23,7 +23,7 @@ namespace osu.Game.Screens.Import
|
|||||||
{
|
{
|
||||||
public override bool HideOverlaysOnEnter => true;
|
public override bool HideOverlaysOnEnter => true;
|
||||||
|
|
||||||
private FileSelector fileSelector;
|
private OsuFileSelector fileSelector;
|
||||||
private Container contentContainer;
|
private Container contentContainer;
|
||||||
private TextFlowContainer currentFileText;
|
private TextFlowContainer currentFileText;
|
||||||
|
|
||||||
@ -57,7 +57,7 @@ namespace osu.Game.Screens.Import
|
|||||||
Colour = colours.GreySeafoamDark,
|
Colour = colours.GreySeafoamDark,
|
||||||
RelativeSizeAxes = Axes.Both,
|
RelativeSizeAxes = Axes.Both,
|
||||||
},
|
},
|
||||||
fileSelector = new FileSelector(validFileExtensions: game.HandledExtensions.ToArray())
|
fileSelector = new OsuFileSelector(validFileExtensions: game.HandledExtensions.ToArray())
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.Both,
|
RelativeSizeAxes = Axes.Both,
|
||||||
Width = 0.65f
|
Width = 0.65f
|
||||||
|
Loading…
Reference in New Issue
Block a user