Added history and improved marking of playing track.

This commit is contained in:
The Wobbler 2025-01-26 13:51:31 +01:00
parent 29f86e2196
commit 74bff6ea13
3 changed files with 48 additions and 14 deletions

View file

@ -18,6 +18,7 @@ class Player:
self.track_progress = TrackProgress(self.app) self.track_progress = TrackProgress(self.app)
self.current_playlist = Playlist(self.app, "None") self.current_playlist = Playlist(self.app, "None")
self.history = Playlist(self.app, "History")
self.playing = False self.playing = False
self.paused = False self.paused = False
@ -38,15 +39,19 @@ class Player:
def track_finished(self): def track_finished(self):
if not self.current_playlist.on_last_track(): if not self.current_playlist.on_last_track():
previous_track = self.current_playlist.current_track
self.current_sound, self.current_sound_duration = self.current_playlist.next_track() self.current_sound, self.current_sound_duration = self.current_playlist.next_track()
self.play() self.play()
self.track_progress.start() self.track_progress.start()
self.app.gui.on_track_change(previous_track, self.current_playlist.current_track)
self.history.append_track(self.current_playlist.current_track)
last_track = self.history.h_last_track()
self.app.gui.on_track_change(last_track, self.current_playlist.current_track)
if self.app.settings.clear_track_cache: if self.app.settings.clear_track_cache:
previous_track.clear_cache() last_track.clear_cache()
else: else:
self.stop() self.stop()
@ -58,6 +63,8 @@ class Player:
self.play() self.play()
self.track_progress.start() self.track_progress.start()
self.history.append_track(self.current_playlist.current_track)
self.app.gui.on_track_change(None, self.current_playlist.current_track) self.app.gui.on_track_change(None, self.current_playlist.current_track)
self.app.gui.track_control.on_playstate_update() self.app.gui.track_control.on_playstate_update()
@ -65,16 +72,26 @@ class Player:
def play_track_in_playlist(self, track_index): def play_track_in_playlist(self, track_index):
self.stop() self.stop()
previous_track = self.current_playlist.current_track if len(self.history.tracks) == 0:
self.history.append_track(self.current_playlist.current_track)
self.current_sound, self.current_sound_duration = self.current_playlist.set_track(track_index) self.current_sound, self.current_sound_duration = self.current_playlist.set_track(track_index)
self.play() self.play()
self.track_progress.start() self.track_progress.start()
self.app.gui.on_track_change(previous_track, self.current_playlist.current_track)
if self.app.settings.clear_track_cache and not previous_track == self.current_playlist.current_track: self.history.append_track(self.current_playlist.current_track)
previous_track.clear_cache()
last_track = self.history.h_last_track()
self.app.gui.on_track_change(last_track, self.current_playlist.current_track)
if (
self.app.settings.clear_track_cache and
not last_track is None and
not last_track == self.current_playlist.current_track
):
last_track.clear_cache()
def pause(self): def pause(self):
self.music_channel.pause() self.music_channel.pause()
@ -102,8 +119,6 @@ class Player:
if not self.current_playlist.on_first_track(): if not self.current_playlist.on_first_track():
self.music_channel.stop() self.music_channel.stop()
last_track = self.current_playlist.current_track
self.current_sound, self.current_sound_duration = self.current_playlist.previous_track() self.current_sound, self.current_sound_duration = self.current_playlist.previous_track()
self.track_progress.stop() self.track_progress.stop()
@ -111,7 +126,9 @@ class Player:
self.play() self.play()
self.track_progress.start() self.track_progress.start()
self.app.gui.on_track_change(last_track, self.current_playlist.current_track) self.history.append_track(self.current_playlist.current_track)
self.app.gui.on_track_change(self.history.h_last_track(), self.current_playlist.current_track)
def stop(self): def stop(self):
self.music_channel.stop() self.music_channel.stop()

View file

@ -116,3 +116,15 @@ class Playlist:
wbz.write(wbz_data) wbz.write(wbz_data)
wbz.close() wbz.close()
def append_track(self, track):
self.tracks.append(track)
if self.view:
self.view.append_track(track)
def h_last_track(self):
# get last track in history (only gets used in player.history)
if len(self.tracks) > 1:
return self.tracks[-2]

View file

@ -19,12 +19,11 @@ class PlaylistView(QTreeWidget):
playlist.view = self playlist.view = self
self.setDragDropMode(QAbstractItemView.DragDropMode.InternalMove) self.setDragDropMode(QAbstractItemView.DragDropMode.InternalMove)
#self.setAcceptDrops(True)
self.setSelectionMode(QAbstractItemView.SelectionMode.ExtendedSelection) self.setSelectionMode(QAbstractItemView.SelectionMode.ExtendedSelection)
self.setColumnCount(4) self.setColumnCount(4)
self.play_icon = QIcon.fromTheme(QIcon.ThemeIcon.MediaPlaybackStart) self.playing_mark = QIcon.fromTheme(QIcon.ThemeIcon.MediaPlaybackStart)
headers = [ headers = [
"", "",
@ -107,7 +106,7 @@ class PlaylistView(QTreeWidget):
i += 1 i += 1
if not self.topLevelItemCount() == 0: if not self.topLevelItemCount() == 0:
self.topLevelItem(0).setIcon(0, self.play_icon) self.topLevelItem(0).setIcon(0, self.playing_mark)
def on_track_activation(self, item, column): def on_track_activation(self, item, column):
if not self.app.player.current_playlist == self.playlist: if not self.app.player.current_playlist == self.playlist:
@ -117,10 +116,16 @@ class PlaylistView(QTreeWidget):
self.app.player.play_track_in_playlist(index) self.app.player.play_track_in_playlist(index)
def on_track_change(self, previous_track, track): def on_track_change(self, previous_track, track):
# remove playing mark from first track bc it may not be in the history
self.topLevelItem(0).setIcon(0, QIcon(None))
# unmark the previous track and mark the current track as playing # unmark the previous track and mark the current track as playing
if previous_track: if previous_track:
previous_track.item.setIcon(0, QIcon(None)) previous_track.item.setIcon(0, QIcon(None))
if track: if track:
track.item.setIcon(0, self.play_icon) track.item.setIcon(0, self.playing_mark)
def append_track(self, track):
TrackItem(track, self.topLevelItemCount() - 1, self)