summaryrefslogtreecommitdiff
path: root/noncore/multimedia/opieplayer2/skin.cpp
authorsimon <simon>2002-12-11 12:47:06 (UTC)
committer simon <simon>2002-12-11 12:47:06 (UTC)
commitdd6a6d5345e191ffa6da3e015c4e024bd8ca67b7 (patch) (side-by-side diff)
tree565797ef0522be6d3cff893d8bc04c4378306c16 /noncore/multimedia/opieplayer2/skin.cpp
parent6f5e269efd9d6a5910251ce26750134e841f7b14 (diff)
downloadopie-dd6a6d5345e191ffa6da3e015c4e024bd8ca67b7.zip
opie-dd6a6d5345e191ffa6da3e015c4e024bd8ca67b7.tar.gz
opie-dd6a6d5345e191ffa6da3e015c4e024bd8ca67b7.tar.bz2
- button mask composing moved to Skin class
Diffstat (limited to 'noncore/multimedia/opieplayer2/skin.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/multimedia/opieplayer2/skin.cpp36
1 files changed, 33 insertions, 3 deletions
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
@@ -9,13 +9,12 @@ 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
@@ -39,6 +38,37 @@ QImage Skin::buttonDownImage() const
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 );