Simplify code; fix queue showing non shuffled queue when enqueuing while shuffled

This commit is contained in:
Royce551 2022-03-13 18:28:55 -05:00
parent 818484e90c
commit 3a140a684f

View file

@ -21,8 +21,6 @@ namespace FRESHMusicPlayer.Pages
{
private bool taskIsRunning;
private readonly Queue<List<string>> displayqueue = new Queue<List<string>>();
private int currentIndex = 0;
private List<string> lastQueue = new List<string>();
private readonly MainWindow window;
public QueueManagement(MainWindow window)
@ -59,14 +57,9 @@ namespace FRESHMusicPlayer.Pages
async void GetResults()
{
var list = displayqueue.Dequeue();
var nextLength = 0; // length of the tracks that come after the current
int number = 1;
SetControlEnabled(false);
await Task.Run(() =>
{
if (!list.SequenceEqual(lastQueue)) // has the contents of the queue changed, or just the positions?
{ // yes; refresh list
var difference = QueueList.Items.Count - window.Player.Queue.Queue.Count;
while (difference > 0)
{
@ -94,24 +87,9 @@ namespace FRESHMusicPlayer.Pages
entry.UpdatePosition();
});
}
}
else // no; just update positions (massively faster)
{
foreach (var item in QueueList.Items)
{
if (item is QueueEntry entry)
{
Dispatcher.Invoke(() => entry.UpdatePosition());
if (entry.Index + 1 == window.Player.Queue.Position) currentIndex = entry.Index;
if (window.Player.Queue.Position < number) nextLength += entry.Length;
}
number++;
}
} // convert the items in the listbox into a list of file paths to be compared with `list`
lastQueue = Dispatcher.Invoke(() => QueueList.Items.Cast<QueueEntry>().Select(x => window.Player.Queue.Queue[x.Index]).ToList());
});
if (QueueList.Items.Count > 0) (QueueList.Items[currentIndex] as QueueEntry).BringIntoView(); // Bring current track into view
//if (QueueList.Items.Count > 0) (QueueList.Items[currentIndex] as QueueEntry).BringIntoView(); // Bring current track into view
SetControlEnabled(true);
taskIsRunning = false;
if (displayqueue.Count != 0) GetResults();