Lot of fixes for everything.

This commit is contained in:
Tobias Rundstrom 2006-02-21 00:29:28 -03:00
parent bdb2d70683
commit d356989d5e
18 changed files with 253 additions and 47 deletions

View file

@ -2,6 +2,11 @@
#include "MainWindow.h" #include "MainWindow.h"
#include "Button.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) 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_name_pressed = pressed;
m_diffx = 0; m_diffx = 0;
m_diffy = 0; m_diffy = 0;
m_nodrag = false;
} }
Button::~Button () Button::~Button ()
@ -18,6 +24,10 @@ Button::~Button ()
void void
Button::setPixmaps(Skin *skin) Button::setPixmaps(Skin *skin)
{ {
if (!m_name_normal && !m_name_pressed) {
return;
}
m_pixmap_normal = skin->getItem (m_name_normal); m_pixmap_normal = skin->getItem (m_name_normal);
m_pixmap_pressed = skin->getItem (m_name_pressed); m_pixmap_pressed = skin->getItem (m_name_pressed);
m_pixmap = m_pixmap_normal; m_pixmap = m_pixmap_normal;

View file

@ -10,6 +10,7 @@ class Button : public PixWidget
Q_OBJECT Q_OBJECT
public: public:
Button (QWidget *parent, uint btn1, uint btn2); Button (QWidget *parent, uint btn1, uint btn2);
Button (QWidget *parent);
~Button (); ~Button ();
bool noDrag (void) { return m_nodrag; } bool noDrag (void) { return m_nodrag; }

View file

@ -12,18 +12,17 @@
#include "Skin.h" #include "Skin.h"
using namespace std;
class SkinDisplay : public QWidget class SkinDisplay : public QWidget
{ {
Q_OBJECT Q_OBJECT
public: public:
SkinDisplay (QWidget *parent); SkinDisplay (QWidget *parent);
bool getNoDrag() const { return m_noDrag; } bool getNoDrag () const { return m_noDrag; }
void setNoDrag(bool d) { m_noDrag = d; } void setNoDrag (bool d) { m_noDrag = d; }
QWidget *getMW () const { return m_mw; }
QWidget *getMW() const { return m_mw; }
public slots: public slots:
virtual void setPixmaps(Skin *skin); virtual void setPixmaps(Skin *skin);

View file

@ -107,14 +107,6 @@ MainDisplay::SetupPushButtons (void)
m_eject = new Button (this, Skin::BTN_EJECT_0, Skin::BTN_EJECT_1); m_eject = new Button (this, Skin::BTN_EJECT_0, Skin::BTN_EJECT_1);
m_eject->move(136, 89); 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) MainDisplay::~MainDisplay (void)

View file

@ -47,6 +47,7 @@ class MainDisplay : public SkinDisplay
public slots: public slots:
void setPixmaps(Skin *skin); void setPixmaps(Skin *skin);
protected: protected:
void SetupPushButtons (void); void SetupPushButtons (void);
void SetupToggleButtons (void); void SetupToggleButtons (void);
@ -57,10 +58,6 @@ class MainDisplay : public SkinDisplay
Button *m_stop; Button *m_stop;
Button *m_next; Button *m_next;
Button *m_eject; Button *m_eject;
Button *m_shadebtn;
Button *m_menubtn;
Button *m_closebtn;
Button *m_minimize;
ToggleButton *m_pls; ToggleButton *m_pls;
ToggleButton *m_eq; ToggleButton *m_eq;

View file

@ -6,16 +6,44 @@ MainWindow::MainWindow (QWidget *parent) : QMainWindow (parent)
setWindowFlags(Qt::FramelessWindowHint); setWindowFlags(Qt::FramelessWindowHint);
setGeometry(100, 100, 275, 116); setGeometry(100, 100, 275, 116);
/*
* Initialize the Handler that will
* update the display and the buttons
*/
m_handler = new XMMSHandler (this); m_handler = new XMMSHandler (this);
/*
* Initialize skin, but don't open one
*/
skin = new Skin (); skin = new Skin ();
m_display = new MainDisplay(this);
/*
* The MainDisplay is the mainwindow non-shaded mode
*/
m_display = new MainDisplay (this);
setCentralWidget (m_display); setCentralWidget (m_display);
skin->setSkin ("./CleanAMP/");
m_display->show (); 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 () MainWindow::~MainWindow ()
@ -26,7 +54,30 @@ MainWindow::~MainWindow ()
void void
MainWindow::setNoDrag (bool b) 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) Skin *MainWindow::getSkin(void)

View file

@ -16,6 +16,7 @@ class MainWindow;
#include "Skin.h" #include "Skin.h"
#include "XmmsQT4.h" #include "XmmsQT4.h"
#include "MainDisplay.h" #include "MainDisplay.h"
#include "ShadedDisplay.h"
using namespace std; using namespace std;
@ -25,14 +26,27 @@ class MainWindow : public QMainWindow
public: public:
MainWindow (QWidget *parent); MainWindow (QWidget *parent);
~MainWindow (void); ~MainWindow (void);
Skin *getSkin (void); Skin *getSkin (void);
void setNoDrag (bool b);
XMMSHandler *getHandler () { return m_handler; } XMMSHandler *getHandler () { return m_handler; }
MainDisplay *getMD () { return m_display; } 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: private:
bool m_isshaded;
Skin *skin; Skin *skin;
XMMSHandler *m_handler; XMMSHandler *m_handler;
MainDisplay *m_display; MainDisplay *m_display;
ShadedDisplay *m_shaded;
}; };
#endif #endif

56
ShadedDisplay.cpp Normal file
View 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
View 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

View file

@ -119,7 +119,7 @@ Slider::setPos (uint p)
} }
uint x = m_pix * p / m_max; 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_button->move (x , 0);
m_pos = x; m_pos = x;
update (); update ();

View file

@ -18,7 +18,7 @@ SmallNumberDisplay::setPixmaps (Skin *skin)
void void
SmallNumberDisplay::setNumber (int num, int len) SmallNumberDisplay::setNumber (int num, int len)
{ {
snprintf (m_nums, len+1, "%d", num); snprintf (m_nums, len+1, "%02d", num);
m_num = len; m_num = len;
drawNumber (); drawNumber ();

View file

@ -1,3 +1,6 @@
#ifndef __SMALLNUMBERDISPLAY_H__
#define __SMALLNUMBERDISPLAY_H__
#include "PixWidget.h" #include "PixWidget.h"
#include <QPainter> #include <QPainter>
@ -25,3 +28,4 @@ class SmallNumberDisplay : public PixWidget
Skin *m_skin; Skin *m_skin;
}; };
#endif

View file

@ -14,6 +14,8 @@ TextScroller::TextScroller (QWidget *parent, uint w, uint h) : QWidget (parent)
m_w = w; m_w = w;
m_x_off = 0; m_x_off = 0;
m_x2_off = 0; m_x2_off = 0;
m_fontsize = 8; /* default */
m_ttf = true;
setMinimumSize(m_w + 2, m_h); setMinimumSize(m_w + 2, m_h);
setMaximumSize(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); m_timer = new QTimer (this);
connect (m_timer, SIGNAL (timeout()), this, SLOT (addOffset ())); connect (m_timer, SIGNAL (timeout()), this, SLOT (addOffset ()));
setAutoFillBackground (true);
//setText (QString::fromUtf8 ("Okerueu etuoduå öästö åntöå dS !! !¤ ¤ % % & & ¤"));
} }
void void
@ -65,7 +62,11 @@ TextScroller::addOffset ()
void void
TextScroller::setText (const QString &text) TextScroller::setText (const QString &text)
{ {
drawQtFont (text); if (m_ttf) {
drawQtFont (text);
} else {
drawBitmapFont (text);
}
m_x_off = 1; m_x_off = 1;
m_x2_off = 0; m_x2_off = 0;
update (); update ();
@ -110,7 +111,7 @@ void
TextScroller::drawQtFont (const QString &text) TextScroller::drawQtFont (const QString &text)
{ {
QFont font(m_skin->getPLeditValue ("font")); QFont font(m_skin->getPLeditValue ("font"));
font.setPixelSize (9); font.setPixelSize (m_fontsize);
QFontMetrics fM(font); QFontMetrics fM(font);
QRect rect = fM.boundingRect (text); QRect rect = fM.boundingRect (text);

View file

@ -23,6 +23,8 @@ class TextScroller : public QWidget
~TextScroller (); ~TextScroller ();
void setText(const QString &text); void setText(const QString &text);
void setFontSize (int i) { m_fontsize = i; }
void setTTF (bool b) { m_ttf = b; }
public slots: public slots:
void addOffset (); void addOffset ();
@ -38,6 +40,8 @@ class TextScroller : public QWidget
int m_y; int m_y;
int m_x_off; int m_x_off;
int m_x2_off; int m_x2_off;
int m_fontsize;
bool m_ttf;
QTimer *m_timer; QTimer *m_timer;

View file

@ -1,23 +1,41 @@
#include "MainWindow.h"
#include "TitleBar.h" #include "TitleBar.h"
#include "Display.h" #include "Display.h"
TitleBar::TitleBar (QWidget *parent, bool shaded) : PixWidget (parent) TitleBar::TitleBar (QWidget *parent, bool shaded) : PixWidget (parent)
{ {
MainWindow *mw = dynamic_cast<MainWindow*>(window ());
m_shaded = shaded; m_shaded = shaded;
setMinimumSize(QSize(275, 14)); setMinimumSize (275, 14);
setMaximumSize(QSize(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 void
TitleBar::setPixmaps (Skin *skin) TitleBar::setPixmaps (Skin *skin)
{ {
if (m_shaded) { if (m_shaded) {
m_pixmap_active = skin->getItem(Skin::STATUSBAR_0); m_pixmap_active = skin->getItem (Skin::STATUSBAR_0);
m_pixmap_inactive = skin->getItem(Skin::STATUSBAR_1); m_pixmap_inactive = skin->getItem (Skin::STATUSBAR_1);
} else { } else {
m_pixmap_active = skin->getItem(Skin::TITLEBAR_0); m_pixmap_active = skin->getItem (Skin::TITLEBAR_0);
m_pixmap_inactive = skin->getItem(Skin::TITLEBAR_1); m_pixmap_inactive = skin->getItem (Skin::TITLEBAR_1);
} }
if (underMouse()) { if (underMouse()) {
@ -38,14 +56,17 @@ TitleBar::setActive (bool active)
{ {
if (active) { if (active) {
m_pixmap = m_pixmap_active; m_pixmap = m_pixmap_active;
update(); update ();
} else { } else {
m_pixmap = m_pixmap_inactive; m_pixmap = m_pixmap_inactive;
update(); update ();
} }
} }
void void
TitleBar::mouseDoubleClickEvent (QMouseEvent *event) TitleBar::mouseDoubleClickEvent (QMouseEvent *event)
{ {
MainWindow *mw = dynamic_cast<MainWindow*>(window ());
mw->switchDisplay ();
} }

View file

@ -4,6 +4,7 @@
class TitleBar; class TitleBar;
#include "PixWidget.h" #include "PixWidget.h"
#include "Button.h"
using namespace std; using namespace std;
@ -24,6 +25,12 @@ class TitleBar : public PixWidget
private: private:
QPixmap m_pixmap_active; QPixmap m_pixmap_active;
QPixmap m_pixmap_inactive; QPixmap m_pixmap_inactive;
Button *m_shadebtn;
Button *m_menubtn;
Button *m_closebtn;
Button *m_minimize;
bool m_shaded; bool m_shaded;
}; };

View file

@ -36,6 +36,15 @@ XMMSHandler::playback_status (XMMSResult *res)
uint i; uint i;
res->getValue (&i); res->getValue (&i);
m_mw->getMD ()->m_playstatus->setStatus (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 void
@ -46,11 +55,17 @@ XMMSHandler::playback_playtime (XMMSResult *res)
sec = (i / 1000) % 60; sec = (i / 1000) % 60;
min = (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 */ if (m_mw->getShaded ()) {
m_mw->getMD ()->m_slider->setPos (i); 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 (); res->restart ();
} }
@ -84,8 +99,8 @@ XMMSHandler::medialib_info (XMMSResult *res)
/* Make this NICER! */ /* Make this NICER! */
res->entryFormat (str, 4096, "${artist} - ${album} - ${title}"); res->entryFormat (str, 4096, "${artist} - ${album} - ${title}");
qDebug ("%s", str);
m_mw->getMD ()->m_text->setText (QString::fromUtf8 (str)); m_mw->getMD ()->m_text->setText (QString::fromUtf8 (str));
m_mw->getSD ()->m_title->setText (QString::fromUtf8 (str));
if (res->getDictValue ("bitrate", &b)) { if (res->getDictValue ("bitrate", &b)) {
m_mw->getMD ()->m_kbps->setNumber (b/1000, 3); m_mw->getMD ()->m_kbps->setNumber (b/1000, 3);

View file

@ -12,7 +12,8 @@ SOURCES += XmmsQT4.cpp \
SmallNumberDisplay.cpp \ SmallNumberDisplay.cpp \
StereoMono.cpp \ StereoMono.cpp \
Slider.cpp \ Slider.cpp \
PlayStatus.cpp PlayStatus.cpp \
ShadedDisplay.cpp
HEADERS += XmmsQT4.h \ HEADERS += XmmsQT4.h \
PixWidget.h \ PixWidget.h \
@ -28,7 +29,8 @@ HEADERS += XmmsQT4.h \
SmallNumberDisplay.h \ SmallNumberDisplay.h \
StereoMono.h \ StereoMono.h \
Slider.h \ Slider.h \
PlayStatus.h PlayStatus.h \
ShadedDisplay.h
CONFIG += link_pkgconfig CONFIG += link_pkgconfig
PKGCONFIG += xmms2-client xmms2-client-cpp sigc++-2.0 PKGCONFIG += xmms2-client xmms2-client-cpp sigc++-2.0