-rw-r--r-- | noncore/multimedia/opieplayer2/mediawidget.cpp | 24 | ||||
-rw-r--r-- | noncore/multimedia/opieplayer2/mediawidget.h | 1 | ||||
-rw-r--r-- | noncore/multimedia/opieplayer2/skin.cpp | 36 | ||||
-rw-r--r-- | noncore/multimedia/opieplayer2/skin.h | 7 |
4 files changed, 41 insertions, 27 deletions
diff --git a/noncore/multimedia/opieplayer2/mediawidget.cpp b/noncore/multimedia/opieplayer2/mediawidget.cpp index 4de7ea9..da0706e 100644 --- a/noncore/multimedia/opieplayer2/mediawidget.cpp +++ b/noncore/multimedia/opieplayer2/mediawidget.cpp @@ -45,10 +45,9 @@ MediaWidget::~MediaWidget() void MediaWidget::setupButtons( const SkinButtonInfo *skinInfo, uint buttonCount, const Skin &skin, const QSize &buttonAreaSize ) { - buttonMask = QImage( buttonAreaSize, 8, 255 ); - buttonMask.fill( 0 ); + buttonMask = skin.buttonMask( skinInfo, buttonCount, buttonAreaSize ); buttons.clear(); buttons.reserve( buttonCount ); @@ -62,32 +61,13 @@ MediaWidget::Button MediaWidget::setupButton( const SkinButtonInfo &buttonInfo, { Button button; button.command = buttonInfo.command; button.type = buttonInfo.type; - - button.mask = setupButtonMask( button.command, skin.buttonMaskImage( buttonInfo.fileName ) ); + button.mask = skin.buttonMaskImage( buttonInfo.fileName ); return button; } -QBitmap MediaWidget::setupButtonMask( const Command &command, const QImage &maskImage ) -{ - if ( maskImage.isNull() ) - return QBitmap(); - - uchar **dest = buttonMask.jumpTable(); - for ( int y = 0; y < buttonMask.height(); y++ ) { - uchar *line = dest[y]; - for ( int x = 0; x < buttonMask.width(); x++ ) - if ( !qRed( maskImage.pixel( x, y ) ) ) - line[x] = command + 1; - } - - // ### grmbl qt2. use constructor when switching to qt3. - QBitmap bm; bm = maskImage; - return bm; -} - void MediaWidget::loadDefaultSkin( const SkinButtonInfo *skinInfo, uint buttonCount, const QString &fileNameInfix ) { Config cfg( "OpiePlayer" ); cfg.setGroup( "Options" ); diff --git a/noncore/multimedia/opieplayer2/mediawidget.h b/noncore/multimedia/opieplayer2/mediawidget.h index 0d635aa..4bd8760 100644 --- a/noncore/multimedia/opieplayer2/mediawidget.h +++ b/noncore/multimedia/opieplayer2/mediawidget.h @@ -103,9 +103,8 @@ signals: protected: void setupButtons( const SkinButtonInfo *skinInfo, uint buttonCount, const Skin &skin, const QSize &buttonAreaSize ); Button setupButton( const SkinButtonInfo &buttonInfo, const Skin &skin ); - QBitmap setupButtonMask( const Command &command, const QImage &maskImage ); void loadDefaultSkin( const SkinButtonInfo *skinInfo, uint buttonCount, const QString &fileNameInfix = QString::null ); void loadSkin( const SkinButtonInfo *skinInfo, uint buttonCount, const QString &name, const QString &fileNameInfix ); diff --git a/noncore/multimedia/opieplayer2/skin.cpp b/noncore/multimedia/opieplayer2/skin.cpp index 7d05d80..ef70957 100644 --- a/noncore/multimedia/opieplayer2/skin.cpp +++ b/noncore/multimedia/opieplayer2/skin.cpp @@ -8,15 +8,14 @@ Skin::Skin( const QString &name, const QString &fileNameInfix ) { m_skinPath = "opieplayer2/skins/" + name; } -void Skin::preload( const MediaWidget::SkinButtonInfo *skinButtonInfo, uint buttonCount ) +void Skin::preload( const MediaWidget::SkinButtonInfo *skinButtonInfo, uint buttonCount, const QSize &buttonAreaSize ) { backgroundImage(); buttonUpImage(); buttonDownImage(); - for ( uint i = 0; i < buttonCount; ++i ) - ( void )buttonMaskImage( skinButtonInfo[ i ].fileName ); + ( void )buttonMask( skinButtonInfo, buttonCount, buttonAreaSize ); } QImage Skin::backgroundImage() const { @@ -38,8 +37,39 @@ QImage Skin::buttonDownImage() const m_buttonDownImage = QImage( Resource::findPixmap( QString( "%1/skin%2_down" ).arg( m_skinPath ).arg( m_fileNameInfix ) ) ); return m_buttonDownImage; } +QImage Skin::buttonMask( const MediaWidget::SkinButtonInfo *skinButtonInfo, uint buttonCount, const QSize &buttonAreaSize ) const +{ + if ( buttonAreaSize != m_buttonMask.size() ) + m_buttonMask = QImage(); + + if ( !m_buttonMask.isNull() ) + return m_buttonMask; + + m_buttonMask = QImage( buttonAreaSize, 8, 255 ); + m_buttonMask.fill( 0 ); + + for ( uint i = 0; i < buttonCount; ++i ) + addButtonToMask( skinButtonInfo[ i ].command + 1, buttonMaskImage( skinButtonInfo[ i ].fileName ) ); + + return m_buttonMask; +} + +void Skin::addButtonToMask( int tag, const QImage &maskImage ) const +{ + if ( maskImage.isNull() ) + return; + + uchar **dest = m_buttonMask.jumpTable(); + for ( int y = 0; y < m_buttonMask.height(); y++ ) { + uchar *line = dest[y]; + for ( int x = 0; x < m_buttonMask.width(); x++ ) + if ( !qRed( maskImage.pixel( x, y ) ) ) + line[x] = tag; + } +} + QImage Skin::buttonMaskImage( const QString &fileName ) const { ButtonMaskImageMap::Iterator it = m_buttonMasks.find( fileName ); if ( it == m_buttonMasks.end() ) { diff --git a/noncore/multimedia/opieplayer2/skin.h b/noncore/multimedia/opieplayer2/skin.h index 9276a5b..14873e7 100644 --- a/noncore/multimedia/opieplayer2/skin.h +++ b/noncore/multimedia/opieplayer2/skin.h @@ -11,17 +11,21 @@ class Skin { public: Skin( const QString &name, const QString &fileNameInfix ); - void preload( const MediaWidget::SkinButtonInfo *skinButtonInfo, uint buttonCount ); + void preload( const MediaWidget::SkinButtonInfo *skinButtonInfo, uint buttonCount, const QSize &buttonAreaSize ); QImage backgroundImage() const; QImage buttonUpImage() const; QImage buttonDownImage() const; + QImage buttonMask( const MediaWidget::SkinButtonInfo *skinButtonInfo, uint buttonCount, const QSize &buttonAreaSize ) const; + QImage buttonMaskImage( const QString &fileName ) const; private: + void addButtonToMask( int tag, const QImage &maskImage ) const; + QString m_name; QString m_fileNameInfix; QString m_skinPath; @@ -29,8 +33,9 @@ private: mutable QImage m_backgroundImage; mutable QImage m_buttonUpImage; mutable QImage m_buttonDownImage; + mutable QImage m_buttonMask; mutable ButtonMaskImageMap m_buttonMasks; Skin( const Skin & ); Skin &operator=( const Skin & ); |