1
0
mirror of https://github.com/clementine-player/Clementine synced 2025-01-18 12:32:09 +01:00

Make sure the playlist gets reshuffled when the user manually changes track. Fixes issue #137

This commit is contained in:
David Sansome 2010-03-30 00:51:00 +00:00
parent ef9780b44e
commit c0da64c6a2
3 changed files with 13 additions and 11 deletions

View File

@ -365,7 +365,7 @@ void MainWindow::QueueFiles(const QList<QUrl>& urls) {
QModelIndex playlist_index = playlist_->InsertPaths(urls);
if (playlist_index.isValid() && player_->GetState() != Engine::Playing)
player_->PlayAt(playlist_index.row());
player_->PlayAt(playlist_index.row(), true);
}
void MainWindow::ReportError(const QString& message) {
@ -442,7 +442,7 @@ void MainWindow::PlayIndex(const QModelIndex& index) {
if (!index.isValid())
return;
player_->PlayAt(index.row());
player_->PlayAt(index.row(), true);
}
void MainWindow::LibraryDoubleClick(const QModelIndex& index) {
@ -451,7 +451,7 @@ void MainWindow::LibraryDoubleClick(const QModelIndex& index) {
library_sort_model_->mapToSource(index)));
if (first_song.isValid() && player_->GetState() != Engine::Playing)
player_->PlayAt(first_song.row());
player_->PlayAt(first_song.row(), true);
}
void MainWindow::VolumeWheelEvent(int delta) {
@ -563,7 +563,7 @@ void MainWindow::InsertRadioItem(RadioItem* item) {
QList<RadioItem*>() << item);
if (first_song.isValid() && player_->GetState() != Engine::Playing)
player_->PlayAt(first_song.row());
player_->PlayAt(first_song.row(), true);
}
void MainWindow::PlaylistRightClick(const QPoint& global_pos, const QModelIndex& index) {
@ -632,7 +632,7 @@ void MainWindow::PlaylistPlay() {
if (playlist_->current_index() == playlist_menu_index_.row()) {
player_->PlayPause();
} else {
player_->PlayAt(playlist_menu_index_.row());
player_->PlayAt(playlist_menu_index_.row(), true);
}
}

View File

@ -133,7 +133,7 @@ void Player::NextItem() {
return;
}
PlayAt(i);
PlayAt(i, false);
}
void Player::TrackEnded() {
@ -173,7 +173,7 @@ void Player::PlayPause() {
break;
i = 0;
}
PlayAt(i);
PlayAt(i, false);
break;
}
}
@ -196,7 +196,7 @@ void Player::Previous() {
return;
}
PlayAt(i);
PlayAt(i, false);
}
void Player::EngineStateChanged(Engine::State state) {
@ -225,10 +225,12 @@ Engine::State Player::GetState() const {
return engine_->state();
}
void Player::PlayAt(int index) {
void Player::PlayAt(int index, bool manual_change) {
if (!init_engine_.isFinished())
return;
if (manual_change)
playlist_->set_current_index(-1); // to reshuffle
playlist_->set_current_index(index);
PlaylistItem* item = playlist_->item_at(index);
@ -507,7 +509,7 @@ void Player::SetRandom(bool enable) {
}
void Player::PlayTrack(int index) {
PlayAt(index);
PlayAt(index, true);
}
void Player::PlaylistChanged() {

View File

@ -80,7 +80,7 @@ class Player : public QObject {
public slots:
void ReloadSettings();
void PlayAt(int index);
void PlayAt(int index, bool manual_change);
void PlayPause();
void NextItem();
void Previous();