1
0
mirror of https://github.com/ppy/osu.git synced 2024-11-07 08:07:23 +08:00
osu-lazer/osu.Game/Screens/Edit/Compose/ComposeScreen.cs

117 lines
4.0 KiB
C#
Raw Normal View History

// 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.
2018-04-13 17:19:50 +08:00
using System.Diagnostics;
2021-03-29 17:30:23 +08:00
using System.Linq;
using osu.Framework.Allocation;
using osu.Framework.Bindables;
2018-04-13 17:19:50 +08:00
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using osu.Framework.Input;
using osu.Framework.Input.Bindings;
2021-03-29 17:30:23 +08:00
using osu.Framework.Platform;
using osu.Game.Beatmaps;
2021-03-29 17:30:23 +08:00
using osu.Game.Extensions;
using osu.Game.Rulesets;
2019-12-05 19:12:25 +08:00
using osu.Game.Rulesets.Edit;
using osu.Game.Screens.Edit.Compose.Components.Timeline;
using osu.Game.Skinning;
2018-04-13 17:19:50 +08:00
2018-11-06 17:28:22 +08:00
namespace osu.Game.Screens.Edit.Compose
2018-04-13 17:19:50 +08:00
{
public class ComposeScreen : EditorScreenWithTimeline, IKeyBindingHandler<PlatformAction>
2018-04-13 17:19:50 +08:00
{
[Resolved]
private IBindable<WorkingBeatmap> beatmap { get; set; }
2021-03-29 17:30:23 +08:00
[Resolved]
private GameHost host { get; set; }
[Resolved]
private EditorClock clock { get; set; }
2019-12-05 19:12:25 +08:00
2021-03-29 17:30:23 +08:00
private HitObjectComposer composer;
public ComposeScreen()
: base(EditorScreenMode.Compose)
{
}
private Ruleset ruleset;
protected override IReadOnlyDependencyContainer CreateChildDependencies(IReadOnlyDependencyContainer parent)
2018-04-13 17:19:50 +08:00
{
var dependencies = new DependencyContainer(base.CreateChildDependencies(parent));
ruleset = parent.Get<IBindable<WorkingBeatmap>>().Value.BeatmapInfo.Ruleset?.CreateInstance();
2019-12-05 19:12:25 +08:00
composer = ruleset?.CreateHitObjectComposer();
2019-04-01 11:16:05 +08:00
// make the composer available to the timeline and other components in this screen.
if (composer != null)
dependencies.CacheAs(composer);
return dependencies;
}
protected override Drawable CreateMainContent()
{
2019-12-06 11:51:43 +08:00
if (ruleset == null || composer == null)
return new ScreenWhiteBox.UnderConstructionMessage(ruleset == null ? "This beatmap" : $"{ruleset.Description}'s composer");
2018-04-13 17:19:50 +08:00
return wrapSkinnableContent(composer);
}
protected override Drawable CreateTimelineContent()
{
if (ruleset == null || composer == null)
return base.CreateTimelineContent();
return wrapSkinnableContent(new TimelineBlueprintContainer(composer));
}
private Drawable wrapSkinnableContent(Drawable content)
{
Debug.Assert(ruleset != null);
var beatmapSkinProvider = new BeatmapSkinProvidingContainer(beatmap.Value.Skin);
2019-12-06 11:51:43 +08:00
// the beatmapSkinProvider is used as the fallback source here to allow the ruleset-specific skin implementation
// full access to all skin sources.
var rulesetSkinProvider = new SkinProvidingContainer(ruleset.CreateLegacySkinProvider(beatmapSkinProvider, EditorBeatmap.PlayableBeatmap));
2019-12-06 11:51:43 +08:00
// load the skinning hierarchy first.
// this is intentionally done in two stages to ensure things are in a loaded state before exposing the ruleset to skin sources.
return beatmapSkinProvider.WithChild(rulesetSkinProvider.WithChild(content));
2018-04-13 17:19:50 +08:00
}
#region Input Handling
public bool OnPressed(PlatformAction action)
{
if (action.ActionType == PlatformActionType.Copy)
host.GetClipboard().SetText(formatSelectionAsString());
return false;
}
public void OnReleased(PlatformAction action)
{
}
2021-03-29 17:30:23 +08:00
private string formatSelectionAsString()
{
2021-03-29 17:51:28 +08:00
if (composer == null)
return string.Empty;
2021-03-29 17:30:23 +08:00
2021-03-29 17:51:28 +08:00
double displayTime = EditorBeatmap.SelectedHitObjects.OrderBy(h => h.StartTime).FirstOrDefault()?.StartTime ?? clock.CurrentTime;
string selectionAsString = composer.ConvertSelectionToString();
2021-03-29 17:30:23 +08:00
2021-03-29 17:51:28 +08:00
return !string.IsNullOrEmpty(selectionAsString)
? $"{displayTime.ToEditorFormattedString()} ({selectionAsString}) - "
: $"{displayTime.ToEditorFormattedString()} - ";
2021-03-29 17:30:23 +08:00
}
#endregion
2018-04-13 17:19:50 +08:00
}
}