QRegExp regexp("\\[\\d+\\]\\ (.*)");
switch (_state) {
case STATE_ARTIST:
+ _artist_row_for_scroll_to = index.row();
__fill_model_album(_model, _lib->getAlbumsForArtist(data), _icons_theme);
ui->listView->setColumnWidth(0, 70);
ui->listView->scrollToTop();
ui->listLabel->setText(QString(tr("Albums by \"%1\"")).arg(_current_artist));
break;
case STATE_ALBUM:
+ _album_row_for_scroll_to = index.row();
if (regexp.indexIn(data) != -1) {
_current_album = regexp.cap(1).trimmed();
_current_tracks = _lib->getTracksForAlbum(_current_album, _current_artist);
break;
case STATE_PLAYLIST:
{
+ _playlist_row_for_scroll_to = index.row();
_current_playlist = _lib->getPlaylist(data);
_current_tracks = _current_playlist.tracks();
__fill_model_tracks(_model, _current_tracks, _icons_theme);
switch (_state) {
case STATE_ALBUM:
_view_button();
- ui->listView->scrollToTop();
+ if (_model->rowCount() != 0) {
+ ui->listView->scrollTo(_model->index(_artist_row_for_scroll_to, 1), QAbstractItemView::PositionAtCenter);
+ }
break;
case STATE_TRACK:
__fill_model_album(_model, _lib->getAlbumsForArtist(_current_artist), _icons_theme);
ui->listView->setColumnWidth(0, 70);
- ui->listView->scrollToTop();
+ if (_model->rowCount() != 0) {
+ ui->listView->scrollTo(_model->index(_album_row_for_scroll_to, 1), QAbstractItemView::PositionAtCenter);
+ }
_state = STATE_ALBUM;
ui->listLabel->setText(QString(tr("Albums by \"%1\"")).arg(_current_artist));
break;
} else {
_playlists_button();
}
- ui->listView->scrollToTop();
+ if (_model->rowCount() != 0 && !_is_dynamic) {
+ ui->listView->scrollTo(_model->index(_playlist_row_for_scroll_to, 1), QAbstractItemView::PositionAtCenter);
+ }
default:
return;
}
QModelIndex id = _model->index(_search_current_id, 1);
ui->listView->selectionModel()->clearSelection();
ui->listView->selectRow(id.row());
- ui->listView->scrollTo(id);
+ ui->listView->scrollTo(id, QAbstractItemView::PositionAtCenter);
}
void LibraryForm::prevItem() {
QModelIndex id = _model->index(_search_current_id, 1);
ui->listView->selectionModel()->clearSelection();
ui->listView->selectRow(id.row());
- ui->listView->scrollTo(id);
+ ui->listView->scrollTo(id, QAbstractItemView::PositionAtCenter);
}
void LibraryForm::cancelSearch() {
int id = _current_playlist.tracks().indexOf(track);
QModelIndex index = _model->index(id, 0);
ui->playlistView->setCurrentIndex(index);
- ui->playlistView->scrollTo(index);
+ ui->playlistView->scrollTo(index, QAbstractItemView::PositionAtCenter);
_track_renderer->setActiveRow(id);
ui->playlistView->hide();
ui->playlistView->show();
}
QModelIndex id = _model->index(_search_current_id, 1);
_track_renderer->setSearchRow(_search_current_id);
- ui->playlistView->scrollTo(id);
+ ui->playlistView->scrollTo(id, QAbstractItemView::PositionAtCenter);
ui->playlistView->hide();
ui->playlistView->show();
}
}
QModelIndex id = _model->index(_search_current_id, 1);
_track_renderer->setSearchRow(_search_current_id);
- ui->playlistView->scrollTo(id);
+ ui->playlistView->scrollTo(id, QAbstractItemView::PositionAtCenter);
ui->playlistView->hide();
ui->playlistView->show();
}
void PlayerForm::cancelSearch() {
_search_pattern = "";
_track_renderer->setSearchRow(-1);
- ui->playlistView->scrollTo(_model->index(_track_renderer->activeRow(), 1));
+ ui->playlistView->scrollTo(_model->index(_track_renderer->activeRow(), 1), QAbstractItemView::PositionAtCenter);
ui->playlistView->hide();
ui->playlistView->show();
}