-rw-r--r-- | core/launcher/desktop.cpp | 35 |
1 files changed, 17 insertions, 18 deletions
diff --git a/core/launcher/desktop.cpp b/core/launcher/desktop.cpp index 552c7c3..fb10602 100644 --- a/core/launcher/desktop.cpp +++ b/core/launcher/desktop.cpp | |||
@@ -75,307 +75,307 @@ private: | |||
75 | typedef QValueList<QCopKeyRegister> KeyRegisterList; | 75 | typedef QValueList<QCopKeyRegister> KeyRegisterList; |
76 | KeyRegisterList keyRegisterList; | 76 | KeyRegisterList keyRegisterList; |
77 | 77 | ||
78 | static Desktop* qpedesktop = 0; | 78 | static Desktop* qpedesktop = 0; |
79 | static int loggedin=0; | 79 | static int loggedin=0; |
80 | static void login(bool at_poweron) | 80 | static void login(bool at_poweron) |
81 | { | 81 | { |
82 | if ( !loggedin ) { | 82 | if ( !loggedin ) { |
83 | Global::terminateBuiltin("calibrate"); | 83 | Global::terminateBuiltin("calibrate"); |
84 | Password::authenticate(at_poweron); | 84 | Password::authenticate(at_poweron); |
85 | loggedin=1; | 85 | loggedin=1; |
86 | QCopEnvelope e( "QPE/Desktop", "unlocked()" ); | 86 | QCopEnvelope e( "QPE/Desktop", "unlocked()" ); |
87 | } | 87 | } |
88 | } | 88 | } |
89 | 89 | ||
90 | bool Desktop::screenLocked() | 90 | bool Desktop::screenLocked() |
91 | { | 91 | { |
92 | return loggedin == 0; | 92 | return loggedin == 0; |
93 | } | 93 | } |
94 | 94 | ||
95 | /* | 95 | /* |
96 | Priority is number of alerts that are needed to pop up | 96 | Priority is number of alerts that are needed to pop up |
97 | alert. | 97 | alert. |
98 | */ | 98 | */ |
99 | class DesktopPowerAlerter : public QMessageBox | 99 | class DesktopPowerAlerter : public QMessageBox |
100 | { | 100 | { |
101 | public: | 101 | public: |
102 | DesktopPowerAlerter( QWidget *parent, const char *name = 0 ) | 102 | DesktopPowerAlerter( QWidget *parent, const char *name = 0 ) |
103 | : QMessageBox( tr("Battery Status"), "Low Battery", | 103 | : QMessageBox( tr("Battery Status"), "Low Battery", |
104 | QMessageBox::Critical, | 104 | QMessageBox::Critical, |
105 | QMessageBox::Ok | QMessageBox::Default, | 105 | QMessageBox::Ok | QMessageBox::Default, |
106 | QMessageBox::NoButton, QMessageBox::NoButton, | 106 | QMessageBox::NoButton, QMessageBox::NoButton, |
107 | parent, name, FALSE ) | 107 | parent, name, FALSE ) |
108 | { | 108 | { |
109 | currentPriority = INT_MAX; | 109 | currentPriority = INT_MAX; |
110 | alertCount = 0; | 110 | alertCount = 0; |
111 | } | 111 | } |
112 | 112 | ||
113 | void alert( const QString &text, int priority ); | 113 | void alert( const QString &text, int priority ); |
114 | void hideEvent( QHideEvent * ); | 114 | void hideEvent( QHideEvent * ); |
115 | private: | 115 | private: |
116 | int currentPriority; | 116 | int currentPriority; |
117 | int alertCount; | 117 | int alertCount; |
118 | }; | 118 | }; |
119 | 119 | ||
120 | void DesktopPowerAlerter::alert( const QString &text, int priority ) | 120 | void DesktopPowerAlerter::alert( const QString &text, int priority ) |
121 | { | 121 | { |
122 | alertCount++; | 122 | alertCount++; |
123 | if ( alertCount < priority ) | 123 | if ( alertCount < priority ) |
124 | return; | 124 | return; |
125 | if ( priority > currentPriority ) | 125 | if ( priority > currentPriority ) |
126 | return; | 126 | return; |
127 | currentPriority = priority; | 127 | currentPriority = priority; |
128 | setText( text ); | 128 | setText( text ); |
129 | show(); | 129 | show(); |
130 | } | 130 | } |
131 | 131 | ||
132 | 132 | ||
133 | void DesktopPowerAlerter::hideEvent( QHideEvent *e ) | 133 | void DesktopPowerAlerter::hideEvent( QHideEvent *e ) |
134 | { | 134 | { |
135 | QMessageBox::hideEvent( e ); | 135 | QMessageBox::hideEvent( e ); |
136 | alertCount = 0; | 136 | alertCount = 0; |
137 | currentPriority = INT_MAX; | 137 | currentPriority = INT_MAX; |
138 | } | 138 | } |
139 | 139 | ||
140 | 140 | ||
141 | 141 | ||
142 | DesktopApplication::DesktopApplication( int& argc, char **argv, Type appType ) | 142 | DesktopApplication::DesktopApplication( int& argc, char **argv, Type appType ) |
143 | : QPEApplication( argc, argv, appType ) | 143 | : QPEApplication( argc, argv, appType ) |
144 | { | 144 | { |
145 | 145 | ||
146 | QTimer *t = new QTimer( this ); | 146 | QTimer *t = new QTimer( this ); |
147 | connect( t, SIGNAL(timeout()), this, SLOT(psTimeout()) ); | 147 | connect( t, SIGNAL(timeout()), this, SLOT(psTimeout()) ); |
148 | t->start( 10000 ); | 148 | t->start( 10000 ); |
149 | ps = new PowerStatus; | 149 | ps = new PowerStatus; |
150 | pa = new DesktopPowerAlerter( 0 ); | 150 | pa = new DesktopPowerAlerter( 0 ); |
151 | 151 | ||
152 | channel = new QCopChannel( "QPE/Desktop", this ); | 152 | channel = new QCopChannel( "QPE/Desktop", this ); |
153 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), | 153 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), |
154 | this, SLOT(receive(const QCString&, const QByteArray&)) ); | 154 | this, SLOT(receive(const QCString&, const QByteArray&)) ); |
155 | } | 155 | } |
156 | 156 | ||
157 | 157 | ||
158 | DesktopApplication::~DesktopApplication() | 158 | DesktopApplication::~DesktopApplication() |
159 | { | 159 | { |
160 | delete ps; | 160 | delete ps; |
161 | delete pa; | 161 | delete pa; |
162 | } | 162 | } |
163 | 163 | ||
164 | void DesktopApplication::receive( const QCString &msg, const QByteArray &data ) | 164 | void DesktopApplication::receive( const QCString &msg, const QByteArray &data ) |
165 | { | 165 | { |
166 | QDataStream stream( data, IO_ReadOnly ); | 166 | QDataStream stream( data, IO_ReadOnly ); |
167 | if (msg == "keyRegister(int key, QString channel, QString message)") | 167 | if (msg == "keyRegister(int key, QString channel, QString message)") |
168 | { | 168 | { |
169 | int k; | 169 | int k; |
170 | QString c, m; | 170 | QString c, m; |
171 | stream >> k; | 171 | stream >> k; |
172 | stream >> c; | 172 | stream >> c; |
173 | stream >> m; | 173 | stream >> m; |
174 | 174 | ||
175 | qWarning("KeyRegisterReceived: %i, %s, %s", k, (const char*)c, (const char *)m ); | 175 | qWarning("KeyRegisterReceived: %i, %s, %s", k, (const char*)c, (const char *)m ); |
176 | keyRegisterList.append(QCopKeyRegister(k,c,m)); | 176 | keyRegisterList.append(QCopKeyRegister(k,c,m)); |
177 | } | 177 | } |
178 | else if (msg == "suspend()"){ | 178 | else if (msg == "suspend()"){ |
179 | emit power(); | 179 | emit power(); |
180 | } | 180 | } |
181 | 181 | ||
182 | } | 182 | } |
183 | 183 | ||
184 | enum MemState { Unknown, VeryLow, Low, Normal } memstate=Unknown; | 184 | enum MemState { Unknown, VeryLow, Low, Normal } memstate=Unknown; |
185 | 185 | ||
186 | #ifdef Q_WS_QWS | 186 | #ifdef Q_WS_QWS |
187 | bool DesktopApplication::qwsEventFilter( QWSEvent *e ) | 187 | bool DesktopApplication::qwsEventFilter( QWSEvent *e ) |
188 | { | 188 | { |
189 | qpedesktop->checkMemory(); | 189 | qpedesktop->checkMemory(); |
190 | 190 | ||
191 | if ( e->type == QWSEvent::Key ) { | 191 | if ( e->type == QWSEvent::Key ) { |
192 | QWSKeyEvent *ke = (QWSKeyEvent *)e; | 192 | QWSKeyEvent *ke = (QWSKeyEvent *)e; |
193 | if ( !loggedin && ke->simpleData.keycode != Key_F34 ) | 193 | if ( !loggedin && ke->simpleData.keycode != Key_F34 ) |
194 | return TRUE; | 194 | return TRUE; |
195 | bool press = ke->simpleData.is_press; | 195 | bool press = ke->simpleData.is_press; |
196 | bool autoRepeat= ke->simpleData.is_auto_repeat; | 196 | bool autoRepeat= ke->simpleData.is_auto_repeat; |
197 | 197 | ||
198 | /* | 198 | /* |
199 | app that registers key/message to be sent back to the app, when it doesn't have focus, | 199 | app that registers key/message to be sent back to the app, when it doesn't have focus, |
200 | when user presses key, unless keyboard has been requested from app. | 200 | when user presses key, unless keyboard has been requested from app. |
201 | will not send multiple repeats if user holds key | 201 | will not send multiple repeats if user holds key |
202 | i.e. one shot | 202 | i.e. one shot |
203 | 203 | ||
204 | */ | 204 | */ |
205 | if (!keyRegisterList.isEmpty()) { | 205 | if (!keyRegisterList.isEmpty()) { |
206 | KeyRegisterList::Iterator it; | 206 | KeyRegisterList::Iterator it; |
207 | for( it = keyRegisterList.begin(); it != keyRegisterList.end(); ++it ) { | 207 | for( it = keyRegisterList.begin(); it != keyRegisterList.end(); ++it ) { |
208 | if ((*it).getKeyCode() == ke->simpleData.keycode && !autoRepeat && !keyboardGrabbed() && press) { | 208 | if ((*it).getKeyCode() == ke->simpleData.keycode && !autoRepeat && !keyboardGrabbed() && press) { |
209 | if(press) qDebug("press"); else qDebug("release"); | 209 | if(press) qDebug("press"); else qDebug("release"); |
210 | QCopEnvelope((*it).getChannel().utf8(), (*it).getMessage().utf8()); | 210 | QCopEnvelope((*it).getChannel().utf8(), (*it).getMessage().utf8()); |
211 | } | 211 | } |
212 | } | 212 | } |
213 | } | 213 | } |
214 | 214 | ||
215 | if ( !keyboardGrabbed() ) { | 215 | if ( !keyboardGrabbed() ) { |
216 | if ( ke->simpleData.keycode == Key_F9 ) { | 216 | if ( ke->simpleData.keycode == Key_F9 ) { |
217 | if ( press ) emit datebook(); | 217 | if ( press ) emit datebook(); |
218 | return TRUE; | 218 | return TRUE; |
219 | } | 219 | } |
220 | if ( ke->simpleData.keycode == Key_F10 ) { | 220 | if ( ke->simpleData.keycode == Key_F10 ) { |
221 | if ( !press && cardSendTimer ) { | 221 | if ( !press && cardSendTimer ) { |
222 | emit contacts(); | 222 | emit contacts(); |
223 | delete cardSendTimer; | 223 | delete cardSendTimer; |
224 | } else if ( press ) { | 224 | } else if ( press ) { |
225 | cardSendTimer = new QTimer(); | 225 | cardSendTimer = new QTimer(); |
226 | cardSendTimer->start( 2000, TRUE ); | 226 | cardSendTimer->start( 2000, TRUE ); |
227 | connect( cardSendTimer, SIGNAL( timeout() ), this, SLOT( sendCard() ) ); | 227 | connect( cardSendTimer, SIGNAL( timeout() ), this, SLOT( sendCard() ) ); |
228 | } | 228 | } |
229 | return TRUE; | 229 | return TRUE; |
230 | } | 230 | } |
231 | /* menu key now opens application menu/toolbar | 231 | /* menu key now opens application menu/toolbar |
232 | if ( ke->simpleData.keycode == Key_F11 ) { | 232 | if ( ke->simpleData.keycode == Key_F11 ) { |
233 | if ( press ) emit menu(); | 233 | if ( press ) emit menu(); |
234 | return TRUE; | 234 | return TRUE; |
235 | } | 235 | } |
236 | */ | 236 | */ |
237 | if ( ke->simpleData.keycode == Key_F12 ) { | 237 | if ( ke->simpleData.keycode == Key_F12 ) { |
238 | while( activePopupWidget() ) | 238 | while( activePopupWidget() ) |
239 | activePopupWidget()->close(); | 239 | activePopupWidget()->close(); |
240 | if ( press ) emit launch(); | 240 | if ( press ) emit launch(); |
241 | return TRUE; | 241 | return TRUE; |
242 | } | 242 | } |
243 | if ( ke->simpleData.keycode == Key_F13 ) { | 243 | if ( ke->simpleData.keycode == Key_F13 ) { |
244 | if ( press ) emit email(); | 244 | if ( press ) emit email(); |
245 | return TRUE; | 245 | return TRUE; |
246 | } | 246 | } |
247 | } | 247 | } |
248 | 248 | ||
249 | if ( ke->simpleData.keycode == Key_F34 ) { | 249 | if ( ke->simpleData.keycode == Key_F34 ) { |
250 | if ( press ) emit power(); | 250 | if ( press ) emit power(); |
251 | return TRUE; | 251 | return TRUE; |
252 | } | 252 | } |
253 | // This was used for the iPAQ PowerButton | 253 | // This was used for the iPAQ PowerButton |
254 | // See main.cpp for new KeyboardFilter | 254 | // See main.cpp for new KeyboardFilter |
255 | // | 255 | // |
256 | // if ( ke->simpleData.keycode == Key_SysReq ) { | 256 | // if ( ke->simpleData.keycode == Key_SysReq ) { |
257 | // if ( press ) emit power(); | 257 | // if ( press ) emit power(); |
258 | // return TRUE; | 258 | // return TRUE; |
259 | // } | 259 | // } |
260 | if ( ke->simpleData.keycode == Key_F35 ) { | 260 | if ( ke->simpleData.keycode == Key_F35 ) { |
261 | if ( press ) emit backlight(); | 261 | if ( press ) emit backlight(); |
262 | return TRUE; | 262 | return TRUE; |
263 | } | 263 | } |
264 | if ( ke->simpleData.keycode == Key_F32 ) { | 264 | if ( ke->simpleData.keycode == Key_F32 ) { |
265 | if ( press ) QCopEnvelope e( "QPE/Desktop", "startSync()" ); | 265 | if ( press ) QCopEnvelope e( "QPE/Desktop", "startSync()" ); |
266 | return TRUE; | 266 | return TRUE; |
267 | } | 267 | } |
268 | if ( ke->simpleData.keycode == Key_F31 && !ke->simpleData.modifiers ) { | 268 | if ( ke->simpleData.keycode == Key_F31 && !ke->simpleData.modifiers ) { |
269 | if ( press ) emit symbol(); | 269 | if ( press ) emit symbol(); |
270 | return TRUE; | 270 | return TRUE; |
271 | } | 271 | } |
272 | if ( ke->simpleData.keycode == Key_NumLock ) { | 272 | if ( ke->simpleData.keycode == Key_NumLock ) { |
273 | if ( press ) emit numLockStateToggle(); | 273 | if ( press ) emit numLockStateToggle(); |
274 | } | 274 | } |
275 | if ( ke->simpleData.keycode == Key_CapsLock ) { | 275 | if ( ke->simpleData.keycode == Key_CapsLock ) { |
276 | if ( press ) emit capsLockStateToggle(); | 276 | if ( press ) emit capsLockStateToggle(); |
277 | } | 277 | } |
278 | if (( press && !autoRepeat ) || ( !press && autoRepeat )) | 278 | if (( press && !autoRepeat ) || ( !press && autoRepeat )) |
279 | qpedesktop->keyClick(); | 279 | qpedesktop->keyClick(); |
280 | } else { | 280 | } else { |
281 | if ( e->type == QWSEvent::Mouse ) { | 281 | if ( e->type == QWSEvent::Mouse ) { |
282 | QWSMouseEvent *me = (QWSMouseEvent *)e; | 282 | QWSMouseEvent *me = (QWSMouseEvent *)e; |
283 | static bool up = TRUE; | 283 | static bool up = TRUE; |
284 | if ( me->simpleData.state&LeftButton ) { | 284 | if ( me->simpleData.state&LeftButton ) { |
285 | if ( up ) { | 285 | if ( up ) { |
286 | up = FALSE; | 286 | up = FALSE; |
287 | qpedesktop->screenClick(); | 287 | qpedesktop->screenClick(); |
288 | } | 288 | } |
289 | } else { | 289 | } else { |
290 | up = TRUE; | 290 | up = TRUE; |
291 | } | 291 | } |
292 | } | 292 | } |
293 | } | 293 | } |
294 | 294 | ||
295 | return QPEApplication::qwsEventFilter( e ); | 295 | return QPEApplication::qwsEventFilter( e ); |
296 | } | 296 | } |
297 | #endif | 297 | #endif |
298 | 298 | ||
299 | void DesktopApplication::psTimeout() | 299 | void DesktopApplication::psTimeout() |
300 | { | 300 | { |
301 | qpedesktop->checkMemory(); // in case no events are being generated | 301 | qpedesktop->checkMemory(); // in case no events are being generated |
302 | 302 | ||
303 | *ps = PowerStatusManager::readStatus(); | 303 | *ps = PowerStatusManager::readStatus(); |
304 | 304 | ||
305 | if ( (ps->batteryStatus() == PowerStatus::VeryLow ) ) { | 305 | if ( (ps->batteryStatus() == PowerStatus::VeryLow ) ) { |
306 | pa->alert( tr( "Battery is running very low." ), 6 ); | 306 | pa->alert( tr( "Battery is running very low." ), 6 ); |
307 | } | 307 | } |
308 | 308 | ||
309 | if ( ps->batteryStatus() == PowerStatus::Critical ) { | 309 | if ( ps->batteryStatus() == PowerStatus::Critical ) { |
310 | pa->alert( tr( "Battery level is critical!\n" | 310 | pa->alert( tr( "Battery level is critical!\n" |
311 | "Keep power off until power restored!" ), 1 ); | 311 | "Keep power off until power restored!" ), 1 ); |
312 | } | 312 | } |
313 | 313 | ||
314 | if ( ps->backupBatteryStatus() == PowerStatus::VeryLow ) { | 314 | if ( ps->backupBatteryStatus() == PowerStatus::VeryLow ) { |
315 | pa->alert( tr( "The Back-up battery is very low.\nPlease charge the back-up battery." ), 3 ); | 315 | pa->alert( tr( "The Back-up battery is very low.\nPlease charge the back-up battery." ), 3 ); |
316 | } | 316 | } |
317 | } | 317 | } |
318 | 318 | ||
319 | 319 | ||
320 | void DesktopApplication::sendCard() | 320 | void DesktopApplication::sendCard() |
321 | { | 321 | { |
322 | delete cardSendTimer; | 322 | delete cardSendTimer; |
323 | cardSendTimer = 0; | 323 | cardSendTimer = 0; |
324 | QString card = getenv("HOME"); | 324 | QString card = getenv("HOME"); |
325 | card += "/Applications/addressbook/businesscard.vcf"; | 325 | card += "/Applications/addressbook/businesscard.vcf"; |
326 | 326 | ||
327 | if ( QFile::exists( card ) ) { | 327 | if ( QFile::exists( card ) ) { |
328 | QCopEnvelope e("QPE/Obex", "send(QString,QString,QString)"); | 328 | QCopEnvelope e("QPE/Obex", "send(QString,QString,QString)"); |
329 | QString mimetype = "text/x-vCard"; | 329 | QString mimetype = "text/x-vCard"; |
330 | e << tr("business card") << card << mimetype; | 330 | e << tr("business card") << card << mimetype; |
331 | } | 331 | } |
332 | } | 332 | } |
333 | 333 | ||
334 | #if defined(QPE_HAVE_MEMALERTER) | 334 | #if defined(QPE_HAVE_MEMALERTER) |
335 | QPE_MEMALERTER_IMPL | 335 | QPE_MEMALERTER_IMPL |
336 | #endif | 336 | #endif |
337 | 337 | ||
338 | //=========================================================================== | 338 | //=========================================================================== |
339 | 339 | ||
340 | Desktop::Desktop() : | 340 | Desktop::Desktop() : |
341 | QWidget( 0, 0, WStyle_Tool | WStyle_Customize ), | 341 | QWidget( 0, 0, WStyle_Tool | WStyle_Customize ), |
342 | qcopBridge( 0 ), | 342 | qcopBridge( 0 ), |
343 | transferServer( 0 ), | 343 | transferServer( 0 ), |
344 | packageSlave( 0 ) | 344 | packageSlave( 0 ) |
345 | { | 345 | { |
346 | qpedesktop = this; | 346 | qpedesktop = this; |
347 | 347 | ||
348 | // bg = new Info( this ); | 348 | // bg = new Info( this ); |
349 | tb = new TaskBar; | 349 | tb = new TaskBar; |
350 | 350 | ||
351 | launcher = new Launcher( 0, 0, WStyle_Customize | QWidget::WGroupLeader ); | 351 | launcher = new Launcher( 0, 0, WStyle_Customize | QWidget::WGroupLeader ); |
352 | 352 | ||
353 | connect(launcher, SIGNAL(busy()), tb, SLOT(startWait())); | 353 | connect(launcher, SIGNAL(busy()), tb, SLOT(startWait())); |
354 | connect(launcher, SIGNAL(notBusy(const QString&)), tb, SLOT(stopWait(const QString&))); | 354 | connect(launcher, SIGNAL(notBusy(const QString&)), tb, SLOT(stopWait(const QString&))); |
355 | 355 | ||
356 | int displayw = qApp->desktop()->width(); | 356 | int displayw = qApp->desktop()->width(); |
357 | int displayh = qApp->desktop()->height(); | 357 | int displayh = qApp->desktop()->height(); |
358 | 358 | ||
359 | 359 | ||
360 | QSize sz = tb->sizeHint(); | 360 | QSize sz = tb->sizeHint(); |
361 | 361 | ||
362 | setGeometry( 0, displayh-sz.height(), displayw, sz.height() ); | 362 | setGeometry( 0, displayh-sz.height(), displayw, sz.height() ); |
363 | tb->setGeometry( 0, displayh-sz.height(), displayw, sz.height() ); | 363 | tb->setGeometry( 0, displayh-sz.height(), displayw, sz.height() ); |
364 | 364 | ||
365 | tb->show(); | 365 | tb->show(); |
366 | launcher->showMaximized(); | 366 | launcher->showMaximized(); |
367 | launcher->show(); | 367 | launcher->show(); |
368 | launcher->raise(); | 368 | launcher->raise(); |
369 | #if defined(QPE_HAVE_MEMALERTER) | 369 | #if defined(QPE_HAVE_MEMALERTER) |
370 | initMemalerter(); | 370 | initMemalerter(); |
371 | #endif | 371 | #endif |
372 | // start services | 372 | // start services |
373 | startTransferServer(); | 373 | startTransferServer(); |
374 | (void) new IrServer( this ); | 374 | (void) new IrServer( this ); |
375 | rereadVolumes(); | 375 | rereadVolumes(); |
376 | 376 | ||
377 | packageSlave = new PackageSlave( this ); | 377 | packageSlave = new PackageSlave( this ); |
378 | connect(qApp, SIGNAL(volumeChanged(bool)), this, SLOT(rereadVolumes())); | 378 | connect(qApp, SIGNAL(volumeChanged(bool)), this, SLOT(rereadVolumes())); |
379 | 379 | ||
380 | qApp->installEventFilter( this ); | 380 | qApp->installEventFilter( this ); |
381 | } | 381 | } |
@@ -434,377 +434,376 @@ void Desktop::checkMemory() | |||
434 | QMessageBox::critical( 0 , "Memory Status", | 434 | QMessageBox::critical( 0 , "Memory Status", |
435 | "The memory is very low. \n" | 435 | "The memory is very low. \n" |
436 | "Please end this application \n" | 436 | "Please end this application \n" |
437 | "immediately." ); | 437 | "immediately." ); |
438 | recoverMemory(); | 438 | recoverMemory(); |
439 | } | 439 | } |
440 | existingMessage = FALSE; | 440 | existingMessage = FALSE; |
441 | #endif | 441 | #endif |
442 | } | 442 | } |
443 | 443 | ||
444 | static bool isVisibleWindow(int wid) | 444 | static bool isVisibleWindow(int wid) |
445 | { | 445 | { |
446 | const QList<QWSWindow> &list = qwsServer->clientWindows(); | 446 | const QList<QWSWindow> &list = qwsServer->clientWindows(); |
447 | QWSWindow* w; | 447 | QWSWindow* w; |
448 | for (QListIterator<QWSWindow> it(list); (w=it.current()); ++it) { | 448 | for (QListIterator<QWSWindow> it(list); (w=it.current()); ++it) { |
449 | if ( w->winId() == wid ) | 449 | if ( w->winId() == wid ) |
450 | return !w->isFullyObscured(); | 450 | return !w->isFullyObscured(); |
451 | } | 451 | } |
452 | return FALSE; | 452 | return FALSE; |
453 | } | 453 | } |
454 | 454 | ||
455 | static bool hasVisibleWindow(const QString& clientname) | 455 | static bool hasVisibleWindow(const QString& clientname) |
456 | { | 456 | { |
457 | const QList<QWSWindow> &list = qwsServer->clientWindows(); | 457 | const QList<QWSWindow> &list = qwsServer->clientWindows(); |
458 | QWSWindow* w; | 458 | QWSWindow* w; |
459 | for (QListIterator<QWSWindow> it(list); (w=it.current()); ++it) { | 459 | for (QListIterator<QWSWindow> it(list); (w=it.current()); ++it) { |
460 | if ( w->client()->identity() == clientname && !w->isFullyObscured() ) | 460 | if ( w->client()->identity() == clientname && !w->isFullyObscured() ) |
461 | return TRUE; | 461 | return TRUE; |
462 | } | 462 | } |
463 | return FALSE; | 463 | return FALSE; |
464 | } | 464 | } |
465 | 465 | ||
466 | void Desktop::raiseLauncher() | 466 | void Desktop::raiseLauncher() |
467 | { | 467 | { |
468 | Config cfg("qpe"); //F12 'Home' | 468 | Config cfg("qpe"); //F12 'Home' |
469 | cfg.setGroup("AppsKey"); | 469 | cfg.setGroup("AppsKey"); |
470 | QString tempItem; | 470 | QString tempItem; |
471 | tempItem = cfg.readEntry("Middle","Home"); | 471 | tempItem = cfg.readEntry("Middle","Home"); |
472 | if(tempItem == "Home" || tempItem.isEmpty()) { | 472 | if(tempItem == "Home" || tempItem.isEmpty()) { |
473 | if ( isVisibleWindow(launcher->winId()) ) | 473 | if ( isVisibleWindow(launcher->winId()) ) |
474 | launcher->nextView(); | 474 | launcher->nextView(); |
475 | else | 475 | else |
476 | launcher->raise(); | 476 | launcher->raise(); |
477 | } else { | 477 | } else { |
478 | QCopEnvelope e("QPE/System","execute(QString)"); | 478 | QCopEnvelope e("QPE/System","execute(QString)"); |
479 | e << tempItem; | 479 | e << tempItem; |
480 | } | 480 | } |
481 | } | 481 | } |
482 | 482 | ||
483 | void Desktop::executeOrModify(const QString& appLnkFile) | 483 | void Desktop::executeOrModify(const QString& appLnkFile) |
484 | { | 484 | { |
485 | AppLnk lnk(MimeType::appsFolderName() + "/" + appLnkFile); | 485 | AppLnk lnk(MimeType::appsFolderName() + "/" + appLnkFile); |
486 | if ( lnk.isValid() ) { | 486 | if ( lnk.isValid() ) { |
487 | QCString app = lnk.exec().utf8(); | 487 | QCString app = lnk.exec().utf8(); |
488 | Global::terminateBuiltin("calibrate"); | 488 | Global::terminateBuiltin("calibrate"); |
489 | if ( QCopChannel::isRegistered("QPE/Application/" + app) ) { | 489 | if ( QCopChannel::isRegistered("QPE/Application/" + app) ) { |
490 | MRUList::addTask(&lnk); | 490 | MRUList::addTask(&lnk); |
491 | if ( hasVisibleWindow(app) ) | 491 | if ( hasVisibleWindow(app) ) |
492 | QCopChannel::send("QPE/Application/" + app, "nextView()"); | 492 | QCopChannel::send("QPE/Application/" + app, "nextView()"); |
493 | else | 493 | else |
494 | QCopChannel::send("QPE/Application/" + app, "raise()"); | 494 | QCopChannel::send("QPE/Application/" + app, "raise()"); |
495 | } else { | 495 | } else { |
496 | lnk.execute(); | 496 | lnk.execute(); |
497 | } | 497 | } |
498 | } | 498 | } |
499 | } | 499 | } |
500 | 500 | ||
501 | void Desktop::raiseDatebook() | 501 | void Desktop::raiseDatebook() |
502 | { | 502 | { |
503 | Config cfg("qpe"); //F9 'Activity' | 503 | Config cfg("qpe"); //F9 'Activity' |
504 | cfg.setGroup("AppsKey"); | 504 | cfg.setGroup("AppsKey"); |
505 | QString tempItem; | 505 | QString tempItem; |
506 | tempItem = cfg.readEntry("LeftEnd","Calender"); | 506 | tempItem = cfg.readEntry("LeftEnd","Calender"); |
507 | if(tempItem == "Calender" || tempItem.isEmpty()) executeOrModify("Applications/datebook.desktop"); | 507 | if(tempItem == "Calender" || tempItem.isEmpty()) executeOrModify("Applications/datebook.desktop"); |
508 | else { | 508 | else { |
509 | QCopEnvelope e("QPE/System","execute(QString)"); | 509 | QCopEnvelope e("QPE/System","execute(QString)"); |
510 | e << tempItem; | 510 | e << tempItem; |
511 | } | 511 | } |
512 | } | 512 | } |
513 | 513 | ||
514 | void Desktop::raiseContacts() | 514 | void Desktop::raiseContacts() |
515 | { | 515 | { |
516 | Config cfg("qpe"); //F10, 'Contacts' | 516 | Config cfg("qpe"); //F10, 'Contacts' |
517 | cfg.setGroup("AppsKey"); | 517 | cfg.setGroup("AppsKey"); |
518 | QString tempItem; | 518 | QString tempItem; |
519 | tempItem = cfg.readEntry("Left2nd","Address Book"); | 519 | tempItem = cfg.readEntry("Left2nd","Address Book"); |
520 | if(tempItem == "Address Book" || tempItem.isEmpty()) executeOrModify("Applications/addressbook.desktop"); | 520 | if(tempItem == "Address Book" || tempItem.isEmpty()) executeOrModify("Applications/addressbook.desktop"); |
521 | else { | 521 | else { |
522 | QCopEnvelope e("QPE/System","execute(QString)"); | 522 | QCopEnvelope e("QPE/System","execute(QString)"); |
523 | e << tempItem; | 523 | e << tempItem; |
524 | } | 524 | } |
525 | } | 525 | } |
526 | 526 | ||
527 | void Desktop::raiseMenu() | 527 | void Desktop::raiseMenu() |
528 | { | 528 | { |
529 | Config cfg("qpe"); //F11, 'Menu' | 529 | Config cfg("qpe"); //F11, 'Menu' |
530 | cfg.setGroup("AppsKey"); | 530 | cfg.setGroup("AppsKey"); |
531 | QString tempItem; | 531 | QString tempItem; |
532 | tempItem = cfg.readEntry("Right2nd","Popup Menu"); | 532 | tempItem = cfg.readEntry("Right2nd","Popup Menu"); |
533 | if(tempItem == "Popup Menu" || tempItem.isEmpty()) { | 533 | if(tempItem == "Popup Menu" || tempItem.isEmpty()) { |
534 | Global::terminateBuiltin("calibrate"); | 534 | Global::terminateBuiltin("calibrate"); |
535 | tb->startMenu()->launch(); | 535 | tb->startMenu()->launch(); |
536 | } else { | 536 | } else { |
537 | QCopEnvelope e("QPE/System","execute(QString)"); | 537 | QCopEnvelope e("QPE/System","execute(QString)"); |
538 | e << tempItem; | 538 | e << tempItem; |
539 | } | 539 | } |
540 | } | 540 | } |
541 | 541 | ||
542 | void Desktop::raiseEmail() | 542 | void Desktop::raiseEmail() |
543 | { | 543 | { |
544 | Config cfg("qpe"); //F13, 'Mail' | 544 | Config cfg("qpe"); //F13, 'Mail' |
545 | cfg.setGroup("AppsKey"); | 545 | cfg.setGroup("AppsKey"); |
546 | QString tempItem; | 546 | QString tempItem; |
547 | tempItem = cfg.readEntry("RightEnd","Mail"); | 547 | tempItem = cfg.readEntry("RightEnd","Mail"); |
548 | if(tempItem == "Mail" || tempItem == "qtmail" || tempItem.isEmpty()) executeOrModify("Applications/qtmail.desktop"); | 548 | if(tempItem == "Mail" || tempItem == "qtmail" || tempItem.isEmpty()) executeOrModify("Applications/qtmail.desktop"); |
549 | else { | 549 | else { |
550 | QCopEnvelope e("QPE/System","execute(QString)"); | 550 | QCopEnvelope e("QPE/System","execute(QString)"); |
551 | e << tempItem; | 551 | e << tempItem; |
552 | } | 552 | } |
553 | } | 553 | } |
554 | 554 | ||
555 | // autoStarts apps on resume and start | 555 | // autoStarts apps on resume and start |
556 | void Desktop::execAutoStart() { | 556 | void Desktop::execAutoStart() { |
557 | QString appName; | 557 | QString appName; |
558 | int delay; | 558 | int delay; |
559 | QDateTime now = QDateTime::currentDateTime(); | 559 | QDateTime now = QDateTime::currentDateTime(); |
560 | Config cfg( "autostart" ); | 560 | Config cfg( "autostart" ); |
561 | cfg.setGroup( "AutoStart" ); | 561 | cfg.setGroup( "AutoStart" ); |
562 | appName = cfg.readEntry("Apps", ""); | 562 | appName = cfg.readEntry( "Apps", "" ); |
563 | delay = (cfg.readEntry("Delay", "0" )).toInt(); | 563 | delay = ( cfg.readEntry( "Delay", "0" ) ).toInt(); |
564 | // If the time between suspend and resume was longer then the | 564 | // If the time between suspend and resume was longer then the |
565 | // value saved as delay, start the app | 565 | // value saved as delay, start the app |
566 | if ( suspendTime.secsTo(now) >= (delay*60) ) { | 566 | if ( suspendTime.secsTo( now ) >= ( delay * 60 ) && !appName.isEmpty() ) { |
567 | QCopEnvelope e("QPE/System", "execute(QString)"); | 567 | QCopEnvelope e( "QPE/System", "execute(QString)" ); |
568 | e << QString(appName); | 568 | e << QString( appName ); |
569 | } //else { | 569 | } |
570 | //} | ||
571 | } | 570 | } |
572 | 571 | ||
573 | #if defined(QPE_HAVE_TOGGLELIGHT) | 572 | #if defined(QPE_HAVE_TOGGLELIGHT) |
574 | #include <qpe/config.h> | 573 | #include <qpe/config.h> |
575 | 574 | ||
576 | #include <sys/ioctl.h> | 575 | #include <sys/ioctl.h> |
577 | #include <sys/types.h> | 576 | #include <sys/types.h> |
578 | #include <fcntl.h> | 577 | #include <fcntl.h> |
579 | #include <unistd.h> | 578 | #include <unistd.h> |
580 | #include <errno.h> | 579 | #include <errno.h> |
581 | #include <linux/ioctl.h> | 580 | #include <linux/ioctl.h> |
582 | #include <time.h> | 581 | #include <time.h> |
583 | #endif | 582 | #endif |
584 | 583 | ||
585 | static bool blanked=FALSE; | 584 | static bool blanked=FALSE; |
586 | 585 | ||
587 | static void blankScreen() | 586 | static void blankScreen() |
588 | { | 587 | { |
589 | if ( !qt_screen ) return; | 588 | if ( !qt_screen ) return; |
590 | /* Should use a big black window instead. | 589 | /* Should use a big black window instead. |
591 | QGfx* g = qt_screen->screenGfx(); | 590 | QGfx* g = qt_screen->screenGfx(); |
592 | g->fillRect(0,0,qt_screen->width(),qt_screen->height()); | 591 | g->fillRect(0,0,qt_screen->width(),qt_screen->height()); |
593 | delete g; | 592 | delete g; |
594 | */ | 593 | */ |
595 | blanked = TRUE; | 594 | blanked = TRUE; |
596 | } | 595 | } |
597 | 596 | ||
598 | static void darkScreen() | 597 | static void darkScreen() |
599 | { | 598 | { |
600 | extern void qpe_setBacklight(int); | 599 | extern void qpe_setBacklight(int); |
601 | qpe_setBacklight(0); // force off | 600 | qpe_setBacklight(0); // force off |
602 | } | 601 | } |
603 | 602 | ||
604 | 603 | ||
605 | void Desktop::togglePower() | 604 | void Desktop::togglePower() |
606 | { | 605 | { |
607 | extern void qpe_setBacklight ( int ); // We need to toggle the LCD fast - no time to send a QCop | 606 | extern void qpe_setBacklight ( int ); // We need to toggle the LCD fast - no time to send a QCop |
608 | 607 | ||
609 | static bool excllock = false; | 608 | static bool excllock = false; |
610 | 609 | ||
611 | if ( excllock ) | 610 | if ( excllock ) |
612 | return; | 611 | return; |
613 | 612 | ||
614 | excllock = true; | 613 | excllock = true; |
615 | 614 | ||
616 | bool wasloggedin = loggedin; | 615 | bool wasloggedin = loggedin; |
617 | loggedin=0; | 616 | loggedin=0; |
618 | suspendTime = QDateTime::currentDateTime(); | 617 | suspendTime = QDateTime::currentDateTime(); |
619 | 618 | ||
620 | qpe_setBacklight ( 0 ); // force LCD off | 619 | qpe_setBacklight ( 0 ); // force LCD off |
621 | 620 | ||
622 | if ( wasloggedin ) | 621 | if ( wasloggedin ) |
623 | blankScreen(); | 622 | blankScreen(); |
624 | 623 | ||
625 | ODevice::inst ( )-> suspend ( ); | 624 | ODevice::inst ( )-> suspend ( ); |
626 | 625 | ||
627 | QWSServer::screenSaverActivate ( false ); | 626 | QWSServer::screenSaverActivate ( false ); |
628 | 627 | ||
629 | qpe_setBacklight ( -3 ); // force LCD on | 628 | qpe_setBacklight ( -3 ); // force LCD on |
630 | 629 | ||
631 | { | 630 | { |
632 | QCopEnvelope("QPE/Card", "mtabChanged()" ); // might have changed while asleep | 631 | QCopEnvelope("QPE/Card", "mtabChanged()" ); // might have changed while asleep |
633 | } | 632 | } |
634 | 633 | ||
635 | if ( wasloggedin ) | 634 | if ( wasloggedin ) |
636 | login(TRUE); | 635 | login(TRUE); |
637 | 636 | ||
638 | execAutoStart(); | 637 | execAutoStart(); |
639 | //qcopBridge->closeOpenConnections(); | 638 | //qcopBridge->closeOpenConnections(); |
640 | //qDebug("called togglePower()!!!!!!"); | 639 | //qDebug("called togglePower()!!!!!!"); |
641 | 640 | ||
642 | qApp-> processEvents ( ); | 641 | qApp-> processEvents ( ); |
643 | 642 | ||
644 | excllock = false; | 643 | excllock = false; |
645 | } | 644 | } |
646 | 645 | ||
647 | void Desktop::toggleLight() | 646 | void Desktop::toggleLight() |
648 | { | 647 | { |
649 | QCopEnvelope e("QPE/System", "setBacklight(int)"); | 648 | QCopEnvelope e("QPE/System", "setBacklight(int)"); |
650 | e << -2; // toggle | 649 | e << -2; // toggle |
651 | } | 650 | } |
652 | 651 | ||
653 | void Desktop::toggleSymbolInput() | 652 | void Desktop::toggleSymbolInput() |
654 | { | 653 | { |
655 | tb->toggleSymbolInput(); | 654 | tb->toggleSymbolInput(); |
656 | } | 655 | } |
657 | 656 | ||
658 | void Desktop::toggleNumLockState() | 657 | void Desktop::toggleNumLockState() |
659 | { | 658 | { |
660 | tb->toggleNumLockState(); | 659 | tb->toggleNumLockState(); |
661 | } | 660 | } |
662 | 661 | ||
663 | void Desktop::toggleCapsLockState() | 662 | void Desktop::toggleCapsLockState() |
664 | { | 663 | { |
665 | tb->toggleCapsLockState(); | 664 | tb->toggleCapsLockState(); |
666 | } | 665 | } |
667 | 666 | ||
668 | void Desktop::styleChange( QStyle &s ) | 667 | void Desktop::styleChange( QStyle &s ) |
669 | { | 668 | { |
670 | QWidget::styleChange( s ); | 669 | QWidget::styleChange( s ); |
671 | int displayw = qApp->desktop()->width(); | 670 | int displayw = qApp->desktop()->width(); |
672 | int displayh = qApp->desktop()->height(); | 671 | int displayh = qApp->desktop()->height(); |
673 | 672 | ||
674 | QSize sz = tb->sizeHint(); | 673 | QSize sz = tb->sizeHint(); |
675 | 674 | ||
676 | tb->setGeometry( 0, displayh-sz.height(), displayw, sz.height() ); | 675 | tb->setGeometry( 0, displayh-sz.height(), displayw, sz.height() ); |
677 | } | 676 | } |
678 | 677 | ||
679 | void DesktopApplication::shutdown() | 678 | void DesktopApplication::shutdown() |
680 | { | 679 | { |
681 | if ( type() != GuiServer ) | 680 | if ( type() != GuiServer ) |
682 | return; | 681 | return; |
683 | ShutdownImpl *sd = new ShutdownImpl( 0, 0, WDestructiveClose ); | 682 | ShutdownImpl *sd = new ShutdownImpl( 0, 0, WDestructiveClose ); |
684 | connect( sd, SIGNAL(shutdown(ShutdownImpl::Type)), | 683 | connect( sd, SIGNAL(shutdown(ShutdownImpl::Type)), |
685 | this, SLOT(shutdown(ShutdownImpl::Type)) ); | 684 | this, SLOT(shutdown(ShutdownImpl::Type)) ); |
686 | sd->showMaximized(); | 685 | sd->showMaximized(); |
687 | } | 686 | } |
688 | 687 | ||
689 | void DesktopApplication::shutdown( ShutdownImpl::Type t ) | 688 | void DesktopApplication::shutdown( ShutdownImpl::Type t ) |
690 | { | 689 | { |
691 | switch ( t ) { | 690 | switch ( t ) { |
692 | case ShutdownImpl::ShutdownSystem: | 691 | case ShutdownImpl::ShutdownSystem: |
693 | execlp("shutdown", "shutdown", "-h", "now", (void*)0); | 692 | execlp("shutdown", "shutdown", "-h", "now", (void*)0); |
694 | break; | 693 | break; |
695 | case ShutdownImpl::RebootSystem: | 694 | case ShutdownImpl::RebootSystem: |
696 | execlp("shutdown", "shutdown", "-r", "now", (void*)0); | 695 | execlp("shutdown", "shutdown", "-r", "now", (void*)0); |
697 | break; | 696 | break; |
698 | case ShutdownImpl::RestartDesktop: | 697 | case ShutdownImpl::RestartDesktop: |
699 | restart(); | 698 | restart(); |
700 | break; | 699 | break; |
701 | case ShutdownImpl::TerminateDesktop: | 700 | case ShutdownImpl::TerminateDesktop: |
702 | prepareForTermination(FALSE); | 701 | prepareForTermination(FALSE); |
703 | 702 | ||
704 | // This is a workaround for a Qt bug | 703 | // This is a workaround for a Qt bug |
705 | // clipboard applet has to stop its poll timer, or Qt/E | 704 | // clipboard applet has to stop its poll timer, or Qt/E |
706 | // will hang on quit() right before it emits aboutToQuit() | 705 | // will hang on quit() right before it emits aboutToQuit() |
707 | emit aboutToQuit ( ); | 706 | emit aboutToQuit ( ); |
708 | 707 | ||
709 | quit(); | 708 | quit(); |
710 | break; | 709 | break; |
711 | } | 710 | } |
712 | } | 711 | } |
713 | 712 | ||
714 | void DesktopApplication::restart() | 713 | void DesktopApplication::restart() |
715 | { | 714 | { |
716 | prepareForTermination(TRUE); | 715 | prepareForTermination(TRUE); |
717 | 716 | ||
718 | #ifdef Q_WS_QWS | 717 | #ifdef Q_WS_QWS |
719 | for ( int fd = 3; fd < 100; fd++ ) | 718 | for ( int fd = 3; fd < 100; fd++ ) |
720 | close( fd ); | 719 | close( fd ); |
721 | #if defined(QT_DEMO_SINGLE_FLOPPY) | 720 | #if defined(QT_DEMO_SINGLE_FLOPPY) |
722 | execl( "/sbin/init", "qpe", 0 ); | 721 | execl( "/sbin/init", "qpe", 0 ); |
723 | #elif defined(QT_QWS_CASSIOPEIA) | 722 | #elif defined(QT_QWS_CASSIOPEIA) |
724 | execl( "/bin/sh", "sh", 0 ); | 723 | execl( "/bin/sh", "sh", 0 ); |
725 | #else | 724 | #else |
726 | execl( (qpeDir()+"/bin/qpe").latin1(), "qpe", 0 ); | 725 | execl( (qpeDir()+"/bin/qpe").latin1(), "qpe", 0 ); |
727 | #endif | 726 | #endif |
728 | exit(1); | 727 | exit(1); |
729 | #endif | 728 | #endif |
730 | } | 729 | } |
731 | 730 | ||
732 | void Desktop::startTransferServer() | 731 | void Desktop::startTransferServer() |
733 | { | 732 | { |
734 | // start qcop bridge server | 733 | // start qcop bridge server |
735 | qcopBridge = new QCopBridge( 4243 ); | 734 | qcopBridge = new QCopBridge( 4243 ); |
736 | if ( !qcopBridge->ok() ) { | 735 | if ( !qcopBridge->ok() ) { |
737 | delete qcopBridge; | 736 | delete qcopBridge; |
738 | qcopBridge = 0; | 737 | qcopBridge = 0; |
739 | } | 738 | } |
740 | // start transfer server | 739 | // start transfer server |
741 | transferServer = new TransferServer( 4242 ); | 740 | transferServer = new TransferServer( 4242 ); |
742 | if ( !transferServer->ok() ) { | 741 | if ( !transferServer->ok() ) { |
743 | delete transferServer; | 742 | delete transferServer; |
744 | transferServer = 0; | 743 | transferServer = 0; |
745 | } | 744 | } |
746 | if ( !transferServer || !qcopBridge ) | 745 | if ( !transferServer || !qcopBridge ) |
747 | startTimer( 2000 ); | 746 | startTimer( 2000 ); |
748 | } | 747 | } |
749 | 748 | ||
750 | void Desktop::timerEvent( QTimerEvent *e ) | 749 | void Desktop::timerEvent( QTimerEvent *e ) |
751 | { | 750 | { |
752 | killTimer( e->timerId() ); | 751 | killTimer( e->timerId() ); |
753 | startTransferServer(); | 752 | startTransferServer(); |
754 | } | 753 | } |
755 | 754 | ||
756 | void Desktop::terminateServers() | 755 | void Desktop::terminateServers() |
757 | { | 756 | { |
758 | delete transferServer; | 757 | delete transferServer; |
759 | delete qcopBridge; | 758 | delete qcopBridge; |
760 | transferServer = 0; | 759 | transferServer = 0; |
761 | qcopBridge = 0; | 760 | qcopBridge = 0; |
762 | } | 761 | } |
763 | 762 | ||
764 | void Desktop::rereadVolumes() | 763 | void Desktop::rereadVolumes() |
765 | { | 764 | { |
766 | Config cfg("qpe"); | 765 | Config cfg("qpe"); |
767 | cfg.setGroup("Volume"); | 766 | cfg.setGroup("Volume"); |
768 | touchclick = cfg.readBoolEntry("TouchSound"); | 767 | touchclick = cfg.readBoolEntry("TouchSound"); |
769 | keyclick = cfg.readBoolEntry("KeySound"); | 768 | keyclick = cfg.readBoolEntry("KeySound"); |
770 | alarmsound = cfg.readBoolEntry("AlarmSound"); | 769 | alarmsound = cfg.readBoolEntry("AlarmSound"); |
771 | // Config cfg("Sound"); | 770 | // Config cfg("Sound"); |
772 | // cfg.setGroup("System"); | 771 | // cfg.setGroup("System"); |
773 | // touchclick = cfg.readBoolEntry("Touch"); | 772 | // touchclick = cfg.readBoolEntry("Touch"); |
774 | // keyclick = cfg.readBoolEntry("Key"); | 773 | // keyclick = cfg.readBoolEntry("Key"); |
775 | } | 774 | } |
776 | 775 | ||
777 | void Desktop::keyClick() | 776 | void Desktop::keyClick() |
778 | { | 777 | { |
779 | if ( keyclick ) | 778 | if ( keyclick ) |
780 | ODevice::inst ( )-> keySound ( ); | 779 | ODevice::inst ( )-> keySound ( ); |
781 | } | 780 | } |
782 | 781 | ||
783 | void Desktop::screenClick() | 782 | void Desktop::screenClick() |
784 | { | 783 | { |
785 | if ( touchclick ) | 784 | if ( touchclick ) |
786 | ODevice::inst ( )-> touchSound ( ); | 785 | ODevice::inst ( )-> touchSound ( ); |
787 | } | 786 | } |
788 | 787 | ||
789 | void Desktop::soundAlarm() | 788 | void Desktop::soundAlarm() |
790 | { | 789 | { |
791 | if ( qpedesktop-> alarmsound ) | 790 | if ( qpedesktop-> alarmsound ) |
792 | ODevice::inst ( )-> alarmSound ( ); | 791 | ODevice::inst ( )-> alarmSound ( ); |
793 | } | 792 | } |
794 | 793 | ||
795 | bool Desktop::eventFilter( QObject *, QEvent *ev ) | 794 | bool Desktop::eventFilter( QObject *, QEvent *ev ) |
796 | { | 795 | { |
797 | if ( ev-> type ( ) == QEvent::KeyPress ) { | 796 | if ( ev-> type ( ) == QEvent::KeyPress ) { |
798 | QKeyEvent *ke = (QKeyEvent *) ev; | 797 | QKeyEvent *ke = (QKeyEvent *) ev; |
799 | if ( ke-> key ( ) == Qt::Key_F11 ) { // menu key | 798 | if ( ke-> key ( ) == Qt::Key_F11 ) { // menu key |
800 | QWidget *active = qApp-> activeWindow ( ); | 799 | QWidget *active = qApp-> activeWindow ( ); |
801 | 800 | ||
802 | if ( active && active-> isPopup ( )) | 801 | if ( active && active-> isPopup ( )) |
803 | active->close(); | 802 | active->close(); |
804 | 803 | ||
805 | raiseMenu ( ); | 804 | raiseMenu ( ); |
806 | return true; | 805 | return true; |
807 | } | 806 | } |
808 | } | 807 | } |
809 | return false; | 808 | return false; |
810 | } | 809 | } |