aboutsummaryrefslogtreecommitdiff
path: root/src/titlebar.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/titlebar.cpp')
-rw-r--r--src/titlebar.cpp155
1 files changed, 132 insertions, 23 deletions
diff --git a/src/titlebar.cpp b/src/titlebar.cpp
index 189105f06..bdbd86b2e 100644
--- a/src/titlebar.cpp
+++ b/src/titlebar.cpp
@@ -22,18 +22,26 @@
#include <QApplication>
#include <QMouseEvent>
#include <QMenu>
+#include <QSettings>
-#include "titlebar.h"
+#include <soundcore.h>
+#include "symboldisplay.h"
#include "skin.h"
#include "button.h"
#include "dock.h"
+#include "titlebarcontrol.h"
+#include "shadedvisual.h"
+#include "titlebar.h"
TitleBar::TitleBar(QWidget *parent)
: PixmapWidget(parent)
{
+ m_align = FALSE;
m_skin = Skin::getPointer();
setPixmap(m_skin->getTitleBar(Skin::TITLEBAR_A));
m_mw = qobject_cast<MainWindow*>(parent);
+ m_shaded = FALSE;
+ m_currentTime = 0;
//buttons
m_menu = new Button(this,Skin::BT_MENU_N,Skin::BT_MENU_P);
connect(m_menu,SIGNAL(clicked()),this,SLOT(showMainMenu()));
@@ -43,36 +51,40 @@ TitleBar::TitleBar(QWidget *parent)
connect(m_minimize, SIGNAL(clicked()), m_mw, SLOT(showMinimized()));
m_shade = new Button(this,Skin::BT_SHADE1_N,Skin::BT_SHADE1_P);
m_shade->move(254,3);
+ connect(m_shade, SIGNAL(clicked()), SLOT(shade()));
m_close = new Button(this,Skin::BT_CLOSE_N,Skin::BT_CLOSE_P);
m_close->move(264,3);
connect(m_close, SIGNAL(clicked()), m_mw, SLOT(handleCloseRequest()));
setActive(FALSE);
connect(m_skin, SIGNAL(skinChanged()), this, SLOT(updateSkin()));
+
+ QSettings settings(QDir::homePath()+"/.qmmp/qmmprc", QSettings::IniFormat);
+ if (settings.value("Display/shaded", FALSE).toBool())
+ shade();
+ m_align = TRUE;
}
TitleBar::~TitleBar()
-{}
-
-
+{
+ QSettings settings(QDir::homePath()+"/.qmmp/qmmprc", QSettings::IniFormat);
+ settings.setValue("Display/shaded", m_shaded);
+}
void TitleBar::mousePressEvent(QMouseEvent* event)
{
- switch((int) event->button ())
+ switch ((int) event->button ())
+ {
+ case Qt::LeftButton:
{
- case Qt::LeftButton:
- {
- m_pos = event->pos();
- PlayList *pl = m_mw->getPLPointer();
- Dock::getPointer()->calculateDistances();
- x_diff = - m_mw->x() + pl->x();
- y_diff = - m_mw->y() + pl->y();
- break;
- }
- case Qt::RightButton:
- {
- m_mw->menu()->exec(event->globalPos());
- }
+ m_pos = event->pos();
+ Dock::getPointer()->calculateDistances();
+ break;
+ }
+ case Qt::RightButton:
+ {
+ m_mw->menu()->exec(event->globalPos());
+ }
}
}
@@ -88,20 +100,36 @@ void TitleBar::mouseMoveEvent(QMouseEvent* event)
void TitleBar::setActive(bool a)
{
- if(a)
+ if (a)
{
- setPixmap(m_skin->getTitleBar(Skin::TITLEBAR_A));
+ if (m_shaded)
+ {
+ setPixmap(m_skin->getTitleBar(Skin::TITLEBAR_SHADED_A));
+ m_shade2->show();
+ }
+ else
+ {
+ setPixmap(m_skin->getTitleBar(Skin::TITLEBAR_A));
+ m_shade->show();
+ }
m_menu->show();
m_minimize->show();
- m_shade->show();
m_close->show();
}
else
{
- setPixmap(m_skin->getTitleBar(Skin::TITLEBAR_I));
+ if (m_shaded)
+ {
+ setPixmap(m_skin->getTitleBar(Skin::TITLEBAR_SHADED_I));
+ m_shade2->hide();
+ }
+ else
+ {
+ setPixmap(m_skin->getTitleBar(Skin::TITLEBAR_I));
+ m_shade->hide();
+ }
m_menu->hide();
m_minimize->hide();
- m_shade->hide();
m_close->hide();
}
}
@@ -115,3 +143,84 @@ void TitleBar::showMainMenu()
{
m_mw->menu()->exec(m_menu->mapToGlobal(m_menu->pos()));
}
+
+void TitleBar::shade()
+{
+ m_shaded = !m_shaded;
+
+ if (m_shaded)
+ {
+ m_mw->setFixedSize(275,14);
+ setPixmap(m_skin->getTitleBar(Skin::TITLEBAR_SHADED_A));
+ m_shade->hide();
+ m_shade2 = new Button(this,Skin::BT_SHADE2_N, Skin::BT_SHADE2_P);
+ m_shade2->move(254,3);
+ connect(m_shade2, SIGNAL(clicked()), SLOT(shade()));
+ m_shade2->show();
+ m_currentTime = new SymbolDisplay(this, 6);
+ m_currentTime->move(127,4);
+ m_currentTime->show();
+ m_currentTime->display("--:--");
+ m_control = new TitleBarControl(this);
+ m_control->move(168,2);
+ m_control->show();
+ connect (m_control, SIGNAL (nextClicked()), parent(), SLOT (next()));
+ connect (m_control, SIGNAL (previousClicked()), parent(), SLOT (previous()));
+ connect (m_control, SIGNAL (playClicked()), parent(), SLOT (play()));
+ connect (m_control, SIGNAL (pauseClicked()), parent(), SLOT (pause()));
+ connect (m_control, SIGNAL (stopClicked()), parent(), SLOT (stop()));
+ connect (m_control, SIGNAL (ejectClicked()), parent(), SLOT (addFile()));
+ m_visual = new ShadedVisual(this);
+ SoundCore::instance()->addVisualization(m_visual);
+ m_visual->show();
+ m_visual->move(79,5);
+ }
+ else
+ {
+ m_mw->setFixedSize(275,116);
+ setPixmap(m_skin->getTitleBar(Skin::TITLEBAR_A));
+ delete m_shade2;
+ delete m_currentTime;
+ delete m_control;
+ SoundCore::instance()->removeVisual(m_visual);
+ delete m_visual;
+ m_shade2 = 0;
+ m_currentTime = 0;
+ m_shade->show();
+ }
+ if(m_align)
+ Dock::getPointer()->align(m_mw, m_shaded? -102: 102);
+}
+
+QString TitleBar::formatTime ( int sec )
+{
+ int minutes = sec / 60;
+ int seconds = sec % 60;
+
+ QString str_minutes = QString::number ( minutes );
+ QString str_seconds = QString::number ( seconds );
+
+ if ( minutes < 10 ) str_minutes.prepend ( "0" );
+ if ( seconds < 10 ) str_seconds.prepend ( "0" );
+
+ return str_minutes + ":" + str_seconds;
+}
+
+void TitleBar::setInfo(const OutputState &st)
+{
+ if (!m_currentTime)
+ return;
+ switch ( ( int ) st.type() )
+ {
+ case OutputState::Info:
+ {
+ m_currentTime->display(formatTime(st.elapsedSeconds()));
+ break;
+ }
+ case OutputState::Stopped:
+ {
+ m_currentTime->display("--:--");
+ break;
+ }
+ }
+}