summaryrefslogtreecommitdiff
authorsandman <sandman>2002-09-30 23:06:39 (UTC)
committer sandman <sandman>2002-09-30 23:06:39 (UTC)
commit37a8266f4a32d07a27d453897febf1f25963a4d0 (patch) (unidiff)
tree38f41045da51b99b76a69b42beaafd0124564cc9
parent6fdaab436d4fa72b3de06a1a9cf9be0bd964677a (diff)
downloadopie-37a8266f4a32d07a27d453897febf1f25963a4d0.zip
opie-37a8266f4a32d07a27d453897febf1f25963a4d0.tar.gz
opie-37a8266f4a32d07a27d453897febf1f25963a4d0.tar.bz2
- again some speedups for the new busy indicator
- (inefficient) fix for background pixmaps with alpha channel (untested)
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/launcher/launcherview.cpp53
1 files changed, 30 insertions, 23 deletions
diff --git a/core/launcher/launcherview.cpp b/core/launcher/launcherview.cpp
index 5daaeff..33717bc 100644
--- a/core/launcher/launcherview.cpp
+++ b/core/launcher/launcherview.cpp
@@ -1,465 +1,472 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. 2** Copyright (C) 2000-2002 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of the Qtopia Environment. 4** This file is part of the 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 "launcherview.h" 21#include "launcherview.h"
22 22
23#include <qpe/qpeapplication.h> 23#include <qpe/qpeapplication.h>
24#include <qpe/applnk.h> 24#include <qpe/applnk.h>
25#include <qpe/qpedebug.h> 25#include <qpe/qpedebug.h>
26#include <qpe/categories.h> 26#include <qpe/categories.h>
27#include <qpe/categoryselect.h> 27#include <qpe/categoryselect.h>
28#include <qpe/menubutton.h> 28#include <qpe/menubutton.h>
29#include <qpe/mimetype.h> 29#include <qpe/mimetype.h>
30#include <qpe/resource.h> 30#include <qpe/resource.h>
31#include <qpe/qpetoolbar.h> 31#include <qpe/qpetoolbar.h>
32//#include <qtopia/private/palmtoprecord.h> 32//#include <qtopia/private/palmtoprecord.h>
33 33
34#include <qtimer.h> 34#include <qtimer.h>
35#include <qtextstream.h> 35#include <qtextstream.h>
36#include <qdict.h> 36#include <qdict.h>
37#include <qfile.h> 37#include <qfile.h>
38#include <qfileinfo.h> 38#include <qfileinfo.h>
39#include <qhbox.h> 39#include <qhbox.h>
40#include <qiconview.h> 40#include <qiconview.h>
41#include <qpainter.h> 41#include <qpainter.h>
42#include <qregexp.h> 42#include <qregexp.h>
43#include <qtoolbutton.h> 43#include <qtoolbutton.h>
44#include <qimage.h> 44#include <qimage.h>
45 45
46 46
47class BgPixmap 47class BgPixmap
48{ 48{
49public: 49public:
50 BgPixmap( const QPixmap &p ) : pm(p), ref(1) {} 50 BgPixmap( const QPixmap &p ) : pm(p), ref(1) {}
51 QPixmap pm; 51 QPixmap pm;
52 int ref; 52 int ref;
53}; 53};
54 54
55static QMap<QString,BgPixmap*> *bgCache = 0; 55static QMap<QString,BgPixmap*> *bgCache = 0;
56 56
57class LauncherIconView : public QIconView { 57class LauncherIconView : public QIconView {
58public: 58public:
59 LauncherIconView( QWidget* parent, const char* name=0 ) : 59 LauncherIconView( QWidget* parent, const char* name=0 ) :
60 QIconView(parent,name), 60 QIconView(parent,name),
61 tf(""), 61 tf(""),
62 cf(0), 62 cf(0),
63 bsy(0), 63 bsy(0),
64 bigIcns(TRUE), 64 bigIcns(TRUE),
65 bgColor(white) 65 bgColor(white)
66 { 66 {
67 sortmeth = Name; 67 sortmeth = Name;
68 hidden.setAutoDelete(TRUE); 68 hidden.setAutoDelete(TRUE);
69 ike = FALSE; 69 ike = FALSE;
70 busytimer = 0; 70 busytimer = 0;
71 calculateGrid( Bottom ); 71 calculateGrid( Bottom );
72 } 72 }
73 73
74 ~LauncherIconView() 74 ~LauncherIconView()
75 { 75 {
76#if 0 // debuggery 76#if 0 // debuggery
77 QListIterator<AppLnk> it(hidden); 77 QListIterator<AppLnk> it(hidden);
78 AppLnk* l; 78 AppLnk* l;
79 while ((l=it.current())) { 79 while ((l=it.current())) {
80 ++it; 80 ++it;
81 //qDebug("%p: hidden (should remove)",l); 81 //qDebug("%p: hidden (should remove)",l);
82 } 82 }
83#endif 83#endif
84 } 84 }
85 85
86 QPixmap* busyPixmap() const { return (QPixmap*)&bpm[::abs(busystate)]; } 86 QPixmap* busyPixmap() const { return (QPixmap*)&bpm[::abs(busystate)]; }
87 QIconViewItem* busyItem() const { return bsy; } 87 QIconViewItem* busyItem() const { return bsy; }
88 void setBigIcons( bool bi ) { bigIcns = bi; } 88 void setBigIcons( bool bi ) { bigIcns = bi; }
89 89
90 void updateCategoriesAndMimeTypes(); 90 void updateCategoriesAndMimeTypes();
91 91
92 void doAutoScroll() 92 void doAutoScroll()
93 { 93 {
94 // We don't want rubberbanding (yet) 94 // We don't want rubberbanding (yet)
95 } 95 }
96 96
97 void setBusy(bool on) 97 void setBusy(bool on)
98 { 98 {
99 QIconViewItem *c = on ? currentItem() : 0; 99 QIconViewItem *c = on ? currentItem() : 0;
100 qDebug ( "set busy %d -> %s", on, c ? c-> text ().latin1() : "(null)" );
101
100 if ( bsy != c ) { 102 if ( bsy != c ) {
101 if ( bsy ) 103 QIconViewItem *oldbsy = bsy;
102 bsy-> repaint ( );
103 bsy = c; 104 bsy = c;
104 105
106 if ( oldbsy )
107 oldbsy-> repaint ( );
108
105 if ( bsy ) { 109 if ( bsy ) {
106 busystate = 5; 110 QPixmap *src = bsy-> QIconViewItem::pixmap();
107 for ( int i = 0; i <= 5; i++ ) 111 for ( int i = 0; i <= 5; i++ ) {
108 bpm [i] = QPixmap ( );
109 timerEvent ( 0 );
110 busytimer = startTimer ( 150 );
111 }
112 else
113 killTimer ( busytimer );
114 }
115 }
116
117 virtual void timerEvent ( QTimerEvent *te )
118 {
119 if ( !te || ( te-> timerId ( ) == busytimer )) {
120 if ( bsy ) {
121 if ( bpm [::abs(busystate)]. isNull ( )) {
122 QPixmap *src = bsy-> QIconViewItem::pixmap();
123 QImage img = src->convertToImage(); 112 QImage img = src->convertToImage();
124 QRgb* rgb; 113 QRgb* rgb;
125 int count; 114 int count;
126 if ( img.depth() == 32 ) { 115 if ( img.depth() == 32 ) {
127 rgb = (QRgb*)img.bits(); 116 rgb = (QRgb*)img.bits();
128 count = img.bytesPerLine()/sizeof(QRgb)*img.height(); 117 count = img.bytesPerLine()/sizeof(QRgb)*img.height();
129 } else { 118 } else {
130 rgb = img.colorTable(); 119 rgb = img.colorTable();
131 count = img.numColors(); 120 count = img.numColors();
132 } 121 }
133 int rc, gc, bc; 122 int rc, gc, bc;
134 int bs = ::abs ( busystate * 10 ) + 25; 123 int bs = ::abs ( i * 10 ) + 25;
135 colorGroup().highlight().rgb( &rc, &gc, &bc ); 124 colorGroup().highlight().rgb( &rc, &gc, &bc );
136 rc = rc * bs / 100; 125 rc = rc * bs / 100;
137 gc = gc * bs / 100; 126 gc = gc * bs / 100;
138 bc = bc * bs / 100; 127 bc = bc * bs / 100;
139 128
140 for ( int r = 0; r < count; r++, rgb++ ) { 129 for ( int r = 0; r < count; r++, rgb++ ) {
141 int ri = rc + qRed ( *rgb ) * ( 100 - bs ) / 100; 130 int ri = rc + qRed ( *rgb ) * ( 100 - bs ) / 100;
142 int gi = gc + qGreen ( *rgb ) * ( 100 - bs ) / 100; 131 int gi = gc + qGreen ( *rgb ) * ( 100 - bs ) / 100;
143 int bi = bc + qBlue ( *rgb ) * ( 100 - bs ) / 100; 132 int bi = bc + qBlue ( *rgb ) * ( 100 - bs ) / 100;
144 int ai = qAlpha ( *rgb ); 133 int ai = qAlpha ( *rgb );
145 *rgb = qRgba ( ri, gi, bi, ai ); 134 *rgb = qRgba ( ri, gi, bi, ai );
146 } 135 }
147 136
148 bpm [::abs(busystate)].convertFromImage( img ); 137 bpm [i].convertFromImage( img );
149 } 138 }
150 bsy-> repaint ( ); 139 busystate = 0;
140 if ( busytimer )
141 killTimer ( busytimer );
142 timerEvent ( 0 );
143 busytimer = startTimer ( 180 );
144 }
145 else {
146 killTimer ( busytimer );
147 busytimer = 0;
148 }
149 }
150 }
151 151
152 virtual void timerEvent ( QTimerEvent *te )
153 {
154 if ( !te || ( te-> timerId ( ) == busytimer )) {
155 if ( bsy ) {
152 busystate++; 156 busystate++;
153 if ( busystate > 5 ) 157 if ( busystate > 5 )
154 busystate = -4; 158 busystate = -4;
159
160 bsy-> repaint ( );
155 } 161 }
156 } 162 }
157 } 163 }
158 164
159 bool inKeyEvent() const { return ike; } 165 bool inKeyEvent() const { return ike; }
160 void keyPressEvent(QKeyEvent* e) 166 void keyPressEvent(QKeyEvent* e)
161 { 167 {
162 ike = TRUE; 168 ike = TRUE;
163 if ( e->key() == Key_F33 /* OK button */ || e->key() == Key_Space ) 169 if ( e->key() == Key_F33 /* OK button */ || e->key() == Key_Space )
164 returnPressed(currentItem()); 170 returnPressed(currentItem());
165 QIconView::keyPressEvent(e); 171 QIconView::keyPressEvent(e);
166 ike = FALSE; 172 ike = FALSE;
167 } 173 }
168 174
169 void addItem(AppLnk* app, bool resort=TRUE); 175 void addItem(AppLnk* app, bool resort=TRUE);
170 bool removeLink(const QString& linkfile); 176 bool removeLink(const QString& linkfile);
171 177
172 QStringList mimeTypes() const; 178 QStringList mimeTypes() const;
173 QStringList categories() const; 179 QStringList categories() const;
174 180
175 void clear() 181 void clear()
176 { 182 {
177 mimes.clear(); 183 mimes.clear();
178 cats.clear(); 184 cats.clear();
179 QIconView::clear(); 185 QIconView::clear();
180 hidden.clear(); 186 hidden.clear();
181 } 187 }
182 188
183 void addCatsAndMimes(AppLnk* app) 189 void addCatsAndMimes(AppLnk* app)
184 { 190 {
185 // QStringList c = app->categories(); 191 // QStringList c = app->categories();
186 // for (QStringList::ConstIterator cit=c.begin(); cit!=c.end(); ++cit) { 192 // for (QStringList::ConstIterator cit=c.begin(); cit!=c.end(); ++cit) {
187 // cats.replace(*cit,(void*)1); 193 // cats.replace(*cit,(void*)1);
188 // } 194 // }
189 QString maj=app->type(); 195 QString maj=app->type();
190 int sl=maj.find('/'); 196 int sl=maj.find('/');
191 if (sl>=0) { 197 if (sl>=0) {
192 QString k; 198 QString k;
193 k = maj.left(12) == "application/" ? maj : maj.left(sl); 199 k = maj.left(12) == "application/" ? maj : maj.left(sl);
194 mimes.replace(k,(void*)1); 200 mimes.replace(k,(void*)1);
195 } 201 }
196 } 202 }
197 203
198 void setBackgroundPixmap( const QPixmap &pm ) { 204 void setBackgroundPixmap( const QPixmap &pm ) {
199 bgPixmap = pm; 205 bgPixmap = pm;
200 } 206 }
201 207
202 void setBackgroundColor( const QColor &c ) { 208 void setBackgroundColor( const QColor &c ) {
203 bgColor = c; 209 bgColor = c;
204 } 210 }
205 211
206 void drawBackground( QPainter *p, const QRect &r ) 212 void drawBackground( QPainter *p, const QRect &r )
207 { 213 {
208 if ( !bgPixmap.isNull() ) { 214 if ( !bgPixmap.isNull() ) {
209 p->drawTiledPixmap( r, bgPixmap, 215 p-> fillRect ( r, bgColor );
216 p->drawTiledPixmap( r, bgPixmap,
210 QPoint( (r.x() + contentsX()) % bgPixmap.width(), 217 QPoint( (r.x() + contentsX()) % bgPixmap.width(),
211 (r.y() + contentsY()) % bgPixmap.height() ) ); 218 (r.y() + contentsY()) % bgPixmap.height() ) );
212 } else { 219 } else {
213 p->fillRect( r, bgColor ); 220 p->fillRect( r, bgColor );
214 } 221 }
215 } 222 }
216 223
217 void setItemTextPos( ItemTextPos pos ) 224 void setItemTextPos( ItemTextPos pos )
218 { 225 {
219 calculateGrid( pos ); 226 calculateGrid( pos );
220 QIconView::setItemTextPos( pos ); 227 QIconView::setItemTextPos( pos );
221 } 228 }
222 229
223 void hideOrShowItems(bool resort); 230 void hideOrShowItems(bool resort);
224 231
225 void setTypeFilter(const QString& typefilter, bool resort) 232 void setTypeFilter(const QString& typefilter, bool resort)
226 { 233 {
227 tf = QRegExp(typefilter,FALSE,TRUE); 234 tf = QRegExp(typefilter,FALSE,TRUE);
228 hideOrShowItems(resort); 235 hideOrShowItems(resort);
229 } 236 }
230 237
231 void setCategoryFilter( int catfilter, bool resort ) 238 void setCategoryFilter( int catfilter, bool resort )
232 { 239 {
233 Categories cat; 240 Categories cat;
234 cat.load( categoryFileName() ); 241 cat.load( categoryFileName() );
235 QString str; 242 QString str;
236 if ( catfilter == -2 ) 243 if ( catfilter == -2 )
237 cf = 0; 244 cf = 0;
238 else 245 else
239 cf = catfilter; 246 cf = catfilter;
240 hideOrShowItems(resort); 247 hideOrShowItems(resort);
241 } 248 }
242 249
243 enum SortMethod { Name, Date, Type }; 250 enum SortMethod { Name, Date, Type };
244 251
245 void setSortMethod( SortMethod m ) 252 void setSortMethod( SortMethod m )
246 { 253 {
247 if ( sortmeth != m ) { 254 if ( sortmeth != m ) {
248 sortmeth = m; 255 sortmeth = m;
249 sort(); 256 sort();
250 } 257 }
251 } 258 }
252 259
253 int compare(const AppLnk* a, const AppLnk* b) 260 int compare(const AppLnk* a, const AppLnk* b)
254 { 261 {
255 switch (sortmeth) { 262 switch (sortmeth) {
256 case Name: 263 case Name:
257 return a->name().compare(b->name()); 264 return a->name().compare(b->name());
258 case Date: { 265 case Date: {
259 QFileInfo fa(a->linkFileKnown() ? a->linkFile() : a->file()); 266 QFileInfo fa(a->linkFileKnown() ? a->linkFile() : a->file());
260 QFileInfo fb(b->linkFileKnown() ? b->linkFile() : b->file()); 267 QFileInfo fb(b->linkFileKnown() ? b->linkFile() : b->file());
261 return fa.lastModified().secsTo(fb.lastModified()); 268 return fa.lastModified().secsTo(fb.lastModified());
262 } 269 }
263 case Type: 270 case Type:
264 return a->type().compare(b->type()); 271 return a->type().compare(b->type());
265 } 272 }
266 return 0; 273 return 0;
267 } 274 }
268 275
269 QString getAllDocLinkInfo() const; 276 QString getAllDocLinkInfo() const;
270 277
271protected: 278protected:
272 279
273 void styleChange( QStyle &old ) 280 void styleChange( QStyle &old )
274 { 281 {
275 QIconView::styleChange( old ); 282 QIconView::styleChange( old );
276 calculateGrid( itemTextPos() ); 283 calculateGrid( itemTextPos() );
277 } 284 }
278 285
279 void calculateGrid( ItemTextPos pos ) 286 void calculateGrid( ItemTextPos pos )
280 { 287 {
281 int dw = QApplication::desktop()->width(); 288 int dw = QApplication::desktop()->width();
282 int viewerWidth = dw-style().scrollBarExtent().width(); 289 int viewerWidth = dw-style().scrollBarExtent().width();
283 if ( pos == Bottom ) { 290 if ( pos == Bottom ) {
284 int cols = 3; 291 int cols = 3;
285 if ( viewerWidth <= 200 ) 292 if ( viewerWidth <= 200 )
286 cols = 2; 293 cols = 2;
287 else if ( viewerWidth >= 400 ) 294 else if ( viewerWidth >= 400 )
288 cols = viewerWidth/96; 295 cols = viewerWidth/96;
289 setSpacing( 4 ); 296 setSpacing( 4 );
290 setGridX( (viewerWidth-(cols+1)*spacing())/cols ); 297 setGridX( (viewerWidth-(cols+1)*spacing())/cols );
291 setGridY( fontMetrics().height()*2+24 ); 298 setGridY( fontMetrics().height()*2+24 );
292 } else { 299 } else {
293 int cols = 2; 300 int cols = 2;
294 if ( viewerWidth < 150 ) 301 if ( viewerWidth < 150 )
295 cols = 1; 302 cols = 1;
296 else if ( viewerWidth >= 400 ) 303 else if ( viewerWidth >= 400 )
297 cols = viewerWidth/150; 304 cols = viewerWidth/150;
298 setSpacing( 2 ); 305 setSpacing( 2 );
299 setGridX( (viewerWidth-(cols+1)*spacing())/cols ); 306 setGridX( (viewerWidth-(cols+1)*spacing())/cols );
300 setGridY( fontMetrics().height()+2 ); 307 setGridY( fontMetrics().height()+2 );
301 } 308 }
302 } 309 }
303 310
304private: 311private:
305 QList<AppLnk> hidden; 312 QList<AppLnk> hidden;
306 QDict<void> mimes; 313 QDict<void> mimes;
307 QDict<void> cats; 314 QDict<void> cats;
308 SortMethod sortmeth; 315 SortMethod sortmeth;
309 QRegExp tf; 316 QRegExp tf;
310 int cf; 317 int cf;
311 QIconViewItem* bsy; 318 QIconViewItem* bsy;
312 bool ike; 319 bool ike;
313 bool bigIcns; 320 bool bigIcns;
314 QPixmap bgPixmap; 321 QPixmap bgPixmap;
315 QPixmap bpm [6]; 322 QPixmap bpm [6];
316 QColor bgColor; 323 QColor bgColor;
317 int busytimer; 324 int busytimer;
318 int busystate; 325 int busystate;
319}; 326};
320 327
321 328
322bool LauncherView::bsy=FALSE; 329bool LauncherView::bsy=FALSE;
323 330
324void LauncherView::setBusy(bool on) 331void LauncherView::setBusy(bool on)
325{ 332{
326 icons->setBusy(on); 333 icons->setBusy(on);
327} 334}
328 335
329class LauncherItem : public QIconViewItem 336class LauncherItem : public QIconViewItem
330{ 337{
331public: 338public:
332 LauncherItem( QIconView *parent, AppLnk* applnk, bool bigIcon=TRUE ); 339 LauncherItem( QIconView *parent, AppLnk* applnk, bool bigIcon=TRUE );
333 ~LauncherItem() 340 ~LauncherItem()
334 { 341 {
335 LauncherIconView* liv = (LauncherIconView*)iconView(); 342 LauncherIconView* liv = (LauncherIconView*)iconView();
336 if ( liv->busyItem() == this ) 343 if ( liv->busyItem() == this )
337 liv->setBusy(FALSE); 344 liv->setBusy(FALSE);
338 delete app; 345 delete app;
339 } 346 }
340 347
341 AppLnk* appLnk() const { return app; } 348 AppLnk* appLnk() const { return app; }
342 AppLnk* takeAppLnk() { AppLnk* r=app; app=0; return r; } 349 AppLnk* takeAppLnk() { AppLnk* r=app; app=0; return r; }
343 350
344 virtual int compare ( QIconViewItem * i ) const; 351 virtual int compare ( QIconViewItem * i ) const;
345 352
346 void paintItem( QPainter *p, const QColorGroup &cg ) 353 void paintItem( QPainter *p, const QColorGroup &cg )
347 { 354 {
348 LauncherIconView* liv = (LauncherIconView*)iconView(); 355 LauncherIconView* liv = (LauncherIconView*)iconView();
349 QBrush oldBrush( liv->itemTextBackground() ); 356 QBrush oldBrush( liv->itemTextBackground() );
350 QColorGroup mycg( cg ); 357 QColorGroup mycg( cg );
351 if ( liv->currentItem() == this ) { 358 if ( liv->currentItem() == this ) {
352 liv->setItemTextBackground( cg.brush( QColorGroup::Highlight ) ); 359 liv->setItemTextBackground( cg.brush( QColorGroup::Highlight ) );
353 mycg.setColor( QColorGroup::Text, cg.color( QColorGroup::HighlightedText ) ); 360 mycg.setColor( QColorGroup::Text, cg.color( QColorGroup::HighlightedText ) );
354 } 361 }
355 QIconViewItem::paintItem(p,mycg); 362 QIconViewItem::paintItem(p,mycg);
356 if ( liv->currentItem() == this ) 363 if ( liv->currentItem() == this )
357 liv->setItemTextBackground( oldBrush ); 364 liv->setItemTextBackground( oldBrush );
358 } 365 }
359 366
360 virtual QPixmap* pixmap () const 367 virtual QPixmap* pixmap () const
361 { 368 {
362 const LauncherIconView* liv = (LauncherIconView*)iconView(); 369 const LauncherIconView* liv = (LauncherIconView*)iconView();
363 if ( (const LauncherItem *)liv->busyItem() == this ) 370 if ( (const LauncherItem *)liv->busyItem() == this )
364 return liv->busyPixmap(); 371 return liv->busyPixmap();
365 return QIconViewItem::pixmap(); 372 return QIconViewItem::pixmap();
366 } 373 }
367 374
368protected: 375protected:
369 AppLnk* app; 376 AppLnk* app;
370}; 377};
371 378
372 379
373LauncherItem::LauncherItem( QIconView *parent, AppLnk *applnk, bool bigIcon ) 380LauncherItem::LauncherItem( QIconView *parent, AppLnk *applnk, bool bigIcon )
374 : QIconViewItem( parent, applnk->name(), 381 : QIconViewItem( parent, applnk->name(),
375 bigIcon ? applnk->bigPixmap() :applnk->pixmap() ), 382 bigIcon ? applnk->bigPixmap() :applnk->pixmap() ),
376 app(applnk) // Takes ownership 383 app(applnk) // Takes ownership
377{ 384{
378} 385}
379 386
380int LauncherItem::compare ( QIconViewItem * i ) const 387int LauncherItem::compare ( QIconViewItem * i ) const
381{ 388{
382 LauncherIconView* view = (LauncherIconView*)iconView(); 389 LauncherIconView* view = (LauncherIconView*)iconView();
383 return view->compare(app,((LauncherItem *)i)->appLnk()); 390 return view->compare(app,((LauncherItem *)i)->appLnk());
384} 391}
385 392
386QStringList LauncherIconView::mimeTypes() const 393QStringList LauncherIconView::mimeTypes() const
387{ 394{
388 QStringList r; 395 QStringList r;
389 QDictIterator<void> it(mimes); 396 QDictIterator<void> it(mimes);
390 while (it.current()) { 397 while (it.current()) {
391 r.append(it.currentKey()); 398 r.append(it.currentKey());
392 ++it; 399 ++it;
393 } 400 }
394 r.sort(); 401 r.sort();
395 return r; 402 return r;
396} 403}
397 404
398void LauncherIconView::addItem(AppLnk* app, bool resort) 405void LauncherIconView::addItem(AppLnk* app, bool resort)
399{ 406{
400 addCatsAndMimes(app); 407 addCatsAndMimes(app);
401 408
402 if ( (tf.isEmpty() || tf.match(app->type()) >= 0) 409 if ( (tf.isEmpty() || tf.match(app->type()) >= 0)
403 && (cf == 0 || app->categories().contains(cf) 410 && (cf == 0 || app->categories().contains(cf)
404 || cf == -1 && app->categories().count() == 0 ) ) 411 || cf == -1 && app->categories().count() == 0 ) )
405 (void) new LauncherItem( this, app, bigIcns ); 412 (void) new LauncherItem( this, app, bigIcns );
406 else 413 else
407 hidden.append(app); 414 hidden.append(app);
408 if ( resort ) 415 if ( resort )
409 sort(); 416 sort();
410} 417}
411 418
412void LauncherIconView::updateCategoriesAndMimeTypes() 419void LauncherIconView::updateCategoriesAndMimeTypes()
413{ 420{
414 mimes.clear(); 421 mimes.clear();
415 cats.clear(); 422 cats.clear();
416 LauncherItem* item = (LauncherItem*)firstItem(); 423 LauncherItem* item = (LauncherItem*)firstItem();
417 while (item) { 424 while (item) {
418 addCatsAndMimes(item->appLnk()); 425 addCatsAndMimes(item->appLnk());
419 item = (LauncherItem*)item->nextItem(); 426 item = (LauncherItem*)item->nextItem();
420 } 427 }
421 QListIterator<AppLnk> it(hidden); 428 QListIterator<AppLnk> it(hidden);
422 AppLnk* l; 429 AppLnk* l;
423 while ((l=it.current())) { 430 while ((l=it.current())) {
424 addCatsAndMimes(l); 431 addCatsAndMimes(l);
425 ++it; 432 ++it;
426 } 433 }
427} 434}
428 435
429void LauncherIconView::hideOrShowItems(bool resort) 436void LauncherIconView::hideOrShowItems(bool resort)
430{ 437{
431 hidden.setAutoDelete(FALSE); 438 hidden.setAutoDelete(FALSE);
432 QList<AppLnk> links=hidden; 439 QList<AppLnk> links=hidden;
433 hidden.clear(); 440 hidden.clear();
434 hidden.setAutoDelete(TRUE); 441 hidden.setAutoDelete(TRUE);
435 LauncherItem* item = (LauncherItem*)firstItem(); 442 LauncherItem* item = (LauncherItem*)firstItem();
436 while (item) { 443 while (item) {
437 links.append(item->takeAppLnk()); 444 links.append(item->takeAppLnk());
438 item = (LauncherItem*)item->nextItem(); 445 item = (LauncherItem*)item->nextItem();
439 } 446 }
440 viewport()->setUpdatesEnabled( FALSE ); 447 viewport()->setUpdatesEnabled( FALSE );
441 clear(); 448 clear();
442 QListIterator<AppLnk> it(links); 449 QListIterator<AppLnk> it(links);
443 AppLnk* l; 450 AppLnk* l;
444 while ((l=it.current())) { 451 while ((l=it.current())) {
445 addItem(l,FALSE); 452 addItem(l,FALSE);
446 ++it; 453 ++it;
447 } 454 }
448 viewport()->setUpdatesEnabled( TRUE ); 455 viewport()->setUpdatesEnabled( TRUE );
449 if ( resort && !autoArrange() ) 456 if ( resort && !autoArrange() )
450 sort(); 457 sort();
451} 458}
452 459
453bool LauncherIconView::removeLink(const QString& linkfile) 460bool LauncherIconView::removeLink(const QString& linkfile)
454{ 461{
455 LauncherItem* item = (LauncherItem*)firstItem(); 462 LauncherItem* item = (LauncherItem*)firstItem();
456 AppLnk* l; 463 AppLnk* l;
457 bool did = FALSE; 464 bool did = FALSE;
458 DocLnk dl(linkfile); 465 DocLnk dl(linkfile);
459 while (item) { 466 while (item) {
460 l = item->appLnk(); 467 l = item->appLnk();
461 if ( l->linkFileKnown() && l->linkFile() == linkfile 468 if ( l->linkFileKnown() && l->linkFile() == linkfile
462 || l->fileKnown() && ( 469 || l->fileKnown() && (
463 l->file() == linkfile 470 l->file() == linkfile
464 || dl.isValid() && dl.file() == l->file() ) ) { 471 || dl.isValid() && dl.file() == l->file() ) ) {
465 delete item; 472 delete item;