QList<Track> tracks = playlist.tracks();
int count = tracks.count();
_model->setRowCount(count);
+ _model->setColumnCount(2);
QTime time;
for (int i = 0; i < count; i++) {
TrackMetadata meta = tracks.at(i).metadata();
time.setHMS(0, meta.length()/60, meta.length() % 60);
QString t = meta.title()+"#_#"+meta.artist()+"#_#"+meta.album()+"#_#"+time.toString("mm:ss");
- _model->setItem(i, 0, new QStandardItem(t));
+ _model->setItem(i, 1, new QStandardItem(t));
}
}
_time = new QTime();
ui->setupUi(this);
if (_player->random()) {
- ui->randomButton->setIcon(QIcon(":/icons/"+_icons_theme+"/random_active.png"));
+ ui->randomButton->setIcon(QIcon(":/icons/"+_icons_theme+"/random_on.png"));
} else {
- ui->randomButton->setIcon(QIcon(":/icons/"+_icons_theme+"/random_inactive.png"));
+ ui->randomButton->setIcon(QIcon(":/icons/"+_icons_theme+"/random_off.png"));
}
- if (_player->repeat()) {
- ui->repeatButton->setIcon(QIcon(":/icons/"+_icons_theme+"/repeat_active.png"));
+ if (_player->repeat() == REPEAT_ALL) {
+ ui->repeatButton->setIcon(QIcon(":/icons/"+_icons_theme+"/repeat_all.png"));
+ } else if (_player->repeat() == REPEAT_NO){
+ ui->repeatButton->setIcon(QIcon(":/icons/"+_icons_theme+"/repeat_off.png"));
} else {
- ui->repeatButton->setIcon(QIcon(":/icons/"+_icons_theme+"/repeat_inactive.png"));
+ ui->repeatButton->setIcon(QIcon(":/icons/"+_icons_theme+"/repeat_one.png"));
}
- ui->volumeSlider->setMinimum(0);
- ui->volumeSlider->setMaximum(100);
- ui->volumeSlider->hide();
- ui->seekSlider->setEnabled(false);
+
+ _fscreen_button = new QPushButton(this);
+ _fscreen_button->setFlat(true);
+ _fscreen_button->setIcon(QIcon(":/icons/"+_icons_theme+"/fullscreen.png"));
+ _fscreen_button->setCheckable(true);
+ _fscreen_button->setMinimumSize(70, 70);
+ _fscreen_button->setMaximumSize(70, 70);
+ _fscreen_button->setSizePolicy(QSizePolicy::Fixed, QSizePolicy::Fixed);
+ _fscreen_button->hide();
+
ui->progressLayout->removeItem(ui->seekSpacer);
_tools_widget = new ToolsWidget(this);
ui->toolsLayout->insertWidget(0, _tools_widget);
_model = new QStandardItemModel(0, 2, this);
ui->playlistView->setModel(_model);
_context_menu = new QMenu(ui->playlistView);
+ QAction *clear_playlist = _context_menu->addAction("Clear playlist");
QAction *delete_action = _context_menu->addAction("Delete");
QAction *add_to_favorites = _context_menu->addAction("Add to favorites");
QAction *enqueue_action = _context_menu->addAction("Enqueue");
_track_renderer = new TrackRenderer(this);
_track_renderer->setActiveRow(-1);
_track_renderer->setSearchRow(-1);
+ ui->playlistView->setItemDelegateForColumn(1, _track_renderer);
ui->playlistView->setItemDelegateForColumn(0, _track_renderer);
_tag_resolver = new TagResolver(this);
connect(ui->libraryButton, SIGNAL(clicked()), this, SLOT(_library()));
connect(ui->viewButton, SIGNAL(clicked()), this, SLOT(_toggle_view()));
- connect(ui->playlistView, SIGNAL(clicked(QModelIndex)), this, SLOT(_process_click(QModelIndex)));
+ connect(ui->playlistView, SIGNAL(activated(QModelIndex)), this, SLOT(_process_click(QModelIndex)));
connect(ui->playpauseButton, SIGNAL(clicked()), _player, SLOT(toggle()));
connect(ui->nextButton, SIGNAL(clicked()), _player, SLOT(next()));
connect(ui->stopButton, SIGNAL(clicked()), _player, SLOT(stop()));
connect(ui->randomButton, SIGNAL(clicked()), this, SLOT(_toggle_random()));
connect(ui->repeatButton, SIGNAL(clicked()), this, SLOT(_toggle_repeat()));
connect(ui->seekSlider, SIGNAL(sliderMoved(int)), _player, SLOT(seek(int)));
- connect(ui->volumeSlider, SIGNAL(sliderMoved(int)), _player, SLOT(setVolume(int)));
connect(ui->playlistView, SIGNAL(customContextMenuRequested(QPoint)), this, SLOT(_custom_context_menu_requested(QPoint)));
+ connect(clear_playlist, SIGNAL(triggered()), this, SIGNAL(clearPlaylist()));
connect(delete_action, SIGNAL(triggered()), this, SLOT(_delete_track()));
connect(enqueue_action, SIGNAL(triggered()), this, SLOT(_enqueue_track()));
connect(add_to_favorites, SIGNAL(triggered()), this, SLOT(_add_to_favorites()));
connect(_player, SIGNAL(stateChanged(PlayerState)), this, SLOT(_state_changed(PlayerState)));
connect(_player, SIGNAL(trackDone(Track)), _lib, SLOT(updateTrackCount(Track)));
connect(_tag_resolver, SIGNAL(decoded(Track)), this, SLOT(_track_decoded(Track)));
- connect(ui->volumeButton, SIGNAL(clicked()), this, SLOT(_toggle_volume()));
+ connect(ui->dirButton, SIGNAL(clicked()), this, SLOT(_dirview()));
connect(ui->moreButton, SIGNAL(clicked()), this, SLOT(_tools_widget_toggle()));
connect(_tools_widget, SIGNAL(search(QString)), this, SLOT(search(QString)));
connect(_tools_widget, SIGNAL(nextSearch()), this, SLOT(nextItem()));
connect(_tools_widget, SIGNAL(prevSearch()), this, SLOT(prevItem()));
connect(_tools_widget, SIGNAL(toggleFullscreen(bool)), this, SIGNAL(fullscreen(bool)));
+ connect(_tools_widget, SIGNAL(toggleFullscreen(bool)), _fscreen_button, SLOT(setChecked(bool)));
+ connect(_fscreen_button, SIGNAL(clicked(bool)), this, SIGNAL(fullscreen(bool)));
+ connect(_fscreen_button, SIGNAL(clicked(bool)), _tools_widget, SLOT(setFullscreenState(bool)));
ui->viewButton->setIcon(QIcon(":/icons/"+_icons_theme+"/playback.png"));
_top_gradient = ui->topWidget->styleSheet();
_bottom_gradient = ui->bottomWidget->styleSheet();
+ ui->countdownWidget->hide();
// dbus
_dbusadaptor = new DBusAdaptop(_player);
_current_playlist = _lib->getCurrentPlaylist();
_player->setPlaylist(_current_playlist);
__fill_list(_model, _current_playlist);
+ ui->playlistView->setColumnWidth(0, 50);
}
}
index = (!index % 2);
if (index) {
ui->viewButton->setIcon(QIcon(":/icons/"+_icons_theme+"/playlist.png"));
- ui->moreButton->setEnabled(false);
+ ui->moreButton->hide();
+ _fscreen_button->show();
} else {
ui->viewButton->setIcon(QIcon(":/icons/"+_icons_theme+"/playback.png"));
- ui->moreButton->setEnabled(true);
+ ui->moreButton->show();
+ _fscreen_button->hide();
}
ui->stackedWidget->setCurrentIndex(index);
}
void PlayerForm::_process_click(QModelIndex index) {
- int id = index.row();
- _player->stop();
- _player->setTrackId(id);
- _player->play();
- _track_renderer->setActiveRow(id);
- ui->playlistView->hide();
- ui->playlistView->show();
+ if (index.column() == 1) {
+ int id = index.row();
+ _player->stop();
+ _player->setTrackId(id);
+ _player->play();
+ _track_renderer->setActiveRow(id);
+ } else {
+ _custom_context_menu_requested(ui->playlistView->rect().center());
+ }
}
void PlayerForm::_track_changed(Track track) {
void PlayerForm::_delete_track() {
QList<QModelIndex> idx = ui->playlistView->selectionModel()->selectedIndexes();
+ if (idx.isEmpty())
+ return;
int id = idx.first().row();
int aid = _track_renderer->activeRow();
if (aid > id) {
void PlayerForm::_enqueue_track() {
QList<QModelIndex> idx = ui->playlistView->selectionModel()->selectedIndexes();
+ if (idx.isEmpty())
+ return;
int id = idx.first().row();
_player->enqueue(id);
}
void PlayerForm::_add_to_favorites() {
QList<QModelIndex> idx = ui->playlistView->selectionModel()->selectedIndexes();
+ if (idx.isEmpty())
+ return;
int id = idx.first().row();
_lib->addToFavorites(_current_playlist.tracks().at(id));
}
void PlayerForm::_toggle_random() {
_player->toggleRandom();
if (_player->random()) {
- ui->randomButton->setIcon(QIcon(":/icons/"+_icons_theme+"/random_active.png"));
+ ui->randomButton->setIcon(QIcon(":/icons/"+_icons_theme+"/random_on.png"));
} else {
- ui->randomButton->setIcon(QIcon(":/icons/"+_icons_theme+"/random_inactive.png"));
+ ui->randomButton->setIcon(QIcon(":/icons/"+_icons_theme+"/random_off.png"));
}
}
void PlayerForm::_toggle_repeat() {
_player->toggleRepeat();
- if (_player->repeat()) {
- ui->repeatButton->setIcon(QIcon(":/icons/"+_icons_theme+"/repeat_active.png"));
+ if (_player->repeat() == REPEAT_ALL) {
+ ui->repeatButton->setIcon(QIcon(":/icons/"+_icons_theme+"/repeat_all.png"));
+ } else if (_player->repeat() == REPEAT_NO){
+ ui->repeatButton->setIcon(QIcon(":/icons/"+_icons_theme+"/repeat_off.png"));
} else {
- ui->repeatButton->setIcon(QIcon(":/icons/"+_icons_theme+"/repeat_inactive.png"));
+ ui->repeatButton->setIcon(QIcon(":/icons/"+_icons_theme+"/repeat_one.png"));
}
}
}
void PlayerForm::nextItem() {
- QString data = _model->index(_search_current_id, 0).data().toString();
+ QString data = _model->index(_search_current_id, 1).data().toString();
for (int i = _search_current_id+1; i < _model->rowCount(); i++) {
- data = _model->index(i, 0).data().toString();
+ data = _model->index(i, 1).data().toString();
if (data.contains(_search_pattern, Qt::CaseInsensitive)) {
_search_current_id = i;
break;
}
}
- QModelIndex id = _model->index(_search_current_id, 0);
+ QModelIndex id = _model->index(_search_current_id, 1);
_track_renderer->setSearchRow(_search_current_id);
ui->playlistView->scrollTo(id);
ui->playlistView->hide();
}
void PlayerForm::prevItem() {
- QString data = _model->index(_search_current_id, 0).data().toString();
+ QString data = _model->index(_search_current_id, 1).data().toString();
for (int i = _search_current_id-1; i >= 0; i--) {
- data = _model->index(i, 0).data().toString();
+ data = _model->index(i, 1).data().toString();
if (data.contains(_search_pattern, Qt::CaseInsensitive)) {
_search_current_id = i;
break;
}
}
- QModelIndex id = _model->index(_search_current_id, 0);
+ QModelIndex id = _model->index(_search_current_id, 1);
_track_renderer->setSearchRow(_search_current_id);
ui->playlistView->scrollTo(id);
ui->playlistView->hide();
void PlayerForm::cancelSearch() {
_search_pattern = "";
_track_renderer->setSearchRow(-1);
- ui->playlistView->scrollTo(_model->index(_track_renderer->activeRow(), 0));
+ ui->playlistView->scrollTo(_model->index(_track_renderer->activeRow(), 1));
ui->playlistView->hide();
ui->playlistView->show();
}
void PlayerForm::_track_decoded(Track track) {
_current_playlist.addTrack(track);
__fill_list(_model, _current_playlist);
+ ui->playlistView->setColumnWidth(0, 50);
_lib->saveCurrentPlaylist(_current_playlist);
_player->setPlaylist(_current_playlist);
}
void PlayerForm::_add_to_playlists() {
QList<QModelIndex> idx = ui->playlistView->selectionModel()->selectedIndexes();
+ if (idx.isEmpty())
+ return;
int id = idx.first().row();
QList<QString> names = _lib->getPlaylistsNames();
void PlayerForm::_edit_tags() {
QList<QModelIndex> idx = ui->playlistView->selectionModel()->selectedIndexes();
+ if (idx.isEmpty())
+ return;
Track track = _current_playlist.tracks().at(idx.first().row());
EditTagsDialog dialog(this);
track.setMetadata(dialog.meta());
_lib->updateTrackMetadata(track);
reload(true);
+ emit refreshLibrary();
}
}
_player->stop();
}
-void PlayerForm::_toggle_volume() {
- if (ui->volumeSlider->isVisible()) {
- ui->volumeSlider->hide();
- } else {
- ui->volumeSlider->show();
- ui->volumeSlider->setValue(_player->volume());
- }
-}
-
-void PlayerForm::_volume_changed() {
- int value = ui->volumeSlider->value();
- _player->setVolume(value);
+void PlayerForm::_dirview() {
+ emit dirView();
}
void PlayerForm::landscapeMode() {
ui->bhorizontalLayout->addWidget(ui->stopButton);
ui->bhorizontalLayout->addItem(ui->chorizontalSpacer_3);
ui->bhorizontalLayout->addWidget(ui->moreButton);
+ ui->bhorizontalLayout->addWidget(_fscreen_button);
ui->bhorizontalLayout->addItem(ui->chorizontalSpacer_4);
- ui->bhorizontalLayout->addWidget(ui->volumeButton);
+ ui->bhorizontalLayout->addWidget(ui->dirButton);
if (_tools_widget->isVisible()) {
ui->moreButton->setIcon(QIcon(":/icons/"+_icons_theme+"/more.png"));
ui->topWidget->layout()->addWidget(ui->nextButton);
ui->topWidget->layout()->addItem(ui->thorizontalSpacer_3);
ui->topWidget->layout()->addWidget(ui->moreButton);
+ ui->topWidget->layout()->addWidget(_fscreen_button);
ui->bhorizontalLayout->removeItem(ui->chorizontalSpacer_0);
ui->bhorizontalLayout->removeItem(ui->chorizontalSpacer_1);
ui->bhorizontalLayout->removeItem(ui->chorizontalSpacer_2);
ui->bottomWidget->layout()->addItem(ui->bhorizontalSpacer_2);
ui->bottomWidget->layout()->addWidget(ui->repeatButton);
ui->bottomWidget->layout()->addItem(ui->bhorizontalSpacer_3);
- ui->bottomWidget->layout()->addWidget(ui->volumeButton);
+ ui->bottomWidget->layout()->addWidget(ui->dirButton);
if (_tools_widget->isVisible()) {
ui->moreButton->setIcon(QIcon(":/icons/"+_icons_theme+"/unmore.png"));
Config config;
_icons_theme = config.getValue("ui/iconstheme").toString();
_tools_widget->updateIcons();
+ _track_renderer->updateIcons();
ui->libraryButton->setIcon(QIcon(":/icons/"+_icons_theme+"/library.png"));
if (_tools_widget->isVisible()) {
- ui->moreButton->setIcon(QIcon(landscape ? ":/icons/"+_icons_theme+"/unmore.png" : ":/icons/"+_icons_theme+"/more.png"));
+ ui->moreButton->setIcon(QIcon(landscape ? ":/icons/" + _icons_theme + "/unmore.png" : ":/icons/" + _icons_theme + "/more.png"));
} else {
- ui->moreButton->setIcon(QIcon(landscape ? ":/icons/"+_icons_theme+"/more.png" : ":/icons/"+_icons_theme+"/unmore.png"));
+ ui->moreButton->setIcon(QIcon(landscape ? ":/icons/" + _icons_theme + "/more.png" : ":/icons/" + _icons_theme + "/unmore.png"));
}
ui->nextButton->setIcon(QIcon(":/icons/"+_icons_theme+"/next.png"));
ui->stopButton->setIcon(QIcon(":/icons/"+_icons_theme+"/stop.png"));
ui->prevButton->setIcon(QIcon(":/icons/"+_icons_theme+"/prev.png"));
- ui->volumeButton->setIcon(QIcon(":/icons/"+_icons_theme+"/volume.png"));
+ ui->dirButton->setIcon(QIcon(":/icons/"+_icons_theme+"/directory.png"));
if (_player->state() == PLAYER_PLAYING) {
ui->playpauseButton->setIcon(QIcon(":/icons/"+_icons_theme+"/pause.png"));
} else {
} else {
ui->viewButton->setIcon(QIcon(":/icons/"+_icons_theme+"/playback.png"));
}
- if (_player->repeat()) {
- ui->repeatButton->setIcon(QIcon(":/icons/"+_icons_theme+"/repeat_active.png"));
+ if (_player->repeat() == REPEAT_ALL) {
+ ui->repeatButton->setIcon(QIcon(":/icons/"+_icons_theme+"/repeat_all.png"));
+ } else if (_player->repeat() == REPEAT_NO){
+ ui->repeatButton->setIcon(QIcon(":/icons/"+_icons_theme+"/repeat_off.png"));
} else {
- ui->repeatButton->setIcon(QIcon(":/icons/"+_icons_theme+"/repeat_inactive.png"));
+ ui->repeatButton->setIcon(QIcon(":/icons/"+_icons_theme+"/repeat_one.png"));
}
if (_player->random()) {
- ui->randomButton->setIcon(QIcon(":/icons/"+_icons_theme+"/random_active.png"));
+ ui->randomButton->setIcon(QIcon(":/icons/"+_icons_theme+"/random_on.png"));
} else {
- ui->randomButton->setIcon(QIcon(":/icons/"+_icons_theme+"/random_inactive.png"));
+ ui->randomButton->setIcon(QIcon(":/icons/"+_icons_theme+"/random_off.png"));
}
}
ui->bottomWidget->setStyleSheet("");
}
}
+
+void PlayerForm::play(Track track) {
+ reload(true);
+ int id = _current_playlist.tracks().indexOf(track);
+ if (id >= 0) {
+ _player->setTrackId(id);
+ _player->play();
+ } else {
+ _current_playlist.addTrack(track);
+ _lib->saveCurrentPlaylist(_current_playlist);
+ reload(true);
+ _player->setTrackId(_current_playlist.tracks().count()-1);
+ _player->play();
+ }
+}
+
+void PlayerForm::showCountdown(QString text) {
+ ui->countdownWidget->show();
+ ui->timeLabel->setText(text);
+}
+
+void PlayerForm::hideCountdown() {
+ ui->countdownWidget->hide();
+}