aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authortrialuser02 <trialuser02@90c681e8-e032-0410-971d-27865f9a5e38>2012-02-20 20:19:59 +0000
committertrialuser02 <trialuser02@90c681e8-e032-0410-971d-27865f9a5e38>2012-02-20 20:19:59 +0000
commitfc99b46d57b13e22c70f8acc1aaf297bab25f880 (patch)
treea1a4bedd32a1f0e3cca388e232549da4df70cab7
parent3d6d597ffbe16422d817e06cb83463210769d5f4 (diff)
downloadqmmp-fc99b46d57b13e22c70f8acc1aaf297bab25f880.tar.gz
qmmp-fc99b46d57b13e22c70f8acc1aaf297bab25f880.tar.bz2
qmmp-fc99b46d57b13e22c70f8acc1aaf297bab25f880.zip
added 'New Playlist' button (Closes issue 382)
git-svn-id: http://svn.code.sf.net/p/qmmp-dev/code/trunk/qmmp@2625 90c681e8-e032-0410-971d-27865f9a5e38
-rw-r--r--src/plugins/Ui/skinned/forms/skinnedsettings.ui15
-rw-r--r--src/plugins/Ui/skinned/playlistselector.cpp163
-rw-r--r--src/plugins/Ui/skinned/playlistselector.h22
-rw-r--r--src/plugins/Ui/skinned/skinnedsettings.cpp2
4 files changed, 143 insertions, 59 deletions
diff --git a/src/plugins/Ui/skinned/forms/skinnedsettings.ui b/src/plugins/Ui/skinned/forms/skinnedsettings.ui
index 16e6e186c..800c4a97e 100644
--- a/src/plugins/Ui/skinned/forms/skinnedsettings.ui
+++ b/src/plugins/Ui/skinned/forms/skinnedsettings.ui
@@ -13,7 +13,7 @@
<property name="windowTitle">
<string notr="true">Form</string>
</property>
- <layout class="QHBoxLayout" name="horizontalLayout">
+ <layout class="QVBoxLayout" name="verticalLayout_4">
<item>
<widget class="QTabWidget" name="tabWidget">
<property name="currentIndex">
@@ -388,14 +388,14 @@
</property>
</widget>
</item>
- <item row="6" column="0">
+ <item row="8" column="0">
<widget class="QCheckBox" name="popupCheckBox">
<property name="text">
<string>Show popup information</string>
</property>
</widget>
</item>
- <item row="7" column="0">
+ <item row="9" column="0">
<layout class="QHBoxLayout" name="horizontalLayout_3">
<item>
<widget class="QPushButton" name="popupTemplateButton">
@@ -422,7 +422,7 @@
</item>
</layout>
</item>
- <item row="5" column="0">
+ <item row="6" column="0">
<layout class="QHBoxLayout" name="horizontalLayout_2">
<item>
<widget class="QLabel" name="label_4">
@@ -459,6 +459,13 @@
</item>
</layout>
</item>
+ <item row="5" column="0">
+ <widget class="QCheckBox" name="showNewPLCheckBox">
+ <property name="text">
+ <string>Show 'New Playlist' button</string>
+ </property>
+ </widget>
+ </item>
</layout>
</widget>
</item>
diff --git a/src/plugins/Ui/skinned/playlistselector.cpp b/src/plugins/Ui/skinned/playlistselector.cpp
index 5e0a79ef0..99ef7de7c 100644
--- a/src/plugins/Ui/skinned/playlistselector.cpp
+++ b/src/plugins/Ui/skinned/playlistselector.cpp
@@ -34,20 +34,18 @@
PlayListSelector::PlayListSelector(PlayListManager *manager, QWidget *parent) : QWidget(parent)
{
- m_update = false;
m_scrollable = false;
- m_left_pressed = false;
- m_right_pressed = false;
m_moving = false;
m_offset = 0;
m_offset_max = 0;
+ m_metrics = 0;
+ m_pressed_button = BUTTON_UNKNOWN;
m_skin = Skin::instance();
m_pl_manager = manager;
connect(m_pl_manager, SIGNAL(playListsChanged()), SLOT(updateTabs()));
connect(m_skin, SIGNAL(skinChanged()), this, SLOT(updateSkin()));
loadColors();
readSettings();
- updateTabs();
m_menu = new QMenu(this);
m_menu->addAction(tr("&Load"), parent, SIGNAL (loadPlaylist()));
m_menu->addAction(tr("&Save As..."), parent, SIGNAL (savePlaylist()));
@@ -57,33 +55,36 @@ PlayListSelector::PlayListSelector(PlayListManager *manager, QWidget *parent) :
}
PlayListSelector::~PlayListSelector()
-{}
+{
+ if (m_metrics)
+ delete m_metrics;
+ m_metrics = 0;
+}
void PlayListSelector::readSettings()
{
QSettings settings(Qmmp::configFile(), QSettings::IniFormat);
m_font.fromString(settings.value("Skinned/pl_font", QApplication::font().toString()).toString());
- if (m_update)
+ if (m_metrics)
{
delete m_metrics;
- m_metrics = new QFontMetrics(m_font);
- updateTabs();
- }
- else
- {
- m_update = true;
+ m_metrics = 0;
}
m_metrics = new QFontMetrics(m_font);
m_pl_separator = settings.value("Skinned/pl_separator", "|").toString();
+ m_show_new_pl_button = settings.value("Skinned/pl_show_create_button", false).toBool();
+ m_pl_button = "[+]";
m_pl_separator.append(" ");
m_pl_separator.prepend(" ");
resize(width(), m_metrics->height () +1);
drawButtons();
+ updateTabs();
}
void PlayListSelector::updateTabs()
{
m_rects.clear();
+ m_extra_rects.clear();
QRect rect;
foreach(QString text, m_pl_manager->playListNames())
{
@@ -96,6 +97,16 @@ void PlayListSelector::updateTabs()
rect.setHeight(m_metrics->ascent ());
m_rects.append(rect);
}
+
+ if(m_show_new_pl_button)
+ {
+ rect.setX(m_rects.last().x() + m_rects.last().width() + m_metrics->width(" "));
+ rect.setY(0);
+ rect.setWidth(m_metrics->width(m_pl_button));
+ rect.setHeight(m_metrics->ascent ());
+ m_extra_rects.append(rect);
+ }
+
updateScrollers();
update();
}
@@ -160,6 +171,14 @@ void PlayListSelector::paintEvent(QPaintEvent *)
}
}
+
+ for(int i = 0; i < m_extra_rects.size(); ++i)
+ {
+ painter.setPen(m_pressed_button == BUTTON_NEW_PL ? m_current : m_normal);
+ painter.drawText(m_extra_rects[i].x() - m_offset, m_metrics->ascent(), m_pl_button);
+ }
+
+
if(m_moving)
{
painter.setBrush(QBrush(m_selected_bg));
@@ -183,38 +202,27 @@ void PlayListSelector::paintEvent(QPaintEvent *)
void PlayListSelector::mousePressEvent (QMouseEvent *e)
{
- if(m_scrollable && e->x() > width() - 20)
- {
- m_offset += m_rects.at(lastVisible()).right() - m_offset - width() + 42;
- m_offset = qMin(m_offset, m_offset_max);
- m_right_pressed = true;
- drawButtons();
- update();
- return;
- }
- if(m_scrollable && (width() - 40 < e->x()) && (e->x() <= width() - 20))
+ m_pressed_button = findButton(e->pos());
+ if(m_pressed_button != BUTTON_UNKNOWN)
{
- m_offset -= m_rects.at(firstVisible()).x() + m_offset;
- m_offset = qMax(0, m_offset);
- m_left_pressed = true;
drawButtons();
update();
return;
}
- QPoint pp = e->pos();
- pp.rx() += m_offset;
bool selected = false;
- for(int i = 0; i < m_rects.count(); ++i)
+ int index = findPlayList(e->pos());
+ if(index != -1)
{
- if(m_rects.at(i).contains(pp))
- {
- selected = true;
- m_pl_manager->selectPlayList(i);
- break;
- }
+ selected = true;
+ m_pl_manager->selectPlayList(index);
}
+
update();
+
+ QPoint pp = e->pos();
+ pp.rx() += m_offset;
+
if(e->button() == Qt::RightButton)
m_menu->exec(e->globalPos());
else if(e->button() == Qt::MidButton && selected)
@@ -226,14 +234,32 @@ void PlayListSelector::mousePressEvent (QMouseEvent *e)
m_press_offset = pp.x() - m_rects.at(m_pl_manager->selectedPlayListIndex()).x();
QWidget::mousePressEvent(e);
}
-
}
void PlayListSelector::mouseReleaseEvent (QMouseEvent *e)
{
- m_left_pressed = false;
- m_right_pressed = false;
m_moving = false;
+ int released_button = findButton(e->pos());
+ if(released_button == m_pressed_button)
+ {
+ switch(released_button)
+ {
+ case BUTTON_NEW_PL:
+ m_pl_manager->createPlayList();
+ break;
+ case BUTTON_LEFT:
+ m_offset -= m_offset - firstVisible().x() + 9 + 2;
+ m_offset = qMax(0, m_offset);
+ break;
+ case BUTTON_RIGHT:
+ m_offset += lastVisible().right() - m_offset - width() + 42;
+ m_offset = qMin(m_offset, m_offset_max);
+ break;
+ default:
+ ;
+ }
+ }
+ m_pressed_button = BUTTON_UNKNOWN;
drawButtons();
update();
QWidget::mouseReleaseEvent(e);
@@ -302,16 +328,16 @@ void PlayListSelector::drawButtons()
m_pixmap.fill(m_normal_bg);
QPainter painter(&m_pixmap);
painter.setRenderHint(QPainter::Antialiasing, true);
- painter.setPen(m_left_pressed ? m_current : m_normal);
- painter.setBrush(QBrush(m_left_pressed ? m_current : m_normal));
+ painter.setPen(m_pressed_button == BUTTON_LEFT ? m_current : m_normal);
+ painter.setBrush(QBrush(m_pressed_button == BUTTON_LEFT ? m_current : m_normal));
QPoint points[3] = {
QPoint(m_pixmap.width() - 25, height()/2 - 5),
QPoint(m_pixmap.width() - 35, height()/2-1),
QPoint(m_pixmap.width() - 25, height()/2 + 3),
};
painter.drawPolygon(points, 3);
- painter.setPen(m_right_pressed ? m_current : m_normal);
- painter.setBrush(QBrush(m_right_pressed ? m_current : m_normal));
+ painter.setPen(m_pressed_button == BUTTON_RIGHT ? m_current : m_normal);
+ painter.setBrush(QBrush(m_pressed_button == BUTTON_RIGHT ? m_current : m_normal));
QPoint points2[3] = {
QPoint(m_pixmap.width() - 20, height()/2 - 5),
QPoint(m_pixmap.width() - 10, height()/2-1),
@@ -322,10 +348,12 @@ void PlayListSelector::drawButtons()
void PlayListSelector::updateScrollers()
{
- m_scrollable = m_rects.last().right() > width();
+ int last_x = m_extra_rects.isEmpty() ? m_rects.last().right() : m_extra_rects.last().right();
+
+ m_scrollable = last_x > width();
if(m_scrollable)
{
- m_offset_max = m_rects.last().right() - width() + 42;
+ m_offset_max = last_x - width() + 42;
m_offset = qMin(m_offset, m_offset_max);
}
else
@@ -335,22 +363,57 @@ void PlayListSelector::updateScrollers()
}
}
-int PlayListSelector::firstVisible()
+QRect PlayListSelector::firstVisible()
{
for(int i = 0; i < m_rects.size(); ++i)
{
- if(m_rects.at(i).right() - m_offset + m_metrics->width(" - ") + 2 >= 9)
- return i;
+ if(m_rects.at(i).right() + m_metrics->width(m_pl_separator) >= 9 + m_offset)
+ return m_rects.at(i);
}
- return 0;
+ return m_rects.at(0);
}
-int PlayListSelector::lastVisible()
+QRect PlayListSelector::lastVisible()
{
+ for(int i = m_extra_rects.size() - 1; i >= 0; --i)
+ {
+ if(m_extra_rects.at(i).x() - m_offset - m_metrics->width(" ") - 2 <= width() - 40)
+ return m_extra_rects.at(i);
+ }
for(int i = m_rects.size() - 1; i >= 0; --i)
{
- if(m_rects.at(i).x() - m_offset - m_metrics->width(" - ") - 2 <= width() - 40)
+ if(m_rects.at(i).x() - m_offset - m_metrics->width(m_pl_separator) - 2 <= width() - 40)
+ return m_rects.at(i);
+ }
+ return m_extra_rects.isEmpty() ? m_rects.last() : m_extra_rects.last();
+}
+
+int PlayListSelector::findPlayList(QPoint pos)
+{
+ pos.rx() += m_offset;
+ for(int i = 0; i < m_rects.count(); ++i)
+ {
+ if(m_rects.at(i).contains(pos))
return i;
}
- return m_rects.count() - 1;
+ return -1;
+}
+
+int PlayListSelector::findButton(QPoint pos)
+{
+ if(m_scrollable)
+ {
+ if(pos.x() > width() - 20)
+ return BUTTON_RIGHT;
+ else if ((width() - 40 < pos.x()) && (pos.x() <= width() - 20))
+ return BUTTON_LEFT;
+ }
+
+ pos.rx() += m_offset;
+ for(int i = 0; i < m_extra_rects.count(); ++i)
+ {
+ if(m_extra_rects.at(i).contains(pos))
+ return BUTTON_NEW_PL;
+ }
+ return BUTTON_UNKNOWN;
}
diff --git a/src/plugins/Ui/skinned/playlistselector.h b/src/plugins/Ui/skinned/playlistselector.h
index 2dbef24f7..0d585d23a 100644
--- a/src/plugins/Ui/skinned/playlistselector.h
+++ b/src/plugins/Ui/skinned/playlistselector.h
@@ -60,23 +60,35 @@ private:
void loadColors();
void drawButtons();
void updateScrollers();
- int firstVisible();
- int lastVisible();
+ QRect firstVisible();
+ QRect lastVisible();
+ int findPlayList(QPoint pos);
+ int findButton(QPoint pos);
PlayListManager *m_pl_manager;
QFontMetrics *m_metrics;
QFont m_font;
QMenu *m_menu;
- bool m_update;
bool m_scrollable;
QList <QRect> m_rects;
+ QList <QRect> m_extra_rects;
Skin *m_skin;
QColor m_normal, m_current, m_normal_bg, m_selected_bg;
QPixmap m_pixmap;
- bool m_showButtons;
+ bool m_show_new_pl_button;
int m_offset, m_offset_max, m_press_offset;
- bool m_moving, m_left_pressed, m_right_pressed;
+ bool m_moving;
QPoint m_mouse_pos;
QString m_pl_separator;
+ QString m_pl_button;
+ int m_pressed_button;
+
+ enum BUTTON
+ {
+ BUTTON_UNKNOWN = -1,
+ BUTTON_NEW_PL,
+ BUTTON_LEFT,
+ BUTTON_RIGHT
+ };
};
#endif // PLAYLISTSELECTOR_H
diff --git a/src/plugins/Ui/skinned/skinnedsettings.cpp b/src/plugins/Ui/skinned/skinnedsettings.cpp
index a2e92c133..d9c172f0f 100644
--- a/src/plugins/Ui/skinned/skinnedsettings.cpp
+++ b/src/plugins/Ui/skinned/skinnedsettings.cpp
@@ -205,6 +205,7 @@ void SkinnedSettings::readSettings()
ui.playlistsCheckBox->setChecked(settings.value("pl_show_plalists", false).toBool());
ui.popupCheckBox->setChecked(settings.value("pl_show_popup", false).toBool());
ui.plSeplineEdit->setText(settings.value("pl_separator", "|").toString());
+ ui.showNewPLCheckBox->setChecked(settings.value("pl_show_create_button", false).toBool());
//transparency
ui.mwTransparencySlider->setValue(100 - settings.value("mw_opacity", 1.0).toDouble()*100);
ui.eqTransparencySlider->setValue(100 - settings.value("eq_opacity", 1.0).toDouble()*100);
@@ -230,6 +231,7 @@ void SkinnedSettings::writeSettings()
settings.setValue ("pl_show_plalists", ui.playlistsCheckBox->isChecked());
settings.setValue ("pl_show_popup", ui.popupCheckBox->isChecked());
settings.setValue ("pl_separator", ui.plSeplineEdit->text());
+ settings.setValue ("pl_show_create_button", ui.showNewPLCheckBox->isChecked());
settings.setValue ("mw_opacity", 1.0 - (double)ui.mwTransparencySlider->value()/100);
settings.setValue ("eq_opacity", 1.0 - (double)ui.eqTransparencySlider->value()/100);
settings.setValue ("pl_opacity", 1.0 - (double)ui.plTransparencySlider->value()/100);