Lot of fixes for everything.
This commit is contained in:
parent
bdb2d70683
commit
d356989d5e
18 changed files with 253 additions and 47 deletions
10
Button.cpp
10
Button.cpp
|
@ -2,6 +2,11 @@
|
|||
#include "MainWindow.h"
|
||||
#include "Button.h"
|
||||
|
||||
Button::Button (QWidget *parent) : PixWidget (parent)
|
||||
{
|
||||
m_name_normal = 0;
|
||||
m_name_pressed = 0;
|
||||
}
|
||||
|
||||
Button::Button (QWidget *parent, uint normal, uint pressed) : PixWidget (parent)
|
||||
{
|
||||
|
@ -9,6 +14,7 @@ Button::Button (QWidget *parent, uint normal, uint pressed) : PixWidget (parent)
|
|||
m_name_pressed = pressed;
|
||||
m_diffx = 0;
|
||||
m_diffy = 0;
|
||||
m_nodrag = false;
|
||||
}
|
||||
|
||||
Button::~Button ()
|
||||
|
@ -18,6 +24,10 @@ Button::~Button ()
|
|||
void
|
||||
Button::setPixmaps(Skin *skin)
|
||||
{
|
||||
if (!m_name_normal && !m_name_pressed) {
|
||||
return;
|
||||
}
|
||||
|
||||
m_pixmap_normal = skin->getItem (m_name_normal);
|
||||
m_pixmap_pressed = skin->getItem (m_name_pressed);
|
||||
m_pixmap = m_pixmap_normal;
|
||||
|
|
1
Button.h
1
Button.h
|
@ -10,6 +10,7 @@ class Button : public PixWidget
|
|||
Q_OBJECT
|
||||
public:
|
||||
Button (QWidget *parent, uint btn1, uint btn2);
|
||||
Button (QWidget *parent);
|
||||
~Button ();
|
||||
bool noDrag (void) { return m_nodrag; }
|
||||
|
||||
|
|
|
@ -12,18 +12,17 @@
|
|||
|
||||
#include "Skin.h"
|
||||
|
||||
using namespace std;
|
||||
|
||||
class SkinDisplay : public QWidget
|
||||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
SkinDisplay (QWidget *parent);
|
||||
|
||||
bool getNoDrag() const { return m_noDrag; }
|
||||
void setNoDrag(bool d) { m_noDrag = d; }
|
||||
bool getNoDrag () const { return m_noDrag; }
|
||||
void setNoDrag (bool d) { m_noDrag = d; }
|
||||
|
||||
QWidget *getMW () const { return m_mw; }
|
||||
|
||||
QWidget *getMW() const { return m_mw; }
|
||||
public slots:
|
||||
virtual void setPixmaps(Skin *skin);
|
||||
|
||||
|
|
|
@ -107,14 +107,6 @@ MainDisplay::SetupPushButtons (void)
|
|||
m_eject = new Button (this, Skin::BTN_EJECT_0, Skin::BTN_EJECT_1);
|
||||
m_eject->move(136, 89);
|
||||
|
||||
m_menubtn = new Button (this, Skin::MENUBUTTON_0, Skin::MENUBUTTON_1);
|
||||
m_menubtn->move(6, 3);
|
||||
m_minimize = new Button (this, Skin::MINIMIZE_0, Skin::MINIMIZE_1);
|
||||
m_minimize->move(244, 3);
|
||||
m_shadebtn = new Button (this, Skin::SHADE_1_0, Skin::SHADE_1_1);
|
||||
m_shadebtn->move(254, 3);
|
||||
m_closebtn = new Button (this, Skin::CLOSE_0, Skin::CLOSE_1);
|
||||
m_closebtn->move(264, 3);
|
||||
}
|
||||
|
||||
MainDisplay::~MainDisplay (void)
|
||||
|
|
|
@ -47,6 +47,7 @@ class MainDisplay : public SkinDisplay
|
|||
|
||||
public slots:
|
||||
void setPixmaps(Skin *skin);
|
||||
|
||||
protected:
|
||||
void SetupPushButtons (void);
|
||||
void SetupToggleButtons (void);
|
||||
|
@ -57,10 +58,6 @@ class MainDisplay : public SkinDisplay
|
|||
Button *m_stop;
|
||||
Button *m_next;
|
||||
Button *m_eject;
|
||||
Button *m_shadebtn;
|
||||
Button *m_menubtn;
|
||||
Button *m_closebtn;
|
||||
Button *m_minimize;
|
||||
|
||||
ToggleButton *m_pls;
|
||||
ToggleButton *m_eq;
|
||||
|
|
|
@ -6,16 +6,44 @@ MainWindow::MainWindow (QWidget *parent) : QMainWindow (parent)
|
|||
setWindowFlags(Qt::FramelessWindowHint);
|
||||
setGeometry(100, 100, 275, 116);
|
||||
|
||||
/*
|
||||
* Initialize the Handler that will
|
||||
* update the display and the buttons
|
||||
*/
|
||||
m_handler = new XMMSHandler (this);
|
||||
|
||||
/*
|
||||
* Initialize skin, but don't open one
|
||||
*/
|
||||
skin = new Skin ();
|
||||
m_display = new MainDisplay(this);
|
||||
|
||||
/*
|
||||
* The MainDisplay is the mainwindow non-shaded mode
|
||||
*/
|
||||
m_display = new MainDisplay (this);
|
||||
setCentralWidget (m_display);
|
||||
|
||||
skin->setSkin ("./CleanAMP/");
|
||||
m_display->show ();
|
||||
|
||||
/*
|
||||
* MainDisplay's shaded mode
|
||||
*/
|
||||
m_shaded = new ShadedDisplay (this);
|
||||
m_shaded->hide ();
|
||||
|
||||
/*
|
||||
* Per default not shaded. Change this to a
|
||||
* config value later.
|
||||
*/
|
||||
m_isshaded = false;
|
||||
|
||||
/*
|
||||
* Now that everything is initialized
|
||||
* open the skin and send the
|
||||
* SkinChanged signal that will cause
|
||||
* all widgets to get their pixmaps
|
||||
*/
|
||||
skin->setSkin ("./CleanAMP/");
|
||||
|
||||
}
|
||||
|
||||
MainWindow::~MainWindow ()
|
||||
|
@ -26,7 +54,30 @@ MainWindow::~MainWindow ()
|
|||
void
|
||||
MainWindow::setNoDrag (bool b)
|
||||
{
|
||||
m_display->setNoDrag (b);
|
||||
if (m_isshaded) {
|
||||
m_shaded->setNoDrag (b);
|
||||
} else {
|
||||
m_display->setNoDrag (b);
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
MainWindow::switchDisplay ()
|
||||
{
|
||||
if (m_isshaded) {
|
||||
m_shaded->hide ();
|
||||
m_display->show ();
|
||||
resize (275, 116);
|
||||
m_isshaded = false;
|
||||
} else {
|
||||
m_display->hide ();
|
||||
m_shaded->show ();
|
||||
resize (275, 14);
|
||||
m_isshaded = true;
|
||||
}
|
||||
|
||||
update ();
|
||||
|
||||
}
|
||||
|
||||
Skin *MainWindow::getSkin(void)
|
||||
|
|
16
MainWindow.h
16
MainWindow.h
|
@ -16,6 +16,7 @@ class MainWindow;
|
|||
#include "Skin.h"
|
||||
#include "XmmsQT4.h"
|
||||
#include "MainDisplay.h"
|
||||
#include "ShadedDisplay.h"
|
||||
|
||||
using namespace std;
|
||||
|
||||
|
@ -25,14 +26,27 @@ class MainWindow : public QMainWindow
|
|||
public:
|
||||
MainWindow (QWidget *parent);
|
||||
~MainWindow (void);
|
||||
|
||||
Skin *getSkin (void);
|
||||
void setNoDrag (bool b);
|
||||
|
||||
XMMSHandler *getHandler () { return m_handler; }
|
||||
MainDisplay *getMD () { return m_display; }
|
||||
void setNoDrag (bool b);
|
||||
ShadedDisplay *getSD () { return m_shaded; }
|
||||
|
||||
bool getShaded (void) { return m_isshaded; }
|
||||
|
||||
public slots:
|
||||
void switchDisplay ();
|
||||
|
||||
private:
|
||||
bool m_isshaded;
|
||||
Skin *skin;
|
||||
|
||||
XMMSHandler *m_handler;
|
||||
MainDisplay *m_display;
|
||||
ShadedDisplay *m_shaded;
|
||||
};
|
||||
|
||||
|
||||
#endif
|
||||
|
|
56
ShadedDisplay.cpp
Normal file
56
ShadedDisplay.cpp
Normal file
|
@ -0,0 +1,56 @@
|
|||
#include "ShadedDisplay.h"
|
||||
|
||||
ShadedDisplay::ShadedDisplay (QWidget *parent) : SkinDisplay (parent)
|
||||
{
|
||||
MainWindow *mw = dynamic_cast<MainWindow*>(parent);
|
||||
m_mw = parent;
|
||||
|
||||
setMinimumSize (275, 14);
|
||||
setMaximumSize (275, 14);
|
||||
|
||||
m_tbar = new TitleBar(this, true);
|
||||
m_tbar->move (0, 0);
|
||||
|
||||
m_number = new SmallNumberDisplay (this, 10);
|
||||
m_number->move (135, 4);
|
||||
m_number->setNumber (0, 2);
|
||||
|
||||
m_number2 = new SmallNumberDisplay (this, 10);
|
||||
m_number2->move (147, 4);
|
||||
m_number2->setNumber (0, 2);
|
||||
|
||||
m_title = new TextScroller (this, 48, 7);
|
||||
m_title->move (79, 4);
|
||||
m_title->setText ("Promoe 0.1");
|
||||
|
||||
m_prev = new Button (this);
|
||||
m_prev->move(169, 4);
|
||||
m_prev->resize (8, 7);
|
||||
connect (m_prev, SIGNAL(clicked()), mw->getHandler (), SLOT(prev()));
|
||||
|
||||
m_play = new Button (this);
|
||||
m_play->move(177, 4);
|
||||
m_play->resize (10, 7);
|
||||
connect (m_play, SIGNAL(clicked()), mw->getHandler (), SLOT(play()));
|
||||
|
||||
m_pause = new Button (this);
|
||||
m_pause->move(187, 4);
|
||||
m_pause->resize (10, 7);
|
||||
connect (m_pause, SIGNAL(clicked()), mw->getHandler (), SLOT(pause()));
|
||||
|
||||
m_stop = new Button (this);
|
||||
m_stop->move(197, 4);
|
||||
m_stop->resize (9, 7);
|
||||
connect (m_stop, SIGNAL(clicked()), mw->getHandler (), SLOT(stop()));
|
||||
|
||||
m_next = new Button (this);
|
||||
m_next->move(206, 4);
|
||||
m_next->resize (8, 7);
|
||||
connect (m_next, SIGNAL(clicked()), mw->getHandler (), SLOT(next()));
|
||||
|
||||
m_eject = new Button (this);
|
||||
m_eject->move(216, 4);
|
||||
m_eject->resize (9, 7);
|
||||
|
||||
}
|
||||
|
32
ShadedDisplay.h
Normal file
32
ShadedDisplay.h
Normal file
|
@ -0,0 +1,32 @@
|
|||
#ifndef __SHADEDDISPLAY_H__
|
||||
#define __SHADEDDISPLAY_H__
|
||||
|
||||
class ShadedDisplay;
|
||||
|
||||
#include "MainWindow.h"
|
||||
#include "Display.h"
|
||||
#include "SmallNumberDisplay.h"
|
||||
#include "TextBar.h"
|
||||
#include "Button.h"
|
||||
|
||||
class ShadedDisplay : public SkinDisplay
|
||||
{
|
||||
public:
|
||||
ShadedDisplay (QWidget *parent);
|
||||
~ShadedDisplay () { }
|
||||
|
||||
SmallNumberDisplay *m_number;
|
||||
SmallNumberDisplay *m_number2;
|
||||
TextScroller *m_title;
|
||||
|
||||
private:
|
||||
Button *m_prev;
|
||||
Button *m_play;
|
||||
Button *m_pause;
|
||||
Button *m_stop;
|
||||
Button *m_next;
|
||||
Button *m_eject;
|
||||
|
||||
};
|
||||
|
||||
#endif
|
|
@ -119,7 +119,7 @@ Slider::setPos (uint p)
|
|||
}
|
||||
|
||||
uint x = m_pix * p / m_max;
|
||||
if (x != m_pos) {
|
||||
if (x < m_pix - m_button->rect().width() && x != m_pos) {
|
||||
m_button->move (x , 0);
|
||||
m_pos = x;
|
||||
update ();
|
||||
|
|
|
@ -18,7 +18,7 @@ SmallNumberDisplay::setPixmaps (Skin *skin)
|
|||
void
|
||||
SmallNumberDisplay::setNumber (int num, int len)
|
||||
{
|
||||
snprintf (m_nums, len+1, "%d", num);
|
||||
snprintf (m_nums, len+1, "%02d", num);
|
||||
m_num = len;
|
||||
|
||||
drawNumber ();
|
||||
|
|
|
@ -1,3 +1,6 @@
|
|||
#ifndef __SMALLNUMBERDISPLAY_H__
|
||||
#define __SMALLNUMBERDISPLAY_H__
|
||||
|
||||
#include "PixWidget.h"
|
||||
#include <QPainter>
|
||||
|
||||
|
@ -25,3 +28,4 @@ class SmallNumberDisplay : public PixWidget
|
|||
Skin *m_skin;
|
||||
};
|
||||
|
||||
#endif
|
||||
|
|
15
TextBar.cpp
15
TextBar.cpp
|
@ -14,6 +14,8 @@ TextScroller::TextScroller (QWidget *parent, uint w, uint h) : QWidget (parent)
|
|||
m_w = w;
|
||||
m_x_off = 0;
|
||||
m_x2_off = 0;
|
||||
m_fontsize = 8; /* default */
|
||||
m_ttf = true;
|
||||
|
||||
setMinimumSize(m_w + 2, m_h);
|
||||
setMaximumSize(m_w + 2, m_h);
|
||||
|
@ -27,11 +29,6 @@ TextScroller::TextScroller (QWidget *parent, uint w, uint h) : QWidget (parent)
|
|||
m_timer = new QTimer (this);
|
||||
connect (m_timer, SIGNAL (timeout()), this, SLOT (addOffset ()));
|
||||
|
||||
setAutoFillBackground (true);
|
||||
|
||||
|
||||
//setText (QString::fromUtf8 ("Okerueu etuoduå öästö åntöå dS !! !¤ ¤ % % & & ¤"));
|
||||
|
||||
}
|
||||
|
||||
void
|
||||
|
@ -65,7 +62,11 @@ TextScroller::addOffset ()
|
|||
void
|
||||
TextScroller::setText (const QString &text)
|
||||
{
|
||||
drawQtFont (text);
|
||||
if (m_ttf) {
|
||||
drawQtFont (text);
|
||||
} else {
|
||||
drawBitmapFont (text);
|
||||
}
|
||||
m_x_off = 1;
|
||||
m_x2_off = 0;
|
||||
update ();
|
||||
|
@ -110,7 +111,7 @@ void
|
|||
TextScroller::drawQtFont (const QString &text)
|
||||
{
|
||||
QFont font(m_skin->getPLeditValue ("font"));
|
||||
font.setPixelSize (9);
|
||||
font.setPixelSize (m_fontsize);
|
||||
|
||||
QFontMetrics fM(font);
|
||||
QRect rect = fM.boundingRect (text);
|
||||
|
|
|
@ -23,6 +23,8 @@ class TextScroller : public QWidget
|
|||
~TextScroller ();
|
||||
|
||||
void setText(const QString &text);
|
||||
void setFontSize (int i) { m_fontsize = i; }
|
||||
void setTTF (bool b) { m_ttf = b; }
|
||||
|
||||
public slots:
|
||||
void addOffset ();
|
||||
|
@ -38,6 +40,8 @@ class TextScroller : public QWidget
|
|||
int m_y;
|
||||
int m_x_off;
|
||||
int m_x2_off;
|
||||
int m_fontsize;
|
||||
bool m_ttf;
|
||||
|
||||
QTimer *m_timer;
|
||||
|
||||
|
|
37
TitleBar.cpp
37
TitleBar.cpp
|
@ -1,23 +1,41 @@
|
|||
#include "MainWindow.h"
|
||||
#include "TitleBar.h"
|
||||
#include "Display.h"
|
||||
|
||||
TitleBar::TitleBar (QWidget *parent, bool shaded) : PixWidget (parent)
|
||||
{
|
||||
MainWindow *mw = dynamic_cast<MainWindow*>(window ());
|
||||
m_shaded = shaded;
|
||||
|
||||
setMinimumSize(QSize(275, 14));
|
||||
setMaximumSize(QSize(275, 14));
|
||||
setMinimumSize (275, 14);
|
||||
setMaximumSize (275, 14);
|
||||
|
||||
m_menubtn = new Button (this, Skin::MENUBUTTON_0, Skin::MENUBUTTON_1);
|
||||
m_menubtn->move(6, 3);
|
||||
|
||||
m_minimize = new Button (this, Skin::MINIMIZE_0, Skin::MINIMIZE_1);
|
||||
connect (m_minimize, SIGNAL (clicked ()), mw, SLOT (showMinimized ()));
|
||||
m_minimize->move(244, 3);
|
||||
|
||||
m_shadebtn = new Button (this, Skin::SHADE_1_0, Skin::SHADE_1_1);
|
||||
connect (m_shadebtn, SIGNAL (clicked()), mw, SLOT (switchDisplay ()));
|
||||
m_shadebtn->move(254, 3);
|
||||
|
||||
m_closebtn = new Button (this, Skin::CLOSE_0, Skin::CLOSE_1);
|
||||
connect (m_closebtn, SIGNAL (clicked()), qApp, SLOT (quit ()));
|
||||
m_closebtn->move(264, 3);
|
||||
|
||||
}
|
||||
|
||||
void
|
||||
TitleBar::setPixmaps (Skin *skin)
|
||||
{
|
||||
if (m_shaded) {
|
||||
m_pixmap_active = skin->getItem(Skin::STATUSBAR_0);
|
||||
m_pixmap_inactive = skin->getItem(Skin::STATUSBAR_1);
|
||||
m_pixmap_active = skin->getItem (Skin::STATUSBAR_0);
|
||||
m_pixmap_inactive = skin->getItem (Skin::STATUSBAR_1);
|
||||
} else {
|
||||
m_pixmap_active = skin->getItem(Skin::TITLEBAR_0);
|
||||
m_pixmap_inactive = skin->getItem(Skin::TITLEBAR_1);
|
||||
m_pixmap_active = skin->getItem (Skin::TITLEBAR_0);
|
||||
m_pixmap_inactive = skin->getItem (Skin::TITLEBAR_1);
|
||||
}
|
||||
|
||||
if (underMouse()) {
|
||||
|
@ -38,14 +56,17 @@ TitleBar::setActive (bool active)
|
|||
{
|
||||
if (active) {
|
||||
m_pixmap = m_pixmap_active;
|
||||
update();
|
||||
update ();
|
||||
} else {
|
||||
m_pixmap = m_pixmap_inactive;
|
||||
update();
|
||||
update ();
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
TitleBar::mouseDoubleClickEvent (QMouseEvent *event)
|
||||
{
|
||||
MainWindow *mw = dynamic_cast<MainWindow*>(window ());
|
||||
mw->switchDisplay ();
|
||||
}
|
||||
|
||||
|
|
|
@ -4,6 +4,7 @@
|
|||
class TitleBar;
|
||||
|
||||
#include "PixWidget.h"
|
||||
#include "Button.h"
|
||||
|
||||
using namespace std;
|
||||
|
||||
|
@ -24,6 +25,12 @@ class TitleBar : public PixWidget
|
|||
private:
|
||||
QPixmap m_pixmap_active;
|
||||
QPixmap m_pixmap_inactive;
|
||||
|
||||
Button *m_shadebtn;
|
||||
Button *m_menubtn;
|
||||
Button *m_closebtn;
|
||||
Button *m_minimize;
|
||||
|
||||
bool m_shaded;
|
||||
};
|
||||
|
||||
|
|
|
@ -36,6 +36,15 @@ XMMSHandler::playback_status (XMMSResult *res)
|
|||
uint i;
|
||||
res->getValue (&i);
|
||||
m_mw->getMD ()->m_playstatus->setStatus (i);
|
||||
|
||||
if (i == XMMS_PLAYBACK_STATUS_STOP) {
|
||||
m_mw->getSD ()->m_number->setNumber (0, 2);
|
||||
m_mw->getSD ()->m_number2->setNumber (0, 2);
|
||||
m_mw->getMD ()->m_number->setNumber (0, 0);
|
||||
m_mw->getMD ()->m_number2->setNumber (0, 0);
|
||||
m_mw->getMD ()->m_slider->setPos (0);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
void
|
||||
|
@ -46,11 +55,17 @@ XMMSHandler::playback_playtime (XMMSResult *res)
|
|||
|
||||
sec = (i / 1000) % 60;
|
||||
min = (i / 1000) / 60;
|
||||
m_mw->getMD ()->m_number->setNumber (min / 10, min % 10);
|
||||
m_mw->getMD ()->m_number2->setNumber (sec / 10, sec % 10);
|
||||
|
||||
/* update slider */
|
||||
m_mw->getMD ()->m_slider->setPos (i);
|
||||
if (m_mw->getShaded ()) {
|
||||
m_mw->getSD ()->m_number->setNumber (min, 2);
|
||||
m_mw->getSD ()->m_number2->setNumber (sec, 2);
|
||||
} else {
|
||||
m_mw->getMD ()->m_number->setNumber (min / 10, min % 10);
|
||||
m_mw->getMD ()->m_number2->setNumber (sec / 10, sec % 10);
|
||||
|
||||
/* update slider */
|
||||
m_mw->getMD ()->m_slider->setPos (i);
|
||||
}
|
||||
|
||||
res->restart ();
|
||||
}
|
||||
|
@ -84,8 +99,8 @@ XMMSHandler::medialib_info (XMMSResult *res)
|
|||
|
||||
/* Make this NICER! */
|
||||
res->entryFormat (str, 4096, "${artist} - ${album} - ${title}");
|
||||
qDebug ("%s", str);
|
||||
m_mw->getMD ()->m_text->setText (QString::fromUtf8 (str));
|
||||
m_mw->getSD ()->m_title->setText (QString::fromUtf8 (str));
|
||||
|
||||
if (res->getDictValue ("bitrate", &b)) {
|
||||
m_mw->getMD ()->m_kbps->setNumber (b/1000, 3);
|
||||
|
|
|
@ -12,7 +12,8 @@ SOURCES += XmmsQT4.cpp \
|
|||
SmallNumberDisplay.cpp \
|
||||
StereoMono.cpp \
|
||||
Slider.cpp \
|
||||
PlayStatus.cpp
|
||||
PlayStatus.cpp \
|
||||
ShadedDisplay.cpp
|
||||
|
||||
HEADERS += XmmsQT4.h \
|
||||
PixWidget.h \
|
||||
|
@ -28,7 +29,8 @@ HEADERS += XmmsQT4.h \
|
|||
SmallNumberDisplay.h \
|
||||
StereoMono.h \
|
||||
Slider.h \
|
||||
PlayStatus.h
|
||||
PlayStatus.h \
|
||||
ShadedDisplay.h
|
||||
|
||||
CONFIG += link_pkgconfig
|
||||
PKGCONFIG += xmms2-client xmms2-client-cpp sigc++-2.0
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue