author | sandman <sandman> | 2002-09-30 10:12:36 (UTC) |
---|---|---|
committer | sandman <sandman> | 2002-09-30 10:12:36 (UTC) |
commit | ece83520d6bf5c481275a3d4a8e792749119fa08 (patch) (unidiff) | |
tree | eb1c8bfdc013a3aca46c4feaa2ff50e38e5d632b | |
parent | a999acbcd1b8bc1715f2ad2dda6acedf423b89ea (diff) | |
download | opie-ece83520d6bf5c481275a3d4a8e792749119fa08.zip opie-ece83520d6bf5c481275a3d4a8e792749119fa08.tar.gz opie-ece83520d6bf5c481275a3d4a8e792749119fa08.tar.bz2 |
Optimizations for the new busy indicator:
- QPixmaps are buffered now
- real fix for the startTimer 100% cpu-load bug (was a typo)
-rw-r--r-- | core/launcher/launcherview.cpp | 71 |
1 files changed, 36 insertions, 35 deletions
diff --git a/core/launcher/launcherview.cpp b/core/launcher/launcherview.cpp index dbcb0d7..5daaeff 100644 --- a/core/launcher/launcherview.cpp +++ b/core/launcher/launcherview.cpp | |||
@@ -62,116 +62,117 @@ public: | |||
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; } | 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 | if ( bsy != c ) { | 100 | if ( bsy != c ) { |
101 | if ( bsy ) | 101 | if ( bsy ) |
102 | bsy-> repaint ( ); | 102 | bsy-> repaint ( ); |
103 | bsy = c; | 103 | bsy = c; |
104 | 104 | ||
105 | if ( bsy ) { | 105 | if ( bsy ) { |
106 | busystate = 5; | ||
107 | for ( int i = 0; i <= 5; i++ ) | ||
108 | bpm [i] = QPixmap ( ); | ||
109 | timerEvent ( 0 ); | ||
106 | busytimer = startTimer ( 150 ); | 110 | busytimer = startTimer ( 150 ); |
107 | busystate = 50; | ||
108 | // not sure what this startTimer is for, maybe i am just to tired. But | ||
109 | // currently that causes 100% cpuload on app launch | ||
110 | //startTimer ( 0 ); | ||
111 | } | 111 | } |
112 | else | 112 | else |
113 | killTimer ( busytimer ); | 113 | killTimer ( busytimer ); |
114 | } | 114 | } |
115 | } | 115 | } |
116 | 116 | ||
117 | virtual void timerEvent ( QTimerEvent *te ) | 117 | virtual void timerEvent ( QTimerEvent *te ) |
118 | { | 118 | { |
119 | if ( !te || ( te-> timerId ( ) == busytimer )) { | 119 | if ( !te || ( te-> timerId ( ) == busytimer )) { |
120 | if ( bsy ) { | 120 | if ( bsy ) { |
121 | QPixmap *src = bsy-> QIconViewItem::pixmap(); | 121 | if ( bpm [::abs(busystate)]. isNull ( )) { |
122 | QImage img = src->convertToImage(); | 122 | QPixmap *src = bsy-> QIconViewItem::pixmap(); |
123 | QRgb* rgb; | 123 | QImage img = src->convertToImage(); |
124 | int count; | 124 | QRgb* rgb; |
125 | if ( img.depth() == 32 ) { | 125 | int count; |
126 | rgb = (QRgb*)img.bits(); | 126 | if ( img.depth() == 32 ) { |
127 | count = img.bytesPerLine()/sizeof(QRgb)*img.height(); | 127 | rgb = (QRgb*)img.bits(); |
128 | } else { | 128 | count = img.bytesPerLine()/sizeof(QRgb)*img.height(); |
129 | rgb = img.colorTable(); | 129 | } else { |
130 | count = img.numColors(); | 130 | rgb = img.colorTable(); |
131 | } | 131 | count = img.numColors(); |
132 | int rc, gc, bc; | 132 | } |
133 | int bs = ::abs ( busystate ) + 25; | 133 | int rc, gc, bc; |
134 | colorGroup().highlight().rgb( &rc, &gc, &bc ); | 134 | int bs = ::abs ( busystate * 10 ) + 25; |
135 | rc = rc * bs / 100; | 135 | colorGroup().highlight().rgb( &rc, &gc, &bc ); |
136 | gc = gc * bs / 100; | 136 | rc = rc * bs / 100; |
137 | bc = bc * bs / 100; | 137 | gc = gc * bs / 100; |
138 | bc = bc * bs / 100; | ||
138 | 139 | ||
139 | for ( int r = 0; r < count; r++, rgb++ ) { | 140 | for ( int r = 0; r < count; r++, rgb++ ) { |
140 | int ri = rc + qRed ( *rgb ) * ( 100 - bs ) / 100; | 141 | int ri = rc + qRed ( *rgb ) * ( 100 - bs ) / 100; |
141 | int gi = gc + qGreen ( *rgb ) * ( 100 - bs ) / 100; | 142 | int gi = gc + qGreen ( *rgb ) * ( 100 - bs ) / 100; |
142 | int bi = bc + qBlue ( *rgb ) * ( 100 - bs ) / 100; | 143 | int bi = bc + qBlue ( *rgb ) * ( 100 - bs ) / 100; |
143 | int ai = qAlpha ( *rgb ); | 144 | int ai = qAlpha ( *rgb ); |
144 | *rgb = qRgba ( ri, gi, bi, ai ); | 145 | *rgb = qRgba ( ri, gi, bi, ai ); |
146 | } | ||
147 | |||
148 | bpm [::abs(busystate)].convertFromImage( img ); | ||
145 | } | 149 | } |
146 | |||
147 | bpm.convertFromImage( img ); | ||
148 | |||
149 | bsy-> repaint ( ); | 150 | bsy-> repaint ( ); |
150 | 151 | ||
151 | busystate += 10; | 152 | busystate++; |
152 | if ( busystate > 50 ) | 153 | if ( busystate > 5 ) |
153 | busystate = -40; | 154 | busystate = -4; |
154 | } | 155 | } |
155 | } | 156 | } |
156 | } | 157 | } |
157 | 158 | ||
158 | bool inKeyEvent() const { return ike; } | 159 | bool inKeyEvent() const { return ike; } |
159 | void keyPressEvent(QKeyEvent* e) | 160 | void keyPressEvent(QKeyEvent* e) |
160 | { | 161 | { |
161 | ike = TRUE; | 162 | ike = TRUE; |
162 | if ( e->key() == Key_F33 /* OK button */ || e->key() == Key_Space ) | 163 | if ( e->key() == Key_F33 /* OK button */ || e->key() == Key_Space ) |
163 | returnPressed(currentItem()); | 164 | returnPressed(currentItem()); |
164 | QIconView::keyPressEvent(e); | 165 | QIconView::keyPressEvent(e); |
165 | ike = FALSE; | 166 | ike = FALSE; |
166 | } | 167 | } |
167 | 168 | ||
168 | void addItem(AppLnk* app, bool resort=TRUE); | 169 | void addItem(AppLnk* app, bool resort=TRUE); |
169 | bool removeLink(const QString& linkfile); | 170 | bool removeLink(const QString& linkfile); |
170 | 171 | ||
171 | QStringList mimeTypes() const; | 172 | QStringList mimeTypes() const; |
172 | QStringList categories() const; | 173 | QStringList categories() const; |
173 | 174 | ||
174 | void clear() | 175 | void clear() |
175 | { | 176 | { |
176 | mimes.clear(); | 177 | mimes.clear(); |
177 | cats.clear(); | 178 | cats.clear(); |
@@ -290,49 +291,49 @@ protected: | |||
290 | setGridY( fontMetrics().height()*2+24 ); | 291 | setGridY( fontMetrics().height()*2+24 ); |
291 | } else { | 292 | } else { |
292 | int cols = 2; | 293 | int cols = 2; |
293 | if ( viewerWidth < 150 ) | 294 | if ( viewerWidth < 150 ) |
294 | cols = 1; | 295 | cols = 1; |
295 | else if ( viewerWidth >= 400 ) | 296 | else if ( viewerWidth >= 400 ) |
296 | cols = viewerWidth/150; | 297 | cols = viewerWidth/150; |
297 | setSpacing( 2 ); | 298 | setSpacing( 2 ); |
298 | setGridX( (viewerWidth-(cols+1)*spacing())/cols ); | 299 | setGridX( (viewerWidth-(cols+1)*spacing())/cols ); |
299 | setGridY( fontMetrics().height()+2 ); | 300 | setGridY( fontMetrics().height()+2 ); |
300 | } | 301 | } |
301 | } | 302 | } |
302 | 303 | ||
303 | private: | 304 | private: |
304 | QList<AppLnk> hidden; | 305 | QList<AppLnk> hidden; |
305 | QDict<void> mimes; | 306 | QDict<void> mimes; |
306 | QDict<void> cats; | 307 | QDict<void> cats; |
307 | SortMethod sortmeth; | 308 | SortMethod sortmeth; |
308 | QRegExp tf; | 309 | QRegExp tf; |
309 | int cf; | 310 | int cf; |
310 | QIconViewItem* bsy; | 311 | QIconViewItem* bsy; |
311 | bool ike; | 312 | bool ike; |
312 | bool bigIcns; | 313 | bool bigIcns; |
313 | QPixmap bgPixmap; | 314 | QPixmap bgPixmap; |
314 | QPixmap bpm; | 315 | QPixmap bpm [6]; |
315 | QColor bgColor; | 316 | QColor bgColor; |
316 | int busytimer; | 317 | int busytimer; |
317 | int busystate; | 318 | int busystate; |
318 | }; | 319 | }; |
319 | 320 | ||
320 | 321 | ||
321 | bool LauncherView::bsy=FALSE; | 322 | bool LauncherView::bsy=FALSE; |
322 | 323 | ||
323 | void LauncherView::setBusy(bool on) | 324 | void LauncherView::setBusy(bool on) |
324 | { | 325 | { |
325 | icons->setBusy(on); | 326 | icons->setBusy(on); |
326 | } | 327 | } |
327 | 328 | ||
328 | class LauncherItem : public QIconViewItem | 329 | class LauncherItem : public QIconViewItem |
329 | { | 330 | { |
330 | public: | 331 | public: |
331 | LauncherItem( QIconView *parent, AppLnk* applnk, bool bigIcon=TRUE ); | 332 | LauncherItem( QIconView *parent, AppLnk* applnk, bool bigIcon=TRUE ); |
332 | ~LauncherItem() | 333 | ~LauncherItem() |
333 | { | 334 | { |
334 | LauncherIconView* liv = (LauncherIconView*)iconView(); | 335 | LauncherIconView* liv = (LauncherIconView*)iconView(); |
335 | if ( liv->busyItem() == this ) | 336 | if ( liv->busyItem() == this ) |
336 | liv->setBusy(FALSE); | 337 | liv->setBusy(FALSE); |
337 | delete app; | 338 | delete app; |
338 | } | 339 | } |