summaryrefslogtreecommitdiff
path: root/library/resource.cpp
Unidiff
Diffstat (limited to 'library/resource.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--library/resource.cpp8
1 files changed, 6 insertions, 2 deletions
diff --git a/library/resource.cpp b/library/resource.cpp
index dc19880..0915c45 100644
--- a/library/resource.cpp
+++ b/library/resource.cpp
@@ -1,136 +1,140 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000 Trolltech AS. All rights reserved. 2** Copyright (C) 2000 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qtopia Environment. 4** This file is part of Qtopia Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20 20
21#include "qpeapplication.h" 21#include "qpeapplication.h"
22#include "resource.h" 22#include "resource.h"
23#include <qdir.h> 23#include <qdir.h>
24#include <qfile.h> 24#include <qfile.h>
25#include <qregexp.h> 25#include <qregexp.h>
26#include <qpixmapcache.h> 26#include <qpixmapcache.h>
27#include <qpainter.h> 27#include <qpainter.h>
28 28
29#include "inlinepics_p.h" 29#include "inlinepics_p.h"
30 30
31/*! 31/*!
32 \class Resource resource.h 32 \class Resource resource.h
33 \brief The Resource class provides access to named resources. 33 \brief The Resource class provides access to named resources.
34 34
35 The resources may be provided from files or other sources. 35 The resources may be provided from files or other sources.
36*/ 36*/
37 37
38/*! 38/*!
39 \fn Resource::Resource() 39 \fn Resource::Resource()
40 \internal 40 \internal
41*/ 41*/
42 42
43/*! 43/*!
44 Returns the QPixmap named \a pix. You should avoid including 44 Returns the QPixmap named \a pix. You should avoid including
45 any filename type extension (eg. .png, .xpm). 45 any filename type extension (eg. .png, .xpm).
46*/ 46*/
47QPixmap Resource::loadPixmap( const QString &pix ) 47QPixmap Resource::loadPixmap( const QString &pix )
48{ 48{
49 QPixmap pm; 49 QPixmap pm;
50 QString key="QPE_"+pix; 50 QString key="QPE_"+pix;
51 if ( !QPixmapCache::find(key,pm) ) { 51 if ( !QPixmapCache::find(key,pm) ) {
52 pm.convertFromImage(loadImage(pix)); 52 pm.convertFromImage(loadImage(pix));
53 QPixmapCache::insert(key,pm); 53 QPixmapCache::insert(key,pm);
54 } 54 }
55 return pm; 55 return pm;
56} 56}
57 57
58/*! 58/*!
59 Returns the QBitmap named \a pix. You should avoid including 59 Returns the QBitmap named \a pix. You should avoid including
60 any filename type extension (eg. .png, .xpm). 60 any filename type extension (eg. .png, .xpm).
61*/ 61*/
62QBitmap Resource::loadBitmap( const QString &pix ) 62QBitmap Resource::loadBitmap( const QString &pix )
63{ 63{
64 QBitmap bm; 64 QBitmap bm;
65 bm = loadPixmap(pix); 65 bm = loadPixmap(pix);
66 return bm; 66 return bm;
67} 67}
68 68
69/*! 69/*!
70 Returns the filename of a pixmap named \a pix. You should avoid including 70 Returns the filename of a pixmap named \a pix. You should avoid including
71 any filename type extension (eg. .png, .xpm). 71 any filename type extension (eg. .png, .xpm .jpg .jpeg).
72 72
73 Normally you will use loadPixmap() rather than this function. 73 Normally you will use loadPixmap() rather than this function.
74*/ 74*/
75QString Resource::findPixmap( const QString &pix ) 75QString Resource::findPixmap( const QString &pix )
76{ 76{
77 QString picsPath = QPEApplication::qpeDir() + "pics/"; 77 QString picsPath = QPEApplication::qpeDir() + "pics/";
78 78
79 if ( QFile( picsPath + pix + ".png").exists() ) 79 if ( QFile( picsPath + pix + ".png").exists() )
80 return picsPath + pix + ".png"; 80 return picsPath + pix + ".png";
81 else if ( QFile( picsPath + pix + ".jpeg").exists() )
82 return picsPath + pix + ".jpeg";
83 else if ( QFile( picsPath + pix + ".jpg").exists() )
84 return picsPath + pix + ".jpg";
81 else if ( QFile( picsPath + pix + ".xpm").exists() ) 85 else if ( QFile( picsPath + pix + ".xpm").exists() )
82 return picsPath + pix + ".xpm"; 86 return picsPath + pix + ".xpm";
83 else if ( QFile( picsPath + pix ).exists() ) 87 else if ( QFile( picsPath + pix ).exists() )
84 return picsPath + pix; 88 return picsPath + pix;
85 89
86 //qDebug("Cannot find pixmap: %s", pix.latin1()); 90 //qDebug("Cannot find pixmap: %s", pix.latin1());
87 return QString(); 91 return QString();
88} 92}
89 93
90/*! 94/*!
91 Returns a sound file for a sound named \a name. 95 Returns a sound file for a sound named \a name.
92 You should avoid including any filename type extension (eg. .wav, .au, .mp3). 96 You should avoid including any filename type extension (eg. .wav, .au, .mp3).
93*/ 97*/
94QString Resource::findSound( const QString &name ) 98QString Resource::findSound( const QString &name )
95{ 99{
96 QString picsPath = QPEApplication::qpeDir() + "sounds/"; 100 QString picsPath = QPEApplication::qpeDir() + "sounds/";
97 101
98 QString result; 102 QString result;
99 if ( QFile( (result = picsPath + name + ".wav") ).exists() ) 103 if ( QFile( (result = picsPath + name + ".wav") ).exists() )
100 return result; 104 return result;
101 105
102 return QString(); 106 return QString();
103} 107}
104 108
105/*! 109/*!
106 Returns a list of all sound names. 110 Returns a list of all sound names.
107*/ 111*/
108QStringList Resource::allSounds() 112QStringList Resource::allSounds()
109{ 113{
110 QDir resourcedir( QPEApplication::qpeDir() + "sounds/", "*.wav" ); 114 QDir resourcedir( QPEApplication::qpeDir() + "sounds/", "*.wav" );
111 QStringList entries = resourcedir.entryList(); 115 QStringList entries = resourcedir.entryList();
112 QStringList result; 116 QStringList result;
113 for (QStringList::Iterator i=entries.begin(); i != entries.end(); ++i) 117 for (QStringList::Iterator i=entries.begin(); i != entries.end(); ++i)
114 result.append((*i).replace(QRegExp("\\.wav"),"")); 118 result.append((*i).replace(QRegExp("\\.wav"),""));
115 return result; 119 return result;
116} 120}
117 121
118/*! 122/*!
119 Returns the QImage named \a name. You should avoid including 123 Returns the QImage named \a name. You should avoid including
120 any filename type extension (eg. .png, .xpm). 124 any filename type extension (eg. .png, .xpm .jpg).
121*/ 125*/
122QImage Resource::loadImage( const QString &name) 126QImage Resource::loadImage( const QString &name)
123{ 127{
124 QImage img = qembed_findImage(name.latin1()); 128 QImage img = qembed_findImage(name.latin1());
125 if ( img.isNull() ) 129 if ( img.isNull() )
126 return QImage(findPixmap(name)); 130 return QImage(findPixmap(name));
127 return img; 131 return img;
128} 132}
129 133
130/*! 134/*!
131 \fn QIconSet Resource::loadIconSet( const QString &name ) 135 \fn QIconSet Resource::loadIconSet( const QString &name )
132 136
133 Returns a QIconSet for the pixmap named \a name. A disabled icon is 137 Returns a QIconSet for the pixmap named \a name. A disabled icon is
134 generated that conforms to the Qtopia look & feel. You should avoid 138 generated that conforms to the Qtopia look & feel. You should avoid
135 including any filename type extension (eg. .png, .xpm). 139 including any filename type extension (eg. .png, .xpm).
136*/ 140*/