-rw-r--r-- | noncore/multimedia/opieplayer2/mediawidget.cpp | 22 | ||||
-rw-r--r-- | noncore/multimedia/opieplayer2/mediawidget.h | 8 | ||||
-rw-r--r-- | noncore/multimedia/opieplayer2/skin.cpp | 7 | ||||
-rw-r--r-- | noncore/multimedia/opieplayer2/skin.h | 2 |
4 files changed, 23 insertions, 16 deletions
diff --git a/noncore/multimedia/opieplayer2/mediawidget.cpp b/noncore/multimedia/opieplayer2/mediawidget.cpp index 2031b4d..4de7ea9 100644 --- a/noncore/multimedia/opieplayer2/mediawidget.cpp +++ b/noncore/multimedia/opieplayer2/mediawidget.cpp | |||
@@ -31,98 +31,94 @@ | |||
31 | MediaWidget::MediaWidget( PlayListWidget &_playList, MediaPlayerState &_mediaPlayerState, QWidget *parent, const char *name ) | 31 | MediaWidget::MediaWidget( PlayListWidget &_playList, MediaPlayerState &_mediaPlayerState, QWidget *parent, const char *name ) |
32 | : QWidget( parent, name ), mediaPlayerState( _mediaPlayerState ), playList( _playList ) | 32 | : QWidget( parent, name ), mediaPlayerState( _mediaPlayerState ), playList( _playList ) |
33 | { | 33 | { |
34 | connect( &mediaPlayerState, SIGNAL( displayTypeChanged( MediaPlayerState::DisplayType ) ), | 34 | connect( &mediaPlayerState, SIGNAL( displayTypeChanged( MediaPlayerState::DisplayType ) ), |
35 | this, SLOT( setDisplayType( MediaPlayerState::DisplayType ) ) ); | 35 | this, SLOT( setDisplayType( MediaPlayerState::DisplayType ) ) ); |
36 | connect( &mediaPlayerState, SIGNAL( lengthChanged( long ) ), | 36 | connect( &mediaPlayerState, SIGNAL( lengthChanged( long ) ), |
37 | this, SLOT( setLength( long ) ) ); | 37 | this, SLOT( setLength( long ) ) ); |
38 | connect( &mediaPlayerState, SIGNAL( playingToggled( bool ) ), | 38 | connect( &mediaPlayerState, SIGNAL( playingToggled( bool ) ), |
39 | this, SLOT( setPlaying( bool ) ) ); | 39 | this, SLOT( setPlaying( bool ) ) ); |
40 | } | 40 | } |
41 | 41 | ||
42 | MediaWidget::~MediaWidget() | 42 | MediaWidget::~MediaWidget() |
43 | { | 43 | { |
44 | } | 44 | } |
45 | 45 | ||
46 | void MediaWidget::setupButtons( const SkinButtonInfo *skinInfo, uint buttonCount, | 46 | void MediaWidget::setupButtons( const SkinButtonInfo *skinInfo, uint buttonCount, |
47 | const QString &imagePrefix, const QSize &buttonAreaSize ) | 47 | const Skin &skin, const QSize &buttonAreaSize ) |
48 | { | 48 | { |
49 | buttonMask = QImage( buttonAreaSize, 8, 255 ); | 49 | buttonMask = QImage( buttonAreaSize, 8, 255 ); |
50 | buttonMask.fill( 0 ); | 50 | buttonMask.fill( 0 ); |
51 | 51 | ||
52 | buttons.clear(); | 52 | buttons.clear(); |
53 | buttons.reserve( buttonCount ); | 53 | buttons.reserve( buttonCount ); |
54 | 54 | ||
55 | for ( uint i = 0; i < buttonCount; ++i ) { | 55 | for ( uint i = 0; i < buttonCount; ++i ) { |
56 | Button button = setupButton( skinInfo[ i ], imagePrefix ); | 56 | Button button = setupButton( skinInfo[ i ], skin ); |
57 | buttons.push_back( button ); | 57 | buttons.push_back( button ); |
58 | } | 58 | } |
59 | } | 59 | } |
60 | 60 | ||
61 | MediaWidget::Button MediaWidget::setupButton( const SkinButtonInfo &buttonInfo, const QString &imagePrefix ) | 61 | MediaWidget::Button MediaWidget::setupButton( const SkinButtonInfo &buttonInfo, const Skin &skin ) |
62 | { | 62 | { |
63 | Button button; | 63 | Button button; |
64 | button.command = buttonInfo.command; | 64 | button.command = buttonInfo.command; |
65 | button.type = buttonInfo.type; | 65 | button.type = buttonInfo.type; |
66 | 66 | ||
67 | QString fileName = imagePrefix + buttonInfo.fileName + ".png"; | 67 | button.mask = setupButtonMask( button.command, skin.buttonMaskImage( buttonInfo.fileName ) ); |
68 | |||
69 | button.mask = setupButtonMask( button.command, fileName ); | ||
70 | 68 | ||
71 | return button; | 69 | return button; |
72 | } | 70 | } |
73 | 71 | ||
74 | QBitmap MediaWidget::setupButtonMask( const Command &command, const QString &fileName ) | 72 | QBitmap MediaWidget::setupButtonMask( const Command &command, const QImage &maskImage ) |
75 | { | 73 | { |
76 | QImage imgMask( Resource::findPixmap( fileName ) ); | 74 | if ( maskImage.isNull() ) |
77 | if ( imgMask.isNull() ) | ||
78 | return QBitmap(); | 75 | return QBitmap(); |
79 | 76 | ||
80 | uchar **dest = buttonMask.jumpTable(); | 77 | uchar **dest = buttonMask.jumpTable(); |
81 | for ( int y = 0; y < buttonMask.height(); y++ ) { | 78 | for ( int y = 0; y < buttonMask.height(); y++ ) { |
82 | uchar *line = dest[y]; | 79 | uchar *line = dest[y]; |
83 | for ( int x = 0; x < buttonMask.width(); x++ ) | 80 | for ( int x = 0; x < buttonMask.width(); x++ ) |
84 | if ( !qRed( imgMask.pixel( x, y ) ) ) | 81 | if ( !qRed( maskImage.pixel( x, y ) ) ) |
85 | line[x] = command + 1; | 82 | line[x] = command + 1; |
86 | } | 83 | } |
87 | 84 | ||
88 | // ### grmbl qt2. use constructor when switching to qt3. | 85 | // ### grmbl qt2. use constructor when switching to qt3. |
89 | QBitmap bm; bm = imgMask; | 86 | QBitmap bm; bm = maskImage; |
90 | return bm; | 87 | return bm; |
91 | } | 88 | } |
92 | 89 | ||
93 | void MediaWidget::loadDefaultSkin( const SkinButtonInfo *skinInfo, uint buttonCount, const QString &fileNameInfix ) | 90 | void MediaWidget::loadDefaultSkin( const SkinButtonInfo *skinInfo, uint buttonCount, const QString &fileNameInfix ) |
94 | { | 91 | { |
95 | Config cfg( "OpiePlayer" ); | 92 | Config cfg( "OpiePlayer" ); |
96 | cfg.setGroup( "Options" ); | 93 | cfg.setGroup( "Options" ); |
97 | QString skin = cfg.readEntry( "Skin","default" ); | 94 | QString skin = cfg.readEntry( "Skin","default" ); |
98 | 95 | ||
99 | loadSkin( skinInfo, buttonCount, skin, fileNameInfix ); | 96 | loadSkin( skinInfo, buttonCount, skin, fileNameInfix ); |
100 | } | 97 | } |
101 | 98 | ||
102 | void MediaWidget::loadSkin( const SkinButtonInfo *skinInfo, uint buttonCount, const QString &name, const QString &fileNameInfix ) | 99 | void MediaWidget::loadSkin( const SkinButtonInfo *skinInfo, uint buttonCount, const QString &name, const QString &fileNameInfix ) |
103 | { | 100 | { |
104 | Skin skin( name, fileNameInfix ); | 101 | Skin skin( name, fileNameInfix ); |
105 | 102 | ||
106 | QString skinPath = "opieplayer2/skins/" + name; | 103 | QString skinPath = "opieplayer2/skins/" + name; |
107 | backgroundPixmap = skin.backgroundImage(); | 104 | backgroundPixmap = skin.backgroundImage(); |
108 | buttonUpImage = skin.buttonUpImage(); | 105 | buttonUpImage = skin.buttonUpImage(); |
109 | buttonDownImage = skin.buttonDownImage(); | 106 | buttonDownImage = skin.buttonDownImage(); |
110 | 107 | ||
111 | setupButtons( skinInfo, buttonCount, | 108 | setupButtons( skinInfo, buttonCount, skin, buttonUpImage.size() ); |
112 | skinPath + QString::fromLatin1( "/skin%1_mask_" ).arg( fileNameInfix ), buttonUpImage.size() ); | ||
113 | } | 109 | } |
114 | 110 | ||
115 | void MediaWidget::closeEvent( QCloseEvent * ) | 111 | void MediaWidget::closeEvent( QCloseEvent * ) |
116 | { | 112 | { |
117 | mediaPlayerState.setList(); | 113 | mediaPlayerState.setList(); |
118 | } | 114 | } |
119 | 115 | ||
120 | void MediaWidget::paintEvent( QPaintEvent *pe ) | 116 | void MediaWidget::paintEvent( QPaintEvent *pe ) |
121 | { | 117 | { |
122 | QPainter p( this ); | 118 | QPainter p( this ); |
123 | 119 | ||
124 | if ( mediaPlayerState.isFullscreen() ) { | 120 | if ( mediaPlayerState.isFullscreen() ) { |
125 | // Clear the background | 121 | // Clear the background |
126 | p.setBrush( QBrush( Qt::black ) ); | 122 | p.setBrush( QBrush( Qt::black ) ); |
127 | return; | 123 | return; |
128 | } | 124 | } |
diff --git a/noncore/multimedia/opieplayer2/mediawidget.h b/noncore/multimedia/opieplayer2/mediawidget.h index 52b9fcb..0d635aa 100644 --- a/noncore/multimedia/opieplayer2/mediawidget.h +++ b/noncore/multimedia/opieplayer2/mediawidget.h | |||
@@ -30,32 +30,34 @@ | |||
30 | #include "playlistwidget.h" | 30 | #include "playlistwidget.h" |
31 | 31 | ||
32 | #include <vector> | 32 | #include <vector> |
33 | #include <memory> | 33 | #include <memory> |
34 | 34 | ||
35 | namespace | 35 | namespace |
36 | { | 36 | { |
37 | struct simpleAndStupidAllocator | 37 | struct simpleAndStupidAllocator |
38 | { | 38 | { |
39 | static void *allocate( size_t amount ) | 39 | static void *allocate( size_t amount ) |
40 | { return ::operator new( amount ); } | 40 | { return ::operator new( amount ); } |
41 | static void deallocate( void *p, size_t ) | 41 | static void deallocate( void *p, size_t ) |
42 | { ::operator delete( p ); } | 42 | { ::operator delete( p ); } |
43 | }; | 43 | }; |
44 | } | 44 | } |
45 | 45 | ||
46 | class Skin; | ||
47 | |||
46 | class MediaWidget : public QWidget | 48 | class MediaWidget : public QWidget |
47 | { | 49 | { |
48 | Q_OBJECT | 50 | Q_OBJECT |
49 | public: | 51 | public: |
50 | enum Command { Play = 0, Stop, Next, Previous, VolumeUp, VolumeDown, Loop, PlayList, Forward, Back, FullScreen, Undefined }; | 52 | enum Command { Play = 0, Stop, Next, Previous, VolumeUp, VolumeDown, Loop, PlayList, Forward, Back, FullScreen, Undefined }; |
51 | enum ButtonType { NormalButton, ToggleButton }; | 53 | enum ButtonType { NormalButton, ToggleButton }; |
52 | 54 | ||
53 | struct Button | 55 | struct Button |
54 | { | 56 | { |
55 | Button() : command( Undefined ), type( NormalButton ), isDown( false ) {} | 57 | Button() : command( Undefined ), type( NormalButton ), isDown( false ) {} |
56 | 58 | ||
57 | Command command; | 59 | Command command; |
58 | 60 | ||
59 | ButtonType type; // this should be part of the bitfield but gcc2 is too buggy to support this :-( | 61 | ButtonType type; // this should be part of the bitfield but gcc2 is too buggy to support this :-( |
60 | bool isDown : 1; | 62 | bool isDown : 1; |
61 | 63 | ||
@@ -87,35 +89,35 @@ public slots: | |||
87 | virtual void setPlaying( bool playing ) = 0; | 89 | virtual void setPlaying( bool playing ) = 0; |
88 | 90 | ||
89 | virtual void loadSkin() = 0; | 91 | virtual void loadSkin() = 0; |
90 | 92 | ||
91 | signals: | 93 | signals: |
92 | void moreReleased(); | 94 | void moreReleased(); |
93 | void lessReleased(); | 95 | void lessReleased(); |
94 | void forwardReleased(); | 96 | void forwardReleased(); |
95 | void backReleased(); | 97 | void backReleased(); |
96 | void forwardClicked(); | 98 | void forwardClicked(); |
97 | void backClicked(); | 99 | void backClicked(); |
98 | void moreClicked(); | 100 | void moreClicked(); |
99 | void lessClicked(); | 101 | void lessClicked(); |
100 | 102 | ||
101 | protected: | 103 | protected: |
102 | void setupButtons( const SkinButtonInfo *skinInfo, uint buttonCount, | 104 | void setupButtons( const SkinButtonInfo *skinInfo, uint buttonCount, |
103 | const QString &imagePrefix, const QSize &buttonAreaSize ); | 105 | const Skin &skin, const QSize &buttonAreaSize ); |
104 | Button setupButton( const SkinButtonInfo &buttonInfo, const QString &imagePrefix ); | 106 | Button setupButton( const SkinButtonInfo &buttonInfo, const Skin &skin ); |
105 | QBitmap setupButtonMask( const Command &command, const QString &fileName ); | 107 | QBitmap setupButtonMask( const Command &command, const QImage &maskImage ); |
106 | 108 | ||
107 | void loadDefaultSkin( const SkinButtonInfo *skinInfo, uint buttonCount, const QString &fileNameInfix = QString::null ); | 109 | void loadDefaultSkin( const SkinButtonInfo *skinInfo, uint buttonCount, const QString &fileNameInfix = QString::null ); |
108 | void loadSkin( const SkinButtonInfo *skinInfo, uint buttonCount, const QString &name, const QString &fileNameInfix ); | 110 | void loadSkin( const SkinButtonInfo *skinInfo, uint buttonCount, const QString &name, const QString &fileNameInfix ); |
109 | 111 | ||
110 | virtual void closeEvent( QCloseEvent * ); | 112 | virtual void closeEvent( QCloseEvent * ); |
111 | 113 | ||
112 | virtual void paintEvent( QPaintEvent *pe ); | 114 | virtual void paintEvent( QPaintEvent *pe ); |
113 | 115 | ||
114 | Button *buttonAt( const QPoint &position ); | 116 | Button *buttonAt( const QPoint &position ); |
115 | 117 | ||
116 | virtual void mousePressEvent( QMouseEvent *event ); | 118 | virtual void mousePressEvent( QMouseEvent *event ); |
117 | virtual void mouseReleaseEvent( QMouseEvent *event ); | 119 | virtual void mouseReleaseEvent( QMouseEvent *event ); |
118 | 120 | ||
119 | virtual void makeVisible(); | 121 | virtual void makeVisible(); |
120 | 122 | ||
121 | void handleCommand( Command command, bool buttonDown ); | 123 | void handleCommand( Command command, bool buttonDown ); |
diff --git a/noncore/multimedia/opieplayer2/skin.cpp b/noncore/multimedia/opieplayer2/skin.cpp index 352368f..fb1c9c4 100644 --- a/noncore/multimedia/opieplayer2/skin.cpp +++ b/noncore/multimedia/opieplayer2/skin.cpp | |||
@@ -11,18 +11,25 @@ Skin::Skin( const QString &name, const QString &fileNameInfix ) | |||
11 | 11 | ||
12 | QImage Skin::backgroundImage() const | 12 | QImage Skin::backgroundImage() const |
13 | { | 13 | { |
14 | return QImage( Resource::findPixmap( QString( "%1/background" ).arg( m_skinPath ) ) ); | 14 | return QImage( Resource::findPixmap( QString( "%1/background" ).arg( m_skinPath ) ) ); |
15 | } | 15 | } |
16 | 16 | ||
17 | QImage Skin::buttonUpImage() const | 17 | QImage Skin::buttonUpImage() const |
18 | { | 18 | { |
19 | return QImage( Resource::findPixmap( QString( "%1/skin%2_up" ).arg( m_skinPath ).arg( m_fileNameInfix ) ) ); | 19 | return QImage( Resource::findPixmap( QString( "%1/skin%2_up" ).arg( m_skinPath ).arg( m_fileNameInfix ) ) ); |
20 | } | 20 | } |
21 | 21 | ||
22 | QImage Skin::buttonDownImage() const | 22 | QImage Skin::buttonDownImage() const |
23 | { | 23 | { |
24 | return QImage( Resource::findPixmap( QString( "%1/skin%2_down" ).arg( m_skinPath ).arg( m_fileNameInfix ) ) ); | 24 | return QImage( Resource::findPixmap( QString( "%1/skin%2_down" ).arg( m_skinPath ).arg( m_fileNameInfix ) ) ); |
25 | } | 25 | } |
26 | 26 | ||
27 | QImage Skin::buttonMaskImage( const QString &fileName ) const | ||
28 | { | ||
29 | QString prefix = m_skinPath + QString::fromLatin1( "/skin%1_mask_" ).arg( m_fileNameInfix ); | ||
30 | QString path = prefix + fileName + ".png"; | ||
31 | return QImage( Resource::findPixmap( path ) ); | ||
32 | } | ||
33 | |||
27 | /* vim: et sw=4 ts=4 | 34 | /* vim: et sw=4 ts=4 |
28 | */ | 35 | */ |
diff --git a/noncore/multimedia/opieplayer2/skin.h b/noncore/multimedia/opieplayer2/skin.h index 85f9e57..f160b3c 100644 --- a/noncore/multimedia/opieplayer2/skin.h +++ b/noncore/multimedia/opieplayer2/skin.h | |||
@@ -1,27 +1,29 @@ | |||
1 | #ifndef SKIN_H | 1 | #ifndef SKIN_H |
2 | #define SKIN_H | 2 | #define SKIN_H |
3 | 3 | ||
4 | #include <qstring.h> | 4 | #include <qstring.h> |
5 | #include <qimage.h> | 5 | #include <qimage.h> |
6 | 6 | ||
7 | class Skin | 7 | class Skin |
8 | { | 8 | { |
9 | public: | 9 | public: |
10 | Skin( const QString &name, const QString &fileNameInfix ); | 10 | Skin( const QString &name, const QString &fileNameInfix ); |
11 | 11 | ||
12 | QImage backgroundImage() const; | 12 | QImage backgroundImage() const; |
13 | QImage buttonUpImage() const; | 13 | QImage buttonUpImage() const; |
14 | QImage buttonDownImage() const; | 14 | QImage buttonDownImage() const; |
15 | 15 | ||
16 | QImage buttonMaskImage( const QString &fileName ) const; | ||
17 | |||
16 | private: | 18 | private: |
17 | QString m_name; | 19 | QString m_name; |
18 | QString m_fileNameInfix; | 20 | QString m_fileNameInfix; |
19 | QString m_skinPath; | 21 | QString m_skinPath; |
20 | 22 | ||
21 | Skin( const Skin & ); | 23 | Skin( const Skin & ); |
22 | Skin &operator=( const Skin & ); | 24 | Skin &operator=( const Skin & ); |
23 | }; | 25 | }; |
24 | 26 | ||
25 | #endif // SKIN_H | 27 | #endif // SKIN_H |
26 | /* vim: et sw=4 ts=4 | 28 | /* vim: et sw=4 ts=4 |
27 | */ | 29 | */ |