mirror of
https://github.com/ppy/osu.git
synced 2025-01-15 13:23:22 +08:00
Make PreviewTrack a component and use LoadComponentAsync
This commit is contained in:
parent
5566732664
commit
330ce19041
@ -2,25 +2,36 @@
|
|||||||
// 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 osu.Framework.Allocation;
|
||||||
using osu.Framework.Audio.Track;
|
using osu.Framework.Audio.Track;
|
||||||
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
|
using osu.Game.Beatmaps;
|
||||||
|
|
||||||
namespace osu.Game.Audio
|
namespace osu.Game.Audio
|
||||||
{
|
{
|
||||||
public class PreviewTrack
|
public class PreviewTrack : Component
|
||||||
{
|
{
|
||||||
public readonly Track Track;
|
public Track Track { get; private set; }
|
||||||
public readonly OverlayContainer Owner;
|
public readonly OverlayContainer Owner;
|
||||||
|
|
||||||
|
private readonly BeatmapSetInfo beatmapSetInfo;
|
||||||
|
|
||||||
public event Action Stopped;
|
public event Action Stopped;
|
||||||
public event Action Started;
|
public event Action Started;
|
||||||
|
|
||||||
public PreviewTrack(Track track, OverlayContainer owner)
|
public PreviewTrack(BeatmapSetInfo beatmapSetInfo, OverlayContainer owner)
|
||||||
{
|
{
|
||||||
Track = track;
|
this.beatmapSetInfo = beatmapSetInfo;
|
||||||
Owner = owner;
|
Owner = owner;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load(PreviewTrackManager previewTrackManager)
|
||||||
|
{
|
||||||
|
Track = previewTrackManager.Get(this, beatmapSetInfo);
|
||||||
|
}
|
||||||
|
|
||||||
public void Start()
|
public void Start()
|
||||||
{
|
{
|
||||||
Track.Restart();
|
Track.Restart();
|
||||||
|
@ -6,7 +6,6 @@ using osu.Framework.Audio;
|
|||||||
using osu.Framework.Audio.Track;
|
using osu.Framework.Audio.Track;
|
||||||
using osu.Framework.Configuration;
|
using osu.Framework.Configuration;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Framework.IO.Stores;
|
using osu.Framework.IO.Stores;
|
||||||
using osu.Game.Beatmaps;
|
using osu.Game.Beatmaps;
|
||||||
|
|
||||||
@ -32,12 +31,16 @@ namespace osu.Game.Audio
|
|||||||
config.BindWith(FrameworkSetting.VolumeMusic, trackManager.Volume);
|
config.BindWith(FrameworkSetting.VolumeMusic, trackManager.Volume);
|
||||||
}
|
}
|
||||||
|
|
||||||
public PreviewTrack Get(BeatmapSetInfo beatmapSetInfo, OverlayContainer previewOwner)
|
protected override void Update()
|
||||||
{
|
{
|
||||||
var previewTrack = new PreviewTrack(
|
if (CurrentTrack?.Track.HasCompleted ?? false)
|
||||||
trackManager.Get($"https://b.ppy.sh/preview/{beatmapSetInfo?.OnlineBeatmapSetID}.mp3"),
|
CurrentTrack.Stop();
|
||||||
previewOwner);
|
|
||||||
|
|
||||||
|
base.Update();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Track Get(PreviewTrack previewTrack, BeatmapSetInfo beatmapSetInfo)
|
||||||
|
{
|
||||||
previewTrack.Started += () =>
|
previewTrack.Started += () =>
|
||||||
{
|
{
|
||||||
CurrentTrack?.Stop();
|
CurrentTrack?.Stop();
|
||||||
@ -51,15 +54,7 @@ namespace osu.Game.Audio
|
|||||||
audio.Track.RemoveAdjustment(AdjustableProperty.Volume, muteBindable);
|
audio.Track.RemoveAdjustment(AdjustableProperty.Volume, muteBindable);
|
||||||
};
|
};
|
||||||
|
|
||||||
return previewTrack;
|
return trackManager.Get($"https://b.ppy.sh/preview/{beatmapSetInfo?.OnlineBeatmapSetID}.mp3");
|
||||||
}
|
|
||||||
|
|
||||||
protected override void Update()
|
|
||||||
{
|
|
||||||
if (CurrentTrack?.Track.HasCompleted ?? false)
|
|
||||||
CurrentTrack.Stop();
|
|
||||||
|
|
||||||
base.Update();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
// Copyright (c) 2007-2018 ppy Pty Ltd <contact@ppy.sh>.
|
// Copyright (c) 2007-2018 ppy Pty Ltd <contact@ppy.sh>.
|
||||||
// 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.Threading.Tasks;
|
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Configuration;
|
using osu.Framework.Configuration;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
@ -103,19 +102,19 @@ namespace osu.Game.Overlays.Direct
|
|||||||
if (!Playing.Value)
|
if (!Playing.Value)
|
||||||
{
|
{
|
||||||
if (Preview == null)
|
if (Preview == null)
|
||||||
{
|
|
||||||
Task.Run(() =>
|
|
||||||
{
|
{
|
||||||
loading = true;
|
loading = true;
|
||||||
return Preview = previewTrackManager.Get(beatmapSet, parentOverlayContainer);
|
|
||||||
})
|
LoadComponentAsync(
|
||||||
.ContinueWith(t =>
|
Preview = new PreviewTrack(beatmapSet, parentOverlayContainer),
|
||||||
|
t =>
|
||||||
{
|
{
|
||||||
Preview.Started += () => Playing.Value = true;
|
Preview.Started += () => Playing.Value = true;
|
||||||
Preview.Stopped += () => Playing.Value = false;
|
Preview.Stopped += () => Playing.Value = false;
|
||||||
Preview.Start();
|
Preview.Start();
|
||||||
loading = false;
|
loading = false;
|
||||||
});
|
});
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user