summaryrefslogtreecommitdiff
Side-by-side diff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/multimedia/opieplayer2/skin.cpp31
-rw-r--r--noncore/multimedia/opieplayer2/skin.h12
2 files changed, 37 insertions, 6 deletions
diff --git a/noncore/multimedia/opieplayer2/skin.cpp b/noncore/multimedia/opieplayer2/skin.cpp
index fb1c9c4..7d05d80 100644
--- a/noncore/multimedia/opieplayer2/skin.cpp
+++ b/noncore/multimedia/opieplayer2/skin.cpp
@@ -8,28 +8,47 @@ Skin::Skin( const QString &name, const QString &fileNameInfix )
{
m_skinPath = "opieplayer2/skins/" + name;
}
+void Skin::preload( const MediaWidget::SkinButtonInfo *skinButtonInfo, uint buttonCount )
+{
+ backgroundImage();
+ buttonUpImage();
+ buttonDownImage();
+ for ( uint i = 0; i < buttonCount; ++i )
+ ( void )buttonMaskImage( skinButtonInfo[ i ].fileName );
+}
+
QImage Skin::backgroundImage() const
{
- return QImage( Resource::findPixmap( QString( "%1/background" ).arg( m_skinPath ) ) );
+ if ( m_backgroundImage.isNull() )
+ m_backgroundImage = QImage( Resource::findPixmap( QString( "%1/background" ).arg( m_skinPath ) ) );
+ return m_backgroundImage;
}
QImage Skin::buttonUpImage() const
{
- return QImage( Resource::findPixmap( QString( "%1/skin%2_up" ).arg( m_skinPath ).arg( m_fileNameInfix ) ) );
+ if ( m_buttonUpImage.isNull() )
+ m_buttonUpImage = QImage( Resource::findPixmap( QString( "%1/skin%2_up" ).arg( m_skinPath ).arg( m_fileNameInfix ) ) );
+ return m_buttonUpImage;
}
QImage Skin::buttonDownImage() const
{
- return QImage( Resource::findPixmap( QString( "%1/skin%2_down" ).arg( m_skinPath ).arg( m_fileNameInfix ) ) );
+ if ( m_buttonDownImage.isNull() )
+ m_buttonDownImage = QImage( Resource::findPixmap( QString( "%1/skin%2_down" ).arg( m_skinPath ).arg( m_fileNameInfix ) ) );
+ return m_buttonDownImage;
}
QImage Skin::buttonMaskImage( const QString &fileName ) const
{
- QString prefix = m_skinPath + QString::fromLatin1( "/skin%1_mask_" ).arg( m_fileNameInfix );
- QString path = prefix + fileName + ".png";
- return QImage( Resource::findPixmap( path ) );
+ ButtonMaskImageMap::Iterator it = m_buttonMasks.find( fileName );
+ if ( it == m_buttonMasks.end() ) {
+ QString prefix = m_skinPath + QString::fromLatin1( "/skin%1_mask_" ).arg( m_fileNameInfix );
+ QString path = prefix + fileName + ".png";
+ it = m_buttonMasks.insert( fileName, QImage( Resource::findPixmap( path ) ) );
+ }
+ return *it;
}
/* vim: et sw=4 ts=4
*/
diff --git a/noncore/multimedia/opieplayer2/skin.h b/noncore/multimedia/opieplayer2/skin.h
index f160b3c..9276a5b 100644
--- a/noncore/multimedia/opieplayer2/skin.h
+++ b/noncore/multimedia/opieplayer2/skin.h
@@ -2,14 +2,19 @@
#define SKIN_H
#include <qstring.h>
#include <qimage.h>
+#include <qmap.h>
+
+#include "mediawidget.h"
class Skin
{
public:
Skin( const QString &name, const QString &fileNameInfix );
+ void preload( const MediaWidget::SkinButtonInfo *skinButtonInfo, uint buttonCount );
+
QImage backgroundImage() const;
QImage buttonUpImage() const;
QImage buttonDownImage() const;
@@ -19,8 +24,15 @@ private:
QString m_name;
QString m_fileNameInfix;
QString m_skinPath;
+ typedef QMap<QString, QImage> ButtonMaskImageMap;
+
+ mutable QImage m_backgroundImage;
+ mutable QImage m_buttonUpImage;
+ mutable QImage m_buttonDownImage;
+ mutable ButtonMaskImageMap m_buttonMasks;
+
Skin( const Skin & );
Skin &operator=( const Skin & );
};