mirror of
https://github.com/ppy/osu.git
synced 2025-01-22 07:36:05 +08:00
Schedule new track assignment after stopping current track
This commit is contained in:
parent
6805c029e7
commit
8ef9ccc39e
@ -46,12 +46,18 @@ namespace osu.Game.Audio
|
|||||||
{
|
{
|
||||||
var track = CreatePreviewTrack(beatmapSetInfo, trackStore);
|
var track = CreatePreviewTrack(beatmapSetInfo, trackStore);
|
||||||
|
|
||||||
track.Started += () => Schedule(() =>
|
track.Started += () =>
|
||||||
{
|
{
|
||||||
|
// Stopping track should not be within the below schedule since its stop event schedules a null assign to current.
|
||||||
|
// Due to that, assigning the new track to current must be scheduled after the null assign to avoid current track loss.
|
||||||
current?.Stop();
|
current?.Stop();
|
||||||
|
|
||||||
|
Schedule(() =>
|
||||||
|
{
|
||||||
current = track;
|
current = track;
|
||||||
audio.Tracks.AddAdjustment(AdjustableProperty.Volume, muteBindable);
|
audio.Tracks.AddAdjustment(AdjustableProperty.Volume, muteBindable);
|
||||||
});
|
});
|
||||||
|
};
|
||||||
|
|
||||||
track.Stopped += () => Schedule(() =>
|
track.Stopped += () => Schedule(() =>
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user