time.setHMS(0, meta.length()/60, meta.length() % 60);
QString t = meta.title()+"#_#"+meta.artist()+"#_#"+meta.album()+"#_#"+time.toString("mm:ss");
_model->setItem(i, 1, new QStandardItem(t));
- _model->setItem(i, 0, new QStandardItem(""));
}
}
connect(ui->libraryButton, SIGNAL(clicked()), this, SLOT(_library()));
connect(ui->viewButton, SIGNAL(clicked()), this, SLOT(_toggle_view()));
connect(ui->playlistView, SIGNAL(activated(QModelIndex)), this, SLOT(_process_click(QModelIndex)));
- connect(ui->playlistView, SIGNAL(doubleClicked(QModelIndex)), this, SLOT(_process_dbl_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()));
} else {
_custom_context_menu_requested(ui->playlistView->rect().center());
}
-// ui->playlistView->hide();
-// ui->playlistView->show();
}
void PlayerForm::_track_changed(Track track) {
}
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();
}
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"));
_player->play();
}
}
-
-void PlayerForm::_process_dbl_click(QModelIndex) {
- _custom_context_menu_requested(ui->playlistView->rect().center());
-}
{
Config config;
_icons_theme = config.getValue("ui/iconstheme").toString();
+ _apen = QPen(QColor::fromRgb(255, 255, 255, 128));
+ _spen = QPen(QColor::fromRgb(100, 150, 220));
+ _sspen = QPen(QColor::fromRgb(100, 220, 150));
+
+}
+
+void TrackRenderer::updateIcons() {
+ Config config;
+ _icons_theme = config.getValue("ui/iconstheme").toString();
}
void TrackRenderer::paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const {
if (index.column() == 0) {
int x1, y1, x2, y2;
option.rect.getCoords(&x1, &y1, &x2, &y2);
- painter->drawImage(x1, y1 + 5, QImage(":/icons/"+_icons_theme+"/more_l.png"));
+ QImage image(":/icons/"+_icons_theme+"/arrow_r.png");
+ x1 += (x2 - x1 - image.width())/2;
+ y1 += (y2 - y1 - image.width())/2;
+ painter->drawImage(x1, y1, image);
} else {
QString value = index.data().toString();
QStringList meta = value.split("#_#");
option.rect.getCoords(&x1, &y1, &x2, &y2);
QPen pen = painter->pen();
- QPen npen (QColor::fromRgb(80, 130, 255, 50));
- QPen apen (QColor::fromRgb(255, 255, 255, 128));
- QPen spen (QColor::fromRgb(100, 150, 220));
- QPen sspen (QColor::fromRgb(100, 220, 150));
-
f.setBold(false);
- painter->setPen(npen);
- painter->drawLine(x1, y1, x2, y1);
if (index.row() == _search_row) {
f.setBold(true);
- painter->setPen(sspen);
+ painter->setPen(_sspen);
} else if (index.row() == _active_row) {
f.setBold(true);
- painter->setPen(spen);
+ painter->setPen(_spen);
} else {
painter->setPen(pen);
}
fp.setBold(false);
fp.setPointSize(f.pointSize()*3/4);
painter->setFont(fp);
- painter->setPen(apen);
+ painter->setPen(_apen);
painter->drawText(x1+10, y1 + 3*(y2-y1)/5, (x2-x1)-100, 2*fp.pointSize(), Qt::AlignAbsolute, QString("%1 (%2)").arg(meta[2]).arg(meta[1]));
painter->drawText(x2-60, y1 + 3*(y2-y1)/5, 55, 2*fp.pointSize(), Qt::AlignAbsolute, QString("%1").arg(meta[3]));
- painter->setPen(npen);
- painter->drawLine(x1, y2, x2, y2);
painter->setFont(f);
painter->setPen(pen);
}