summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--library/applicationinterface.h33
-rw-r--r--library/fontfactoryinterface.h15
-rw-r--r--library/imagecodecinterface.h13
-rw-r--r--library/qpeapplication.cpp6
-rw-r--r--library/qpeapplication.h40
-rw-r--r--library/styleinterface.h24
6 files changed, 116 insertions, 15 deletions
diff --git a/library/applicationinterface.h b/library/applicationinterface.h
index b37a2c5..b7648f6 100644
--- a/library/applicationinterface.h
+++ b/library/applicationinterface.h
@@ -1,32 +1,65 @@
1/* 1/*
2 * GPLv2 (C) 2002-2003 Trolltech 2 * GPLv2 (C) 2002-2003 Trolltech
3 * (C) 2003 zecke@handhelds.org 3 * (C) 2003 zecke@handhelds.org
4 */ 4 */
5 5
6 6
7#ifndef APPLICATIONINTERFACE_H 7#ifndef APPLICATIONINTERFACE_H
8#define APPLICATIONINTERFACE_H 8#define APPLICATIONINTERFACE_H
9 9
10#include <qstringlist.h> 10#include <qstringlist.h>
11#include <qtopia/qcom.h> 11#include <qtopia/qcom.h>
12 12
13#ifndef QT_NO_COMPONENT 13#ifndef QT_NO_COMPONENT
14// {07E15B48-B947-4334-B866-D2AD58157D8C} 14// {07E15B48-B947-4334-B866-D2AD58157D8C}
15#ifndef IID_QtopiaApplication 15#ifndef IID_QtopiaApplication
16#define IID_QtopiaApplication QUuid( 0x07e15b48, 0xb947, 0x4334, 0xb8, 0x66, 0xd2, 0xad, 0x58, 0x15, 0x7d, 0x8c) 16#define IID_QtopiaApplication QUuid( 0x07e15b48, 0xb947, 0x4334, 0xb8, 0x66, 0xd2, 0xad, 0x58, 0x15, 0x7d, 0x8c)
17#endif 17#endif
18#endif 18#endif
19 19
20
21/**
22 * \brief Application interface currently used by the quicklaunch framework
23 *
24 * This is the interface to be exposed by applications available as DSO
25 * Normally one would use the OApplicationFactory which does the magic of
26 * exposing the interface.
27 *
28 *
29 * Resulting dynamic shared objects (dso) need to go into the
30 * OPIEDIR/plugins/application.
31 *
32 *
33 * You can use this interface to load applications into your application.
34 * @todo Implement Services + Trader
35 * @since Opie 1.0.2
36 */
20struct ApplicationInterface : public QUnknownInterface 37struct ApplicationInterface : public QUnknownInterface
21{ 38{
22public: 39public:
40
41 /**
42 * \brief create the mainwindow for the giving application name
43 * Create a main window for the giving application name
44 *
45 * @param appName The application widget to be created
46 * @param parent The parent of the newly created widget
47 * @param name The name of the QObject
48 * @param f Possible Window Flags
49 *
50 * @return the widget or 0l
51 */
23 virtual QWidget *createMainWindow( const QString &appName, QWidget *parent=0, 52 virtual QWidget *createMainWindow( const QString &appName, QWidget *parent=0,
24 const char *name=0, Qt::WFlags f=0 ) = 0; 53 const char *name=0, Qt::WFlags f=0 ) = 0;
54
55 /**
56 * The list of application windows supported
57 */
25 virtual QStringList applications() const = 0; 58 virtual QStringList applications() const = 0;
26}; 59};
27 60
28/* 61/*
29 * Use an extended interface for QObejct, Opie::Part in the future 62 * Use an extended interface for QObejct, Opie::Part in the future
30 */ 63 */
31 64
32#endif 65#endif
diff --git a/library/fontfactoryinterface.h b/library/fontfactoryinterface.h
index ed65dfa..68b0be5 100644
--- a/library/fontfactoryinterface.h
+++ b/library/fontfactoryinterface.h
@@ -1,41 +1,56 @@
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#ifndef FONTFACTORYINTERFACE_H 20#ifndef FONTFACTORYINTERFACE_H
21#define FONTFACTORYINTERFACE_H 21#define FONTFACTORYINTERFACE_H
22 22
23#include <qnamespace.h> 23#include <qnamespace.h>
24#include <qstring.h> 24#include <qstring.h>
25#include <qpe/qcom.h> 25#include <qpe/qcom.h>
26 26
27class QFontFactory; 27class QFontFactory;
28 28
29#ifndef QT_NO_COMPONENT 29#ifndef QT_NO_COMPONENT
30// {7F194DD6-FAA3-498F-8F30-9C297A570DFA} 30// {7F194DD6-FAA3-498F-8F30-9C297A570DFA}
31#ifndef IID_FontFactory 31#ifndef IID_FontFactory
32#define IID_FontFactory QUuid( 0x7f194dd6, 0xfaa3, 0x498f, 0x8f, 0x30, 0x9c, 0x29, 0x7a, 0x57, 0x0d, 0xfa) 32#define IID_FontFactory QUuid( 0x7f194dd6, 0xfaa3, 0x498f, 0x8f, 0x30, 0x9c, 0x29, 0x7a, 0x57, 0x0d, 0xfa)
33#endif 33#endif
34#endif 34#endif
35 35
36
37/**
38 * \brief Interface for additional Font Factories
39 *
40 * To add special types of fonts TrueTypes or your very own
41 * format. If you implement this Interface you can add
42 * custom font loading.
43 *
44 * The dynamic shared object goes to
45 * OPIEDIR/plugins/fontfactories.
46 *
47 * As of version Opie 1.0.2 loading of the plugins is not
48 * yet implemented
49 *
50 */
36struct FontFactoryInterface : public QUnknownInterface 51struct FontFactoryInterface : public QUnknownInterface
37{ 52{
38 virtual QFontFactory *fontFactory() = 0; 53 virtual QFontFactory *fontFactory() = 0;
39}; 54};
40 55
41#endif 56#endif
diff --git a/library/imagecodecinterface.h b/library/imagecodecinterface.h
index 8306b68..3b1cd7b 100644
--- a/library/imagecodecinterface.h
+++ b/library/imagecodecinterface.h
@@ -1,39 +1,52 @@
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#ifndef IMAGECODECINTERFACE_H 20#ifndef IMAGECODECINTERFACE_H
21#define IMAGECODECINTERFACE_H 21#define IMAGECODECINTERFACE_H
22 22
23#include <qstringlist.h> 23#include <qstringlist.h>
24#include <qpe/qcom.h> 24#include <qpe/qcom.h>
25 25
26#ifndef QT_NO_COMPONENT 26#ifndef QT_NO_COMPONENT
27#ifndef IID_QtopiaImageCodec 27#ifndef IID_QtopiaImageCodec
28#define IID_QtopiaImageCodec QUuid(0x09bf6906, 0x1549, 0xbb4a, 0x18, 0xba, 0xb9, 0xe7, 0x0a, 0x6e, 0x4d, 0x1e) 28#define IID_QtopiaImageCodec QUuid(0x09bf6906, 0x1549, 0xbb4a, 0x18, 0xba, 0xb9, 0xe7, 0x0a, 0x6e, 0x4d, 0x1e)
29#endif 29#endif
30#endif 30#endif
31 31
32
33/**
34 *
35 * \brief add Image Codecs
36 *
37 * This interface will be queried to add new Image loading
38 * and saving routines.
39 *
40 * The ImageCodec needs to be placed in OPIEDIR/plugins/imagecodecs.
41 *
42 * @see QImage
43 * @see QImageIO
44 **/
32struct ImageCodecInterface : public QUnknownInterface 45struct ImageCodecInterface : public QUnknownInterface
33{ 46{
34public: 47public:
35 virtual QStringList keys() const = 0; 48 virtual QStringList keys() const = 0;
36 virtual bool installIOHandler( const QString &format ) = 0; 49 virtual bool installIOHandler( const QString &format ) = 0;
37}; 50};
38 51
39#endif 52#endif
diff --git a/library/qpeapplication.cpp b/library/qpeapplication.cpp
index a97efc0..6f2e43b 100644
--- a/library/qpeapplication.cpp
+++ b/library/qpeapplication.cpp
@@ -246,386 +246,386 @@ public:
246 list = dir.entryList(); 246 list = dir.entryList();
247 QStringList::Iterator it; 247 QStringList::Iterator it;
248 for ( it = list.begin(); it != list.end(); ++it ) { 248 for ( it = list.begin(); it != list.end(); ++it ) {
249 TextCodecInterface *iface = 0; 249 TextCodecInterface *iface = 0;
250 QLibrary *lib = new QLibrary( path + "/" + *it ); 250 QLibrary *lib = new QLibrary( path + "/" + *it );
251 if ( lib->queryInterface( IID_QtopiaTextCodec, (QUnknownInterface**)&iface ) == QS_OK && iface ) { 251 if ( lib->queryInterface( IID_QtopiaTextCodec, (QUnknownInterface**)&iface ) == QS_OK && iface ) {
252 QValueList<int> mibs = iface->mibEnums(); 252 QValueList<int> mibs = iface->mibEnums();
253 for (QValueList<int>::ConstIterator i = mibs.begin(); i != mibs.end(); ++i) { 253 for (QValueList<int>::ConstIterator i = mibs.begin(); i != mibs.end(); ++i) {
254 (void)iface->createForMib(*i); 254 (void)iface->createForMib(*i);
255 // ### it exists now; need to remember if we can delete it 255 // ### it exists now; need to remember if we can delete it
256 } 256 }
257 } 257 }
258 else { 258 else {
259 lib->unload(); 259 lib->unload();
260 delete lib; 260 delete lib;
261 } 261 }
262 } 262 }
263 } 263 }
264 264
265 void loadImageCodecs() 265 void loadImageCodecs()
266 { 266 {
267 QString path = QPEApplication::qpeDir() + "/plugins/imagecodecs"; 267 QString path = QPEApplication::qpeDir() + "/plugins/imagecodecs";
268#ifdef Q_OS_MACX 268#ifdef Q_OS_MACX
269 QDir dir( path, "lib*.dylib" ); 269 QDir dir( path, "lib*.dylib" );
270#else 270#else
271 QDir dir( path, "lib*.so" ); 271 QDir dir( path, "lib*.so" );
272#endif 272#endif
273 QStringList list; 273 QStringList list;
274 if ( dir. exists ( )) 274 if ( dir. exists ( ))
275 list = dir.entryList(); 275 list = dir.entryList();
276 QStringList::Iterator it; 276 QStringList::Iterator it;
277 for ( it = list.begin(); it != list.end(); ++it ) { 277 for ( it = list.begin(); it != list.end(); ++it ) {
278 ImageCodecInterface *iface = 0; 278 ImageCodecInterface *iface = 0;
279 QLibrary *lib = new QLibrary( path + "/" + *it ); 279 QLibrary *lib = new QLibrary( path + "/" + *it );
280 if ( lib->queryInterface( IID_QtopiaImageCodec, (QUnknownInterface**)&iface ) == QS_OK && iface ) { 280 if ( lib->queryInterface( IID_QtopiaImageCodec, (QUnknownInterface**)&iface ) == QS_OK && iface ) {
281 QStringList formats = iface->keys(); 281 QStringList formats = iface->keys();
282 for (QStringList::ConstIterator i = formats.begin(); i != formats.end(); ++i) { 282 for (QStringList::ConstIterator i = formats.begin(); i != formats.end(); ++i) {
283 (void)iface->installIOHandler(*i); 283 (void)iface->installIOHandler(*i);
284 // ### it exists now; need to remember if we can delete it 284 // ### it exists now; need to remember if we can delete it
285 } 285 }
286 } 286 }
287 else { 287 else {
288 lib->unload(); 288 lib->unload();
289 delete lib; 289 delete lib;
290 } 290 }
291 } 291 }
292 } 292 }
293}; 293};
294 294
295class ResourceMimeFactory : public QMimeSourceFactory 295class ResourceMimeFactory : public QMimeSourceFactory
296{ 296{
297public: 297public:
298 ResourceMimeFactory() : resImage( 0 ) 298 ResourceMimeFactory() : resImage( 0 )
299 { 299 {
300 setFilePath( Global::helpPath() ); 300 setFilePath( Global::helpPath() );
301 setExtensionType( "html", "text/html;charset=UTF-8" ); 301 setExtensionType( "html", "text/html;charset=UTF-8" );
302 } 302 }
303 ~ResourceMimeFactory() { 303 ~ResourceMimeFactory() {
304 delete resImage; 304 delete resImage;
305 } 305 }
306 306
307 const QMimeSource* data( const QString& abs_name ) const 307 const QMimeSource* data( const QString& abs_name ) const
308 { 308 {
309 const QMimeSource * r = QMimeSourceFactory::data( abs_name ); 309 const QMimeSource * r = QMimeSourceFactory::data( abs_name );
310 if ( !r ) { 310 if ( !r ) {
311 int sl = abs_name.length(); 311 int sl = abs_name.length();
312 do { 312 do {
313 sl = abs_name.findRev( '/', sl - 1 ); 313 sl = abs_name.findRev( '/', sl - 1 );
314 QString name = sl >= 0 ? abs_name.mid( sl + 1 ) : abs_name; 314 QString name = sl >= 0 ? abs_name.mid( sl + 1 ) : abs_name;
315 int dot = name.findRev( '.' ); 315 int dot = name.findRev( '.' );
316 if ( dot >= 0 ) 316 if ( dot >= 0 )
317 name = name.left( dot ); 317 name = name.left( dot );
318 QImage img = Resource::loadImage( name ); 318 QImage img = Resource::loadImage( name );
319 if ( !img.isNull() ) { 319 if ( !img.isNull() ) {
320 delete resImage; 320 delete resImage;
321 resImage = new QImageDrag( img ); 321 resImage = new QImageDrag( img );
322 r = resImage; 322 r = resImage;
323 } 323 }
324 } 324 }
325 while ( !r && sl > 0 ); 325 while ( !r && sl > 0 );
326 } 326 }
327 return r; 327 return r;
328 } 328 }
329private: 329private:
330 mutable QImageDrag *resImage; 330 mutable QImageDrag *resImage;
331}; 331};
332 332
333static int& hack(int& i) 333static int& hack(int& i)
334{ 334{
335#if QT_VERSION <= 230 && defined(QT_NO_CODECS) 335#if QT_VERSION <= 230 && defined(QT_NO_CODECS)
336 // These should be created, but aren't in Qt 2.3.0 336 // These should be created, but aren't in Qt 2.3.0
337 (void)new QUtf8Codec; 337 (void)new QUtf8Codec;
338 (void)new QUtf16Codec; 338 (void)new QUtf16Codec;
339#endif 339#endif
340 return i; 340 return i;
341} 341}
342 342
343static int muted = 0; 343static int muted = 0;
344static int micMuted = 0; 344static int micMuted = 0;
345 345
346static void setVolume( int t = 0, int percent = -1 ) 346static void setVolume( int t = 0, int percent = -1 )
347{ 347{
348 switch ( t ) { 348 switch ( t ) {
349 case 0: { 349 case 0: {
350 Config cfg( "qpe" ); 350 Config cfg( "qpe" );
351 cfg.setGroup( "Volume" ); 351 cfg.setGroup( "Volume" );
352 if ( percent < 0 ) 352 if ( percent < 0 )
353 percent = cfg.readNumEntry( "VolumePercent", 50 ); 353 percent = cfg.readNumEntry( "VolumePercent", 50 );
354#ifndef QT_NO_SOUND 354#ifndef QT_NO_SOUND
355 int fd = 0; 355 int fd = 0;
356 if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) { 356 if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) {
357 int vol = muted ? 0 : percent; 357 int vol = muted ? 0 : percent;
358 // set both channels to same volume 358 // set both channels to same volume
359 vol |= vol << 8; 359 vol |= vol << 8;
360 ioctl( fd, MIXER_WRITE( 0 ), &vol ); 360 ioctl( fd, MIXER_WRITE( 0 ), &vol );
361 ::close( fd ); 361 ::close( fd );
362 } 362 }
363#endif 363#endif
364 } 364 }
365 break; 365 break;
366 } 366 }
367} 367}
368 368
369static void setMic( int t = 0, int percent = -1 ) 369static void setMic( int t = 0, int percent = -1 )
370{ 370{
371 switch ( t ) { 371 switch ( t ) {
372 case 0: { 372 case 0: {
373 Config cfg( "qpe" ); 373 Config cfg( "qpe" );
374 cfg.setGroup( "Volume" ); 374 cfg.setGroup( "Volume" );
375 if ( percent < 0 ) 375 if ( percent < 0 )
376 percent = cfg.readNumEntry( "Mic", 50 ); 376 percent = cfg.readNumEntry( "Mic", 50 );
377 377
378#ifndef QT_NO_SOUND 378#ifndef QT_NO_SOUND
379 int fd = 0; 379 int fd = 0;
380 int mic = micMuted ? 0 : percent; 380 int mic = micMuted ? 0 : percent;
381 if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) { 381 if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) {
382 ioctl( fd, MIXER_WRITE( SOUND_MIXER_MIC ), &mic ); 382 ioctl( fd, MIXER_WRITE( SOUND_MIXER_MIC ), &mic );
383 ::close( fd ); 383 ::close( fd );
384 } 384 }
385#endif 385#endif
386 } 386 }
387 break; 387 break;
388 } 388 }
389} 389}
390 390
391 391
392static void setBass( int t = 0, int percent = -1 ) 392static void setBass( int t = 0, int percent = -1 )
393{ 393{
394 switch ( t ) { 394 switch ( t ) {
395 case 0: { 395 case 0: {
396 Config cfg( "qpe" ); 396 Config cfg( "qpe" );
397 cfg.setGroup( "Volume" ); 397 cfg.setGroup( "Volume" );
398 if ( percent < 0 ) 398 if ( percent < 0 )
399 percent = cfg.readNumEntry( "BassPercent", 50 ); 399 percent = cfg.readNumEntry( "BassPercent", 50 );
400 400
401#ifndef QT_NO_SOUND 401#ifndef QT_NO_SOUND
402 int fd = 0; 402 int fd = 0;
403 int bass = percent; 403 int bass = percent;
404 if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) { 404 if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) {
405 ioctl( fd, MIXER_WRITE( SOUND_MIXER_BASS ), &bass ); 405 ioctl( fd, MIXER_WRITE( SOUND_MIXER_BASS ), &bass );
406 ::close( fd ); 406 ::close( fd );
407 } 407 }
408#endif 408#endif
409 } 409 }
410 break; 410 break;
411 } 411 }
412} 412}
413 413
414 414
415static void setTreble( int t = 0, int percent = -1 ) 415static void setTreble( int t = 0, int percent = -1 )
416{ 416{
417 switch ( t ) { 417 switch ( t ) {
418 case 0: { 418 case 0: {
419 Config cfg( "qpe" ); 419 Config cfg( "qpe" );
420 cfg.setGroup( "Volume" ); 420 cfg.setGroup( "Volume" );
421 if ( percent < 0 ) 421 if ( percent < 0 )
422 percent = cfg.readNumEntry( "TreblePercent", 50 ); 422 percent = cfg.readNumEntry( "TreblePercent", 50 );
423 423
424#ifndef QT_NO_SOUND 424#ifndef QT_NO_SOUND
425 int fd = 0; 425 int fd = 0;
426 int treble = percent; 426 int treble = percent;
427 if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) { 427 if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) {
428 ioctl( fd, MIXER_WRITE( SOUND_MIXER_TREBLE ), &treble ); 428 ioctl( fd, MIXER_WRITE( SOUND_MIXER_TREBLE ), &treble );
429 ::close( fd ); 429 ::close( fd );
430 } 430 }
431#endif 431#endif
432 } 432 }
433 break; 433 break;
434 } 434 }
435} 435}
436 436
437 437
438/*! 438/**
439 \class QPEApplication qpeapplication.h 439 \class QPEApplication
440 \brief The QPEApplication class implements various system services 440 \brief The QPEApplication class implements various system services
441 that are available to all Qtopia applications. 441 that are available to all Qtopia applications.
442 442
443 Simply by using QPEApplication instead of QApplication, a standard Qt 443 Simply by using QPEApplication instead of QApplication, a standard Qt
444 application becomes a Qtopia application. It automatically follows 444 application becomes a Qtopia application. It automatically follows
445 style changes, quits and raises, and in the 445 style changes, quits and raises, and in the
446 case of \link docwidget.html document-oriented\endlink applications, 446 case of \link docwidget.html document-oriented\endlink applications,
447 changes the currently displayed document in response to the environment. 447 changes the currently displayed document in response to the environment.
448 448
449 To create a \link docwidget.html document-oriented\endlink 449 To create a \link docwidget.html document-oriented\endlink
450 application use showMainDocumentWidget(); to create a 450 application use showMainDocumentWidget(); to create a
451 non-document-oriented application use showMainWidget(). The 451 non-document-oriented application use showMainWidget(). The
452 keepRunning() function indicates whether the application will 452 keepRunning() function indicates whether the application will
453 continue running after it's processed the last \link qcop.html 453 continue running after it's processed the last \link qcop.html
454 QCop\endlink message. This can be changed using setKeepRunning(). 454 QCop\endlink message. This can be changed using setKeepRunning().
455 455
456 A variety of signals are emitted when certain events occur, for 456 A variety of signals are emitted when certain events occur, for
457 example, timeChanged(), clockChanged(), weekChanged(), 457 example, timeChanged(), clockChanged(), weekChanged(),
458 dateFormatChanged() and volumeChanged(). If the application receives 458 dateFormatChanged() and volumeChanged(). If the application receives
459 a \link qcop.html QCop\endlink message on the application's 459 a \link qcop.html QCop\endlink message on the application's
460 QPE/Application/\e{appname} channel, the appMessage() signal is 460 QPE/Application/\e{appname} channel, the appMessage() signal is
461 emitted. There are also flush() and reload() signals, which 461 emitted. There are also flush() and reload() signals, which
462 are emitted when synching begins and ends respectively - upon these 462 are emitted when synching begins and ends respectively - upon these
463 signals, the application should save and reload any data 463 signals, the application should save and reload any data
464 files that are involved in synching. Most of these signals will initially 464 files that are involved in synching. Most of these signals will initially
465 be received and unfiltered through the appMessage() signal. 465 be received and unfiltered through the appMessage() signal.
466 466
467 This class also provides a set of useful static functions. The 467 This class also provides a set of useful static functions. The
468 qpeDir() and documentDir() functions return the respective paths. 468 qpeDir() and documentDir() functions return the respective paths.
469 The grabKeyboard() and ungrabKeyboard() functions are used to 469 The grabKeyboard() and ungrabKeyboard() functions are used to
470 control whether the application takes control of the device's 470 control whether the application takes control of the device's
471 physical buttons (e.g. application launch keys). The stylus' mode of 471 physical buttons (e.g. application launch keys). The stylus' mode of
472 operation is set with setStylusOperation() and retrieved with 472 operation is set with setStylusOperation() and retrieved with
473 stylusOperation(). There are also setInputMethodHint() and 473 stylusOperation(). There are also setInputMethodHint() and
474 inputMethodHint() functions. 474 inputMethodHint() functions.
475 475
476 \ingroup qtopiaemb 476 \ingroup qtopiaemb
477*/ 477*/
478 478
479/*! 479/*!
480 \fn void QPEApplication::clientMoused() 480 \fn void QPEApplication::clientMoused()
481 481
482 \internal 482 \internal
483*/ 483*/
484 484
485/*! 485/*!
486 \fn void QPEApplication::timeChanged(); 486 \fn void QPEApplication::timeChanged();
487 This signal is emitted when the time changes outside the normal 487 This signal is emitted when the time changes outside the normal
488 passage of time, i.e. if the time is set backwards or forwards. 488 passage of time, i.e. if the time is set backwards or forwards.
489*/ 489*/
490 490
491/*! 491/*!
492 \fn void QPEApplication::clockChanged( bool ampm ); 492 \fn void QPEApplication::clockChanged( bool ampm );
493 493
494 This signal is emitted when the user changes the clock's style. If 494 This signal is emitted when the user changes the clock's style. If
495 \a ampm is TRUE, the user wants a 12-hour AM/PM clock, otherwise, 495 \a ampm is TRUE, the user wants a 12-hour AM/PM clock, otherwise,
496 they want a 24-hour clock. 496 they want a 24-hour clock.
497*/ 497*/
498 498
499/*! 499/*!
500 \fn void QPEApplication::volumeChanged( bool muted ) 500 \fn void QPEApplication::volumeChanged( bool muted )
501 501
502 This signal is emitted whenever the mute state is changed. If \a 502 This signal is emitted whenever the mute state is changed. If \a
503 muted is TRUE, then sound output has been muted. 503 muted is TRUE, then sound output has been muted.
504*/ 504*/
505 505
506/*! 506/*!
507 \fn void QPEApplication::weekChanged( bool startOnMonday ) 507 \fn void QPEApplication::weekChanged( bool startOnMonday )
508 508
509 This signal is emitted if the week start day is changed. If \a 509 This signal is emitted if the week start day is changed. If \a
510 startOnMonday is TRUE then the first day of the week is Monday; if 510 startOnMonday is TRUE then the first day of the week is Monday; if
511 \a startOnMonday is FALSE then the first day of the week is 511 \a startOnMonday is FALSE then the first day of the week is
512 Sunday. 512 Sunday.
513*/ 513*/
514 514
515/*! 515/*!
516 \fn void QPEApplication::dateFormatChanged(DateFormat) 516 \fn void QPEApplication::dateFormatChanged(DateFormat)
517 517
518 This signal is emitted whenever the date format is changed. 518 This signal is emitted whenever the date format is changed.
519*/ 519*/
520 520
521/*! 521/*!
522 \fn void QPEApplication::flush() 522 \fn void QPEApplication::flush()
523 523
524 ### 524 ###
525*/ 525*/
526 526
527/*! 527/*!
528 \fn void QPEApplication::reload() 528 \fn void QPEApplication::reload()
529 529
530*/ 530*/
531 531
532 532
533 533
534void QPEApplication::processQCopFile() 534void QPEApplication::processQCopFile()
535{ 535{
536 QString qcopfn("/tmp/qcop-msg-"); 536 QString qcopfn("/tmp/qcop-msg-");
537 qcopfn += d->appName; // append command name 537 qcopfn += d->appName; // append command name
538 538
539 QFile f(qcopfn); 539 QFile f(qcopfn);
540 if ( f.open(IO_ReadWrite) ) { 540 if ( f.open(IO_ReadWrite) ) {
541#ifndef Q_OS_WIN32 541#ifndef Q_OS_WIN32
542 flock(f.handle(), LOCK_EX); 542 flock(f.handle(), LOCK_EX);
543#endif 543#endif
544 QDataStream ds(&f); 544 QDataStream ds(&f);
545 QCString channel, message; 545 QCString channel, message;
546 QByteArray data; 546 QByteArray data;
547 while(!ds.atEnd()) { 547 while(!ds.atEnd()) {
548 ds >> channel >> message >> data; 548 ds >> channel >> message >> data;
549 d->enqueueQCop(channel,message,data); 549 d->enqueueQCop(channel,message,data);
550 } 550 }
551 ::ftruncate(f.handle(), 0); 551 ::ftruncate(f.handle(), 0);
552#ifndef Q_OS_WIN32 552#ifndef Q_OS_WIN32
553 f.flush(); 553 f.flush();
554 flock(f.handle(), LOCK_UN); 554 flock(f.handle(), LOCK_UN);
555#endif 555#endif
556 } 556 }
557#endif 557#endif
558} 558}
559 559
560 560
561/*! 561/*!
562 \fn void QPEApplication::appMessage( const QCString& msg, const QByteArray& data ) 562 \fn void QPEApplication::appMessage( const QCString& msg, const QByteArray& data )
563 563
564 This signal is emitted when a message is received on this 564 This signal is emitted when a message is received on this
565 application's QPE/Application/<i>appname</i> \link qcop.html 565 application's QPE/Application/<i>appname</i> \link qcop.html
566 QCop\endlink channel. 566 QCop\endlink channel.
567 567
568 The slot to which you connect this signal uses \a msg and \a data 568 The slot to which you connect this signal uses \a msg and \a data
569 in the following way: 569 in the following way:
570 570
571\code 571\code
572 void MyWidget::receive( const QCString& msg, const QByteArray& data ) 572 void MyWidget::receive( const QCString& msg, const QByteArray& data )
573 { 573 {
574 QDataStream stream( data, IO_ReadOnly ); 574 QDataStream stream( data, IO_ReadOnly );
575 if ( msg == "someMessage(int,int,int)" ) { 575 if ( msg == "someMessage(int,int,int)" ) {
576 int a,b,c; 576 int a,b,c;
577 stream >> a >> b >> c; 577 stream >> a >> b >> c;
578 ... 578 ...
579 } else if ( msg == "otherMessage(QString)" ) { 579 } else if ( msg == "otherMessage(QString)" ) {
580 ... 580 ...
581 } 581 }
582 } 582 }
583\endcode 583\endcode
584 584
585 \sa qcop.html 585 \sa qcop.html
586 Note that messages received here may be processed by qpe application 586 Note that messages received here may be processed by qpe application
587 and emitted as signals, such as flush() and reload(). 587 and emitted as signals, such as flush() and reload().
588*/ 588*/
589 589
590/*! 590/*!
591 Constructs a QPEApplication just as you would construct 591 Constructs a QPEApplication just as you would construct
592 a QApplication, passing \a argc, \a argv, and \a t. 592 a QApplication, passing \a argc, \a argv, and \a t.
593 593
594 For applications, \a t should be the default, GuiClient. Only 594 For applications, \a t should be the default, GuiClient. Only
595 the Qtopia server passes GuiServer. 595 the Qtopia server passes GuiServer.
596*/ 596*/
597QPEApplication::QPEApplication( int & argc, char **argv, Type t ) 597QPEApplication::QPEApplication( int & argc, char **argv, Type t )
598 : QApplication( hack(argc), argv, t ), pidChannel( 0 ) 598 : QApplication( hack(argc), argv, t ), pidChannel( 0 )
599{ 599{
600 QPixmapCache::setCacheLimit(256); // sensible default for smaller devices. 600 QPixmapCache::setCacheLimit(256); // sensible default for smaller devices.
601 601
602 d = new QPEApplicationData; 602 d = new QPEApplicationData;
603 d->loadTextCodecs(); 603 d->loadTextCodecs();
604 d->loadImageCodecs(); 604 d->loadImageCodecs();
605 int dw = desktop() ->width(); 605 int dw = desktop() ->width();
606 606
607 if ( dw < 200 ) { 607 if ( dw < 200 ) {
608 setFont( QFont( "vera", 8 ) ); 608 setFont( QFont( "vera", 8 ) );
609 AppLnk::setSmallIconSize( 10 ); 609 AppLnk::setSmallIconSize( 10 );
610 AppLnk::setBigIconSize( 28 ); 610 AppLnk::setBigIconSize( 28 );
611 } 611 }
612#if defined(OPIE_HIGH_RES_SMALL_PHY) 612#if defined(OPIE_HIGH_RES_SMALL_PHY)
613 else if ( dw > 600 ) { 613 else if ( dw > 600 ) {
614 setFont( QFont( "vera", 16 ) ); 614 setFont( QFont( "vera", 16 ) );
615 AppLnk::setSmallIconSize( 24 ); 615 AppLnk::setSmallIconSize( 24 );
616 AppLnk::setBigIconSize( 48 ); 616 AppLnk::setBigIconSize( 48 );
617 } 617 }
618#endif 618#endif
619 else if ( dw > 200 ) { 619 else if ( dw > 200 ) {
620 setFont( QFont( "vera", 10 ) ); 620 setFont( QFont( "vera", 10 ) );
621 AppLnk::setSmallIconSize( 14 ); 621 AppLnk::setSmallIconSize( 14 );
622 AppLnk::setBigIconSize( 32 ); 622 AppLnk::setBigIconSize( 32 );
623 } 623 }
624 624
625 QMimeSourceFactory::setDefaultFactory( new ResourceMimeFactory ); 625 QMimeSourceFactory::setDefaultFactory( new ResourceMimeFactory );
626 626
627 connect( this, SIGNAL( lastWindowClosed() ), this, SLOT( hideOrQuit() ) ); 627 connect( this, SIGNAL( lastWindowClosed() ), this, SLOT( hideOrQuit() ) );
628 628
629 629
630 sysChannel = new QCopChannel( "QPE/System", this ); 630 sysChannel = new QCopChannel( "QPE/System", this );
631 connect( sysChannel, SIGNAL( received( const QCString &, const QByteArray & ) ), 631 connect( sysChannel, SIGNAL( received( const QCString &, const QByteArray & ) ),
@@ -1382,404 +1382,406 @@ void QPEApplication::systemMessage( const QCString& msg, const QByteArray& data
1382 else if ( msg == "trebleChange(bool)" ) { // Added: 2002-12-13 by Maximilian Reiss <harlekin@handhelds.org> 1382 else if ( msg == "trebleChange(bool)" ) { // Added: 2002-12-13 by Maximilian Reiss <harlekin@handhelds.org>
1383 setTreble(); 1383 setTreble();
1384 } else if ( msg == "getMarkedText()" ) { 1384 } else if ( msg == "getMarkedText()" ) {
1385 if ( type() == GuiServer ) { 1385 if ( type() == GuiServer ) {
1386 const ushort unicode = 'C'-'@'; 1386 const ushort unicode = 'C'-'@';
1387 const int scan = Key_C; 1387 const int scan = Key_C;
1388 qwsServer->processKeyEvent( unicode, scan, ControlButton, TRUE, FALSE ); 1388 qwsServer->processKeyEvent( unicode, scan, ControlButton, TRUE, FALSE );
1389 qwsServer->processKeyEvent( unicode, scan, ControlButton, FALSE, FALSE ); 1389 qwsServer->processKeyEvent( unicode, scan, ControlButton, FALSE, FALSE );
1390 } 1390 }
1391 } else if ( msg == "newChannel(QString)") { 1391 } else if ( msg == "newChannel(QString)") {
1392 QString myChannel = "QPE/Application/" + d->appName; 1392 QString myChannel = "QPE/Application/" + d->appName;
1393 QString channel; 1393 QString channel;
1394 stream >> channel; 1394 stream >> channel;
1395 if (channel == myChannel) { 1395 if (channel == myChannel) {
1396 processQCopFile(); 1396 processQCopFile();
1397 d->sendQCopQ(); 1397 d->sendQCopQ();
1398 } 1398 }
1399 } 1399 }
1400 1400
1401 1401
1402#endif 1402#endif
1403} 1403}
1404 1404
1405 1405
1406 1406
1407 1407
1408 1408
1409/*! 1409/*!
1410 \internal 1410 \internal
1411*/ 1411*/
1412bool QPEApplication::raiseAppropriateWindow() 1412bool QPEApplication::raiseAppropriateWindow()
1413{ 1413{
1414 bool r=FALSE; 1414 bool r=FALSE;
1415 1415
1416 // 1. Raise the main widget 1416 // 1. Raise the main widget
1417 QWidget *top = d->qpe_main_widget; 1417 QWidget *top = d->qpe_main_widget;
1418 if ( !top ) top = mainWidget(); 1418 if ( !top ) top = mainWidget();
1419 1419
1420 if ( top && d->keep_running ) { 1420 if ( top && d->keep_running ) {
1421 if ( top->isVisible() ) 1421 if ( top->isVisible() )
1422 r = TRUE; 1422 r = TRUE;
1423 else if (d->preloaded) { 1423 else if (d->preloaded) {
1424 // We are preloaded and not visible.. pretend we just started.. 1424 // We are preloaded and not visible.. pretend we just started..
1425#ifndef QT_NO_COP 1425#ifndef QT_NO_COP
1426 QCopEnvelope e("QPE/System", "fastAppShowing(QString)"); 1426 QCopEnvelope e("QPE/System", "fastAppShowing(QString)");
1427 e << d->appName; 1427 e << d->appName;
1428#endif 1428#endif
1429 } 1429 }
1430 1430
1431 d->show_mx(top,d->nomaximize, d->appName); 1431 d->show_mx(top,d->nomaximize, d->appName);
1432 top->raise(); 1432 top->raise();
1433 } 1433 }
1434 1434
1435 QWidget *topm = activeModalWidget(); 1435 QWidget *topm = activeModalWidget();
1436 1436
1437 // 2. Raise any parentless widgets (except top and topm, as they 1437 // 2. Raise any parentless widgets (except top and topm, as they
1438 // are raised before and after this loop). Order from most 1438 // are raised before and after this loop). Order from most
1439 // recently raised as deepest to least recently as top, so 1439 // recently raised as deepest to least recently as top, so
1440 // that repeated calls cycle through widgets. 1440 // that repeated calls cycle through widgets.
1441 QWidgetList *list = topLevelWidgets(); 1441 QWidgetList *list = topLevelWidgets();
1442 if ( list ) { 1442 if ( list ) {
1443 bool foundlast = FALSE; 1443 bool foundlast = FALSE;
1444 QWidget* topsub = 0; 1444 QWidget* topsub = 0;
1445 if ( d->lastraised ) { 1445 if ( d->lastraised ) {
1446 for (QWidget* w = list->first(); w; w = list->next()) { 1446 for (QWidget* w = list->first(); w; w = list->next()) {
1447 if ( !w->parentWidget() && w != topm && w->isVisible() && !w->isDesktop() ) { 1447 if ( !w->parentWidget() && w != topm && w->isVisible() && !w->isDesktop() ) {
1448 if ( w == d->lastraised ) 1448 if ( w == d->lastraised )
1449 foundlast = TRUE; 1449 foundlast = TRUE;
1450 if ( foundlast ) { 1450 if ( foundlast ) {
1451 w->raise(); 1451 w->raise();
1452 topsub = w; 1452 topsub = w;
1453 } 1453 }
1454 } 1454 }
1455 } 1455 }
1456 } 1456 }
1457 for (QWidget* w = list->first(); w; w = list->next()) { 1457 for (QWidget* w = list->first(); w; w = list->next()) {
1458 if ( !w->parentWidget() && w != topm && w->isVisible() && !w->isDesktop() ) { 1458 if ( !w->parentWidget() && w != topm && w->isVisible() && !w->isDesktop() ) {
1459 if ( w == d->lastraised ) 1459 if ( w == d->lastraised )
1460 break; 1460 break;
1461 w->raise(); 1461 w->raise();
1462 topsub = w; 1462 topsub = w;
1463 } 1463 }
1464 } 1464 }
1465 d->lastraised = topsub; 1465 d->lastraised = topsub;
1466 delete list; 1466 delete list;
1467 } 1467 }
1468 1468
1469 // 3. Raise the active modal widget. 1469 // 3. Raise the active modal widget.
1470 if ( topm && topm != top ) { 1470 if ( topm && topm != top ) {
1471 topm->show(); 1471 topm->show();
1472 topm->raise(); 1472 topm->raise();
1473 // If we haven't already handled the fastAppShowing message 1473 // If we haven't already handled the fastAppShowing message
1474 if (!top && d->preloaded) { 1474 if (!top && d->preloaded) {
1475#ifndef QT_NO_COP 1475#ifndef QT_NO_COP
1476 QCopEnvelope e("QPE/System", "fastAppShowing(QString)"); 1476 QCopEnvelope e("QPE/System", "fastAppShowing(QString)");
1477 e << d->appName; 1477 e << d->appName;
1478#endif 1478#endif
1479 } 1479 }
1480 r = FALSE; 1480 r = FALSE;
1481 } 1481 }
1482 1482
1483 return r; 1483 return r;
1484} 1484}
1485 1485
1486 1486
1487void QPEApplication::pidMessage( const QCString& msg, const QByteArray& data) 1487void QPEApplication::pidMessage( const QCString& msg, const QByteArray& data)
1488{ 1488{
1489#ifdef Q_WS_QWS 1489#ifdef Q_WS_QWS
1490 1490
1491 if ( msg == "quit()" ) { 1491 if ( msg == "quit()" ) {
1492 tryQuit(); 1492 tryQuit();
1493 } 1493 }
1494 else if ( msg == "quitIfInvisible()" ) { 1494 else if ( msg == "quitIfInvisible()" ) {
1495 if ( d->qpe_main_widget && !d->qpe_main_widget->isVisible() ) 1495 if ( d->qpe_main_widget && !d->qpe_main_widget->isVisible() )
1496 quit(); 1496 quit();
1497 } 1497 }
1498 else if ( msg == "close()" ) { 1498 else if ( msg == "close()" ) {
1499 hideOrQuit(); 1499 hideOrQuit();
1500 } 1500 }
1501 else if ( msg == "disablePreload()" ) { 1501 else if ( msg == "disablePreload()" ) {
1502 d->preloaded = FALSE; 1502 d->preloaded = FALSE;
1503 d->keep_running = TRUE; 1503 d->keep_running = TRUE;
1504 /* so that quit will quit */ 1504 /* so that quit will quit */
1505 } 1505 }
1506 else if ( msg == "enablePreload()" ) { 1506 else if ( msg == "enablePreload()" ) {
1507 if (d->qpe_main_widget) 1507 if (d->qpe_main_widget)
1508 d->preloaded = TRUE; 1508 d->preloaded = TRUE;
1509 d->keep_running = TRUE; 1509 d->keep_running = TRUE;
1510 /* so next quit won't quit */ 1510 /* so next quit won't quit */
1511 } 1511 }
1512 else if ( msg == "raise()" ) { 1512 else if ( msg == "raise()" ) {
1513 d->keep_running = TRUE; 1513 d->keep_running = TRUE;
1514 d->notbusysent = FALSE; 1514 d->notbusysent = FALSE;
1515 raiseAppropriateWindow(); 1515 raiseAppropriateWindow();
1516 // Tell the system we're still chugging along... 1516 // Tell the system we're still chugging along...
1517 QCopEnvelope e("QPE/System", "appRaised(QString)"); 1517 QCopEnvelope e("QPE/System", "appRaised(QString)");
1518 e << d->appName; 1518 e << d->appName;
1519 } 1519 }
1520 else if ( msg == "flush()" ) { 1520 else if ( msg == "flush()" ) {
1521 emit flush(); 1521 emit flush();
1522 // we need to tell the desktop 1522 // we need to tell the desktop
1523 QCopEnvelope e( "QPE/Desktop", "flushDone(QString)" ); 1523 QCopEnvelope e( "QPE/Desktop", "flushDone(QString)" );
1524 e << d->appName; 1524 e << d->appName;
1525 } 1525 }
1526 else if ( msg == "reload()" ) { 1526 else if ( msg == "reload()" ) {
1527 emit reload(); 1527 emit reload();
1528 } 1528 }
1529 else if ( msg == "setDocument(QString)" ) { 1529 else if ( msg == "setDocument(QString)" ) {
1530 d->keep_running = TRUE; 1530 d->keep_running = TRUE;
1531 QDataStream stream( data, IO_ReadOnly ); 1531 QDataStream stream( data, IO_ReadOnly );
1532 QString doc; 1532 QString doc;
1533 stream >> doc; 1533 stream >> doc;
1534 QWidget *mw = mainWidget(); 1534 QWidget *mw = mainWidget();
1535 if ( !mw ) 1535 if ( !mw )
1536 mw = d->qpe_main_widget; 1536 mw = d->qpe_main_widget;
1537 if ( mw ) 1537 if ( mw )
1538 Global::setDocument( mw, doc ); 1538 Global::setDocument( mw, doc );
1539 1539
1540 } else if ( msg == "QPEProcessQCop()" ) { 1540 } else if ( msg == "QPEProcessQCop()" ) {
1541 processQCopFile(); 1541 processQCopFile();
1542 d->sendQCopQ(); 1542 d->sendQCopQ();
1543 }else 1543 }else
1544 { 1544 {
1545 bool p = d->keep_running; 1545 bool p = d->keep_running;
1546 d->keep_running = FALSE; 1546 d->keep_running = FALSE;
1547 emit appMessage( msg, data); 1547 emit appMessage( msg, data);
1548 if ( d->keep_running ) { 1548 if ( d->keep_running ) {
1549 d->notbusysent = FALSE; 1549 d->notbusysent = FALSE;
1550 raiseAppropriateWindow(); 1550 raiseAppropriateWindow();
1551 if ( !p ) { 1551 if ( !p ) {
1552 // Tell the system we're still chugging along... 1552 // Tell the system we're still chugging along...
1553#ifndef QT_NO_COP 1553#ifndef QT_NO_COP
1554 QCopEnvelope e("QPE/System", "appRaised(QString)"); 1554 QCopEnvelope e("QPE/System", "appRaised(QString)");
1555 e << d->appName; 1555 e << d->appName;
1556#endif 1556#endif
1557 } 1557 }
1558 } 1558 }
1559 if ( p ) 1559 if ( p )
1560 d->keep_running = p; 1560 d->keep_running = p;
1561 } 1561 }
1562#endif 1562#endif
1563} 1563}
1564 1564
1565 1565
1566/*! 1566/*!
1567 Sets widget \a mw as the mainWidget() and shows it. For small windows, 1567 Sets widget \a mw as the mainWidget() and shows it. For small windows,
1568 consider passing TRUE for \a nomaximize rather than the default FALSE. 1568 consider passing TRUE for \a nomaximize rather than the default FALSE.
1569 1569
1570 \sa showMainDocumentWidget() 1570 \sa showMainDocumentWidget()
1571*/ 1571*/
1572void QPEApplication::showMainWidget( QWidget* mw, bool nomaximize ) 1572void QPEApplication::showMainWidget( QWidget* mw, bool nomaximize )
1573{ 1573{
1574 setMainWidget(mw);
1574 d->show(mw, nomaximize ); 1575 d->show(mw, nomaximize );
1575} 1576}
1576 1577
1577/*! 1578/*!
1578 Sets widget \a mw as the mainWidget() and shows it. For small windows, 1579 Sets widget \a mw as the mainWidget() and shows it. For small windows,
1579 consider passing TRUE for \a nomaximize rather than the default FALSE. 1580 consider passing TRUE for \a nomaximize rather than the default FALSE.
1580 1581
1581 This calls designates the application as 1582 This calls designates the application as
1582 a \link docwidget.html document-oriented\endlink application. 1583 a \link docwidget.html document-oriented\endlink application.
1583 1584
1584 The \a mw widget \e must have this slot: setDocument(const QString&). 1585 The \a mw widget \e must have this slot: setDocument(const QString&).
1585 1586
1586 \sa showMainWidget() 1587 \sa showMainWidget()
1587*/ 1588*/
1588void QPEApplication::showMainDocumentWidget( QWidget* mw, bool nomaximize ) 1589void QPEApplication::showMainDocumentWidget( QWidget* mw, bool nomaximize )
1589{ 1590{
1590 if ( mw && argc() == 2 ) 1591 if ( mw && argc() == 2 )
1591 Global::setDocument( mw, QString::fromUtf8(argv()[1]) ); 1592 Global::setDocument( mw, QString::fromUtf8(argv()[1]) );
1592 1593
1593 1594
1595 setMainWidget(mw);
1594 d->show(mw, nomaximize ); 1596 d->show(mw, nomaximize );
1595} 1597}
1596 1598
1597 1599
1598/*! 1600/*!
1599 If an application is started via a \link qcop.html QCop\endlink 1601 If an application is started via a \link qcop.html QCop\endlink
1600 message, the application will process the \link qcop.html 1602 message, the application will process the \link qcop.html
1601 QCop\endlink message and then quit. If the application calls this 1603 QCop\endlink message and then quit. If the application calls this
1602 function while processing a \link qcop.html QCop\endlink message, 1604 function while processing a \link qcop.html QCop\endlink message,
1603 after processing its outstanding \link qcop.html QCop\endlink 1605 after processing its outstanding \link qcop.html QCop\endlink
1604 messages the application will start 'properly' and show itself. 1606 messages the application will start 'properly' and show itself.
1605 1607
1606 \sa keepRunning() 1608 \sa keepRunning()
1607*/ 1609*/
1608void QPEApplication::setKeepRunning() 1610void QPEApplication::setKeepRunning()
1609{ 1611{
1610 if ( qApp && qApp->inherits( "QPEApplication" ) ) { 1612 if ( qApp && qApp->inherits( "QPEApplication" ) ) {
1611 QPEApplication * qpeApp = ( QPEApplication* ) qApp; 1613 QPEApplication * qpeApp = ( QPEApplication* ) qApp;
1612 qpeApp->d->keep_running = TRUE; 1614 qpeApp->d->keep_running = TRUE;
1613 } 1615 }
1614} 1616}
1615 1617
1616/*! 1618/*!
1617 Returns TRUE if the application will quit after processing the 1619 Returns TRUE if the application will quit after processing the
1618 current list of qcop messages; otherwise returns FALSE. 1620 current list of qcop messages; otherwise returns FALSE.
1619 1621
1620 \sa setKeepRunning() 1622 \sa setKeepRunning()
1621*/ 1623*/
1622bool QPEApplication::keepRunning() const 1624bool QPEApplication::keepRunning() const
1623{ 1625{
1624 return d->keep_running; 1626 return d->keep_running;
1625} 1627}
1626 1628
1627/*! 1629/*!
1628 \internal 1630 \internal
1629*/ 1631*/
1630void QPEApplication::internalSetStyle( const QString &style ) 1632void QPEApplication::internalSetStyle( const QString &style )
1631{ 1633{
1632#if QT_VERSION >= 300 1634#if QT_VERSION >= 300
1633 if ( style == "QPE" ) { 1635 if ( style == "QPE" ) {
1634 setStyle( new QPEStyle ); 1636 setStyle( new QPEStyle );
1635 } 1637 }
1636 else { 1638 else {
1637 QStyle *s = QStyleFactory::create( style ); 1639 QStyle *s = QStyleFactory::create( style );
1638 if ( s ) 1640 if ( s )
1639 setStyle( s ); 1641 setStyle( s );
1640 } 1642 }
1641#else 1643#else
1642 if ( style == "Windows" ) { 1644 if ( style == "Windows" ) {
1643 setStyle( new QWindowsStyle ); 1645 setStyle( new QWindowsStyle );
1644 } 1646 }
1645 else if ( style == "QPE" ) { 1647 else if ( style == "QPE" ) {
1646 setStyle( new QPEStyle ); 1648 setStyle( new QPEStyle );
1647 } 1649 }
1648 else if ( style == "Light" ) { 1650 else if ( style == "Light" ) {
1649 setStyle( new LightStyle ); 1651 setStyle( new LightStyle );
1650 } 1652 }
1651#ifndef QT_NO_STYLE_PLATINUM 1653#ifndef QT_NO_STYLE_PLATINUM
1652 else if ( style == "Platinum" ) { 1654 else if ( style == "Platinum" ) {
1653 setStyle( new QPlatinumStyle ); 1655 setStyle( new QPlatinumStyle );
1654 } 1656 }
1655#endif 1657#endif
1656#ifndef QT_NO_STYLE_MOTIF 1658#ifndef QT_NO_STYLE_MOTIF
1657 else if ( style == "Motif" ) { 1659 else if ( style == "Motif" ) {
1658 setStyle( new QMotifStyle ); 1660 setStyle( new QMotifStyle );
1659 } 1661 }
1660#endif 1662#endif
1661#ifndef QT_NO_STYLE_MOTIFPLUS 1663#ifndef QT_NO_STYLE_MOTIFPLUS
1662 else if ( style == "MotifPlus" ) { 1664 else if ( style == "MotifPlus" ) {
1663 setStyle( new QMotifPlusStyle ); 1665 setStyle( new QMotifPlusStyle );
1664 } 1666 }
1665#endif 1667#endif
1666 1668
1667 else { 1669 else {
1668 QStyle *sty = 0; 1670 QStyle *sty = 0;
1669 QString path = QPEApplication::qpeDir ( ) + "/plugins/styles/"; 1671 QString path = QPEApplication::qpeDir ( ) + "/plugins/styles/";
1670 1672
1671#ifdef Q_OS_MACX 1673#ifdef Q_OS_MACX
1672 if ( style. find ( ".dylib" ) > 0 ) 1674 if ( style. find ( ".dylib" ) > 0 )
1673 path += style; 1675 path += style;
1674 else 1676 else
1675 path = path + "lib" + style. lower ( ) + ".dylib"; // compatibility 1677 path = path + "lib" + style. lower ( ) + ".dylib"; // compatibility
1676#else 1678#else
1677 if ( style. find ( ".so" ) > 0 ) 1679 if ( style. find ( ".so" ) > 0 )
1678 path += style; 1680 path += style;
1679 else 1681 else
1680 path = path + "lib" + style. lower ( ) + ".so"; // compatibility 1682 path = path + "lib" + style. lower ( ) + ".so"; // compatibility
1681#endif 1683#endif
1682 static QLibrary *lastlib = 0; 1684 static QLibrary *lastlib = 0;
1683 static StyleInterface *lastiface = 0; 1685 static StyleInterface *lastiface = 0;
1684 1686
1685 QLibrary *lib = new QLibrary ( path ); 1687 QLibrary *lib = new QLibrary ( path );
1686 StyleInterface *iface = 0; 1688 StyleInterface *iface = 0;
1687 1689
1688 if (( lib-> queryInterface ( IID_Style, ( QUnknownInterface ** ) &iface ) == QS_OK ) && iface ) 1690 if (( lib-> queryInterface ( IID_Style, ( QUnknownInterface ** ) &iface ) == QS_OK ) && iface )
1689 sty = iface-> style ( ); 1691 sty = iface-> style ( );
1690 1692
1691 if ( sty ) { 1693 if ( sty ) {
1692 setStyle ( sty ); 1694 setStyle ( sty );
1693 1695
1694 if ( lastiface ) 1696 if ( lastiface )
1695 lastiface-> release ( ); 1697 lastiface-> release ( );
1696 lastiface = iface; 1698 lastiface = iface;
1697 1699
1698 if ( lastlib ) { 1700 if ( lastlib ) {
1699 lastlib-> unload ( ); 1701 lastlib-> unload ( );
1700 delete lastlib; 1702 delete lastlib;
1701 } 1703 }
1702 lastlib = lib; 1704 lastlib = lib;
1703 } 1705 }
1704 else { 1706 else {
1705 if ( iface ) 1707 if ( iface )
1706 iface-> release ( ); 1708 iface-> release ( );
1707 delete lib; 1709 delete lib;
1708 1710
1709 setStyle ( new LightStyle ( )); 1711 setStyle ( new LightStyle ( ));
1710 } 1712 }
1711 } 1713 }
1712#endif 1714#endif
1713} 1715}
1714 1716
1715/*! 1717/*!
1716 \internal 1718 \internal
1717*/ 1719*/
1718void QPEApplication::prepareForTermination( bool willrestart ) 1720void QPEApplication::prepareForTermination( bool willrestart )
1719{ 1721{
1720 if ( willrestart ) { 1722 if ( willrestart ) {
1721 // Draw a big wait icon, the image can be altered in later revisions 1723 // Draw a big wait icon, the image can be altered in later revisions
1722 // QWidget *d = QApplication::desktop(); 1724 // QWidget *d = QApplication::desktop();
1723 QImage img = Resource::loadImage( "launcher/new_wait" ); 1725 QImage img = Resource::loadImage( "launcher/new_wait" );
1724 QPixmap pix; 1726 QPixmap pix;
1725 pix.convertFromImage( img.smoothScale( 1 * img.width(), 1 * img.height() ) ); 1727 pix.convertFromImage( img.smoothScale( 1 * img.width(), 1 * img.height() ) );
1726 QLabel *lblWait = new QLabel( 0, "wait hack!", QWidget::WStyle_Customize | 1728 QLabel *lblWait = new QLabel( 0, "wait hack!", QWidget::WStyle_Customize |
1727 QWidget::WStyle_NoBorder | QWidget::WStyle_Tool ); 1729 QWidget::WStyle_NoBorder | QWidget::WStyle_Tool );
1728 lblWait->setPixmap( pix ); 1730 lblWait->setPixmap( pix );
1729 lblWait->setAlignment( QWidget::AlignCenter ); 1731 lblWait->setAlignment( QWidget::AlignCenter );
1730 lblWait->show(); 1732 lblWait->show();
1731 lblWait->showMaximized(); 1733 lblWait->showMaximized();
1732 } 1734 }
1733#ifndef SINGLE_APP 1735#ifndef SINGLE_APP
1734 { QCopEnvelope envelope( "QPE/System", "forceQuit()" ); 1736 { QCopEnvelope envelope( "QPE/System", "forceQuit()" );
1735 } 1737 }
1736 processEvents(); // ensure the message goes out. 1738 processEvents(); // ensure the message goes out.
1737 sleep( 1 ); // You have 1 second to comply. 1739 sleep( 1 ); // You have 1 second to comply.
1738#endif 1740#endif
1739} 1741}
1740 1742
1741/*! 1743/*!
1742 \internal 1744 \internal
1743*/ 1745*/
1744void QPEApplication::shutdown() 1746void QPEApplication::shutdown()
1745{ 1747{
1746 // Implement in server's QPEApplication subclass 1748 // Implement in server's QPEApplication subclass
1747} 1749}
1748 1750
1749/*! 1751/*!
1750 \internal 1752 \internal
1751*/ 1753*/
1752void QPEApplication::restart() 1754void QPEApplication::restart()
1753{ 1755{
1754 // Implement in server's QPEApplication subclass 1756 // Implement in server's QPEApplication subclass
1755} 1757}
1756 1758
1757static QPtrDict<void>* stylusDict = 0; 1759static QPtrDict<void>* stylusDict = 0;
1758static void createDict() 1760static void createDict()
1759{ 1761{
1760 if ( !stylusDict ) 1762 if ( !stylusDict )
1761 stylusDict = new QPtrDict<void>; 1763 stylusDict = new QPtrDict<void>;
1762} 1764}
1763 1765
1764/*! 1766/*!
1765 Returns the current StylusMode for widget \a w. 1767 Returns the current StylusMode for widget \a w.
1766 1768
1767 \sa setStylusOperation() StylusMode 1769 \sa setStylusOperation() StylusMode
1768*/ 1770*/
1769QPEApplication::StylusMode QPEApplication::stylusOperation( QWidget* w ) 1771QPEApplication::StylusMode QPEApplication::stylusOperation( QWidget* w )
1770{ 1772{
1771 if ( stylusDict ) 1773 if ( stylusDict )
1772 return ( StylusMode ) ( int ) stylusDict->find( w ); 1774 return ( StylusMode ) ( int ) stylusDict->find( w );
1773 return LeftOnly; 1775 return LeftOnly;
1774} 1776}
1775 1777
1776/*! 1778/*!
1777 \enum QPEApplication::StylusMode 1779 \enum QPEApplication::StylusMode
1778 1780
1779 \value LeftOnly the stylus only generates LeftButton 1781 \value LeftOnly the stylus only generates LeftButton
1780 events (the default). 1782 events (the default).
1781 \value RightOnHold the stylus generates RightButton events 1783 \value RightOnHold the stylus generates RightButton events
1782 if the user uses the press-and-hold gesture. 1784 if the user uses the press-and-hold gesture.
1783 1785
1784 \sa setStylusOperation() stylusOperation() 1786 \sa setStylusOperation() stylusOperation()
1785*/ 1787*/
diff --git a/library/qpeapplication.h b/library/qpeapplication.h
index 729cf2b..3ef8b46 100644
--- a/library/qpeapplication.h
+++ b/library/qpeapplication.h
@@ -1,206 +1,244 @@
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#ifndef __QPE_APPLICATION_H__ 20#ifndef __QPE_APPLICATION_H__
21#define __QPE_APPLICATION_H__ 21#define __QPE_APPLICATION_H__
22 22
23#include <stdlib.h> // for setenv() 23#include <stdlib.h> // for setenv()
24 24
25#include <qglobal.h> 25#include <qglobal.h>
26#include <qapplication.h> 26#include <qapplication.h>
27#include <qdialog.h> 27#include <qdialog.h>
28#include <qwsdisplay_qws.h> 28#include <qwsdisplay_qws.h>
29#if defined(_WS_QWS_) && !defined(Q_WS_QWS) 29#if defined(_WS_QWS_) && !defined(Q_WS_QWS)
30#define Q_WS_QWS 30#define Q_WS_QWS
31#endif 31#endif
32#include "qpedecoration_qws.h" 32#include "qpedecoration_qws.h"
33#include "timestring.h" 33#include "timestring.h"
34 34
35class QCopChannel; 35class QCopChannel;
36class QPEApplicationData; 36class QPEApplicationData;
37class QWSEvent; 37class QWSEvent;
38class QWSKeyEvent; 38class QWSKeyEvent;
39 39
40 40/**
41 \brief The QPEApplication class implements various system services
42 that are available to all Qtopia applications.
43
44 Simply by using QPEApplication instead of QApplication, a standard Qt
45 application becomes a Qtopia application. It automatically follows
46 style changes, quits and raises, and in the
47 case of \link docwidget.html document-oriented\endlink applications,
48 changes the currently displayed document in response to the environment.
49
50 To create a \link docwidget.html document-oriented\endlink
51 application use showMainDocumentWidget(); to create a
52 non-document-oriented application use showMainWidget(). The
53 keepRunning() function indicates whether the application will
54 continue running after it's processed the last \link qcop.html
55 QCop\endlink message. This can be changed using setKeepRunning().
56
57 A variety of signals are emitted when certain events occur, for
58 example, timeChanged(), clockChanged(), weekChanged(),
59 dateFormatChanged() and volumeChanged(). If the application receives
60 a \link qcop.html QCop\endlink message on the application's
61 QPE/Application/\e{appname} channel, the appMessage() signal is
62 emitted. There are also flush() and reload() signals, which
63 are emitted when synching begins and ends respectively - upon these
64 signals, the application should save and reload any data
65 files that are involved in synching. Most of these signals will initially
66 be received and unfiltered through the appMessage() signal.
67
68 This class also provides a set of useful static functions. The
69 qpeDir() and documentDir() functions return the respective paths.
70 The grabKeyboard() and ungrabKeyboard() functions are used to
71 control whether the application takes control of the device's
72 physical buttons (e.g. application launch keys). The stylus' mode of
73 operation is set with setStylusOperation() and retrieved with
74 stylusOperation(). There are also setInputMethodHint() and
75 inputMethodHint() functions.
76
77 \ingroup qtopiaemb
78*/
41class QPEApplication : public QApplication 79class QPEApplication : public QApplication
42{ 80{
43 Q_OBJECT 81 Q_OBJECT
44public: 82public:
45 QPEApplication( int& argc, char **argv, Type=GuiClient ); 83 QPEApplication( int& argc, char **argv, Type=GuiClient );
46 ~QPEApplication(); 84 ~QPEApplication();
47 85
48 static QString qpeDir(); 86 static QString qpeDir();
49 static QString documentDir(); 87 static QString documentDir();
50 void applyStyle(); 88 void applyStyle();
51 void reset(); 89 void reset();
52 static int defaultRotation(); 90 static int defaultRotation();
53 static void setDefaultRotation(int r); 91 static void setDefaultRotation(int r);
54 static void setCurrentRotation(int r); 92 static void setCurrentRotation(int r);
55 static void setCurrentMode(int x, int y, int depth ); 93 static void setCurrentMode(int x, int y, int depth );
56 static void grabKeyboard(); 94 static void grabKeyboard();
57 static void ungrabKeyboard(); 95 static void ungrabKeyboard();
58 96
59 enum StylusMode { 97 enum StylusMode {
60 LeftOnly, 98 LeftOnly,
61 RightOnHold 99 RightOnHold
62 // RightOnHoldLeftDelayed, etc. 100 // RightOnHoldLeftDelayed, etc.
63 }; 101 };
64 static void setStylusOperation( QWidget*, StylusMode ); 102 static void setStylusOperation( QWidget*, StylusMode );
65 static StylusMode stylusOperation( QWidget* ); 103 static StylusMode stylusOperation( QWidget* );
66 104
67 enum InputMethodHint { 105 enum InputMethodHint {
68 Normal, 106 Normal,
69 AlwaysOff, 107 AlwaysOff,
70 AlwaysOn 108 AlwaysOn
71 }; 109 };
72 110
73 enum screenSaverHint { 111 enum screenSaverHint {
74 Disable = 0, 112 Disable = 0,
75 DisableLightOff = 1, 113 DisableLightOff = 1,
76 DisableSuspend = 2, 114 DisableSuspend = 2,
77 Enable = 100 115 Enable = 100
78 }; 116 };
79 117
80 static void setInputMethodHint( QWidget *, InputMethodHint ); 118 static void setInputMethodHint( QWidget *, InputMethodHint );
81 static InputMethodHint inputMethodHint( QWidget * ); 119 static InputMethodHint inputMethodHint( QWidget * );
82 120
83 void showMainWidget( QWidget*, bool nomax=FALSE ); 121 void showMainWidget( QWidget*, bool nomax=FALSE );
84 void showMainDocumentWidget( QWidget*, bool nomax=FALSE ); 122 void showMainDocumentWidget( QWidget*, bool nomax=FALSE );
85 static void showDialog( QDialog*, bool nomax=FALSE ); 123 static void showDialog( QDialog*, bool nomax=FALSE );
86 static int execDialog( QDialog*, bool nomax=FALSE ); 124 static int execDialog( QDialog*, bool nomax=FALSE );
87 /* Merge setTempScreenSaverMode */ 125 /* Merge setTempScreenSaverMode */
88#ifdef QTOPIA_INTERNAL_INITAPP 126#ifdef QTOPIA_INTERNAL_INITAPP
89 void initApp( int argv, char **argv ); 127 void initApp( int argv, char **argv );
90#endif 128#endif
91 129
92 static void setKeepRunning(); 130 static void setKeepRunning();
93 bool keepRunning() const; 131 bool keepRunning() const;
94 132
95 bool keyboardGrabbed() const; 133 bool keyboardGrabbed() const;
96 134
97 int exec(); 135 int exec();
98 136
99signals: 137signals:
100 void clientMoused(); 138 void clientMoused();
101 void timeChanged(); 139 void timeChanged();
102 void clockChanged( bool pm ); 140 void clockChanged( bool pm );
103 void micChanged( bool muted ); 141 void micChanged( bool muted );
104 void volumeChanged( bool muted ); 142 void volumeChanged( bool muted );
105 void appMessage( const QCString& msg, const QByteArray& data); 143 void appMessage( const QCString& msg, const QByteArray& data);
106 void weekChanged( bool startOnMonday ); 144 void weekChanged( bool startOnMonday );
107 void dateFormatChanged( DateFormat ); 145 void dateFormatChanged( DateFormat );
108 void flush(); 146 void flush();
109 void reload(); 147 void reload();
110 /* linkChanged signal */ 148 /* linkChanged signal */
111 149
112private slots: 150private slots:
113 void systemMessage( const QCString &msg, const QByteArray &data ); 151 void systemMessage( const QCString &msg, const QByteArray &data );
114 void pidMessage( const QCString &msg, const QByteArray &data ); 152 void pidMessage( const QCString &msg, const QByteArray &data );
115 void removeSenderFromStylusDict(); 153 void removeSenderFromStylusDict();
116 void hideOrQuit(); 154 void hideOrQuit();
117 155
118protected: 156protected:
119 bool qwsEventFilter( QWSEvent * ); 157 bool qwsEventFilter( QWSEvent * );
120 void internalSetStyle( const QString &style ); 158 void internalSetStyle( const QString &style );
121 void prepareForTermination(bool willrestart); 159 void prepareForTermination(bool willrestart);
122 virtual void restart(); 160 virtual void restart();
123 virtual void shutdown(); 161 virtual void shutdown();
124 bool eventFilter( QObject *, QEvent * ); 162 bool eventFilter( QObject *, QEvent * );
125 void timerEvent( QTimerEvent * ); 163 void timerEvent( QTimerEvent * );
126 bool raiseAppropriateWindow(); 164 bool raiseAppropriateWindow();
127 virtual void tryQuit(); 165 virtual void tryQuit();
128#if QT_VERSION > 233 166#if QT_VERSION > 233
129 virtual void polish ( QWidget * ); // this is actually implemented in qt_override.cpp (!) 167 virtual void polish ( QWidget * ); // this is actually implemented in qt_override.cpp (!)
130#endif 168#endif
131private: 169private:
132#ifndef QT_NO_TRANSLATION 170#ifndef QT_NO_TRANSLATION
133 void installTranslation( const QString& baseName ); 171 void installTranslation( const QString& baseName );
134#endif 172#endif
135 void mapToDefaultAction( QWSKeyEvent *ke, int defKey ); 173 void mapToDefaultAction( QWSKeyEvent *ke, int defKey );
136 void processQCopFile(); 174 void processQCopFile();
137 175
138#if defined(Q_WS_QWS) && !defined(QT_NO_COP) 176#if defined(Q_WS_QWS) && !defined(QT_NO_COP)
139 QCopChannel *sysChannel; 177 QCopChannel *sysChannel;
140 QCopChannel *pidChannel; 178 QCopChannel *pidChannel;
141#endif 179#endif
142 QPEApplicationData *d; 180 QPEApplicationData *d;
143 181
144 bool reserved_sh; 182 bool reserved_sh;
145 183
146 184
147 185
148}; 186};
149 187
150inline void QPEApplication::showDialog( QDialog* d, bool nomax ) 188inline void QPEApplication::showDialog( QDialog* d, bool nomax )
151{ 189{
152 QSize sh = d->sizeHint(); 190 QSize sh = d->sizeHint();
153 int w = QMAX(sh.width(),d->width()); 191 int w = QMAX(sh.width(),d->width());
154 int h = QMAX(sh.height(),d->height()); 192 int h = QMAX(sh.height(),d->height());
155 if ( !nomax 193 if ( !nomax
156 && ( w > qApp->desktop()->width()*3/4 194 && ( w > qApp->desktop()->width()*3/4
157 || h > qApp->desktop()->height()*3/4 ) ) 195 || h > qApp->desktop()->height()*3/4 ) )
158 { 196 {
159 d->showMaximized(); 197 d->showMaximized();
160 } else { 198 } else {
161 d->resize(w,h); 199 d->resize(w,h);
162 d->show(); 200 d->show();
163 } 201 }
164} 202}
165 203
166inline int QPEApplication::execDialog( QDialog* d, bool nomax ) 204inline int QPEApplication::execDialog( QDialog* d, bool nomax )
167{ 205{
168 showDialog(d,nomax); 206 showDialog(d,nomax);
169 return d->exec(); 207 return d->exec();
170} 208}
171 209
172enum Transformation { Rot0, Rot90, Rot180, Rot270 }; /* from qgfxtransformed_qws.cpp */ 210enum Transformation { Rot0, Rot90, Rot180, Rot270 }; /* from qgfxtransformed_qws.cpp */
173 211
174inline int TransToDeg ( Transformation t ) 212inline int TransToDeg ( Transformation t )
175{ 213{
176 int d = static_cast<int>( t ); 214 int d = static_cast<int>( t );
177 return d * 90; 215 return d * 90;
178} 216}
179 217
180inline Transformation DegToTrans ( int d ) 218inline Transformation DegToTrans ( int d )
181{ 219{
182 Transformation t = static_cast<Transformation>( d / 90 ); 220 Transformation t = static_cast<Transformation>( d / 90 );
183 return t; 221 return t;
184} 222}
185 223
186/* 224/*
187 * Set current rotation of Opie, and rotation for newly started apps. 225 * Set current rotation of Opie, and rotation for newly started apps.
188 * Differs from setDefaultRotation in that 1) it rotates currently running apps, 226 * Differs from setDefaultRotation in that 1) it rotates currently running apps,
189 * and 2) does not set deforient or save orientation to qpe.conf. 227 * and 2) does not set deforient or save orientation to qpe.conf.
190 */ 228 */
191 229
192inline void QPEApplication::setCurrentRotation( int r ) 230inline void QPEApplication::setCurrentRotation( int r )
193{ 231{
194 // setTransformation has been introduced in Qt/Embedded 2.3.4 snapshots 232 // setTransformation has been introduced in Qt/Embedded 2.3.4 snapshots
195 // for compatibility with the SharpROM use fallback to setDefaultTransformation() 233 // for compatibility with the SharpROM use fallback to setDefaultTransformation()
196#if QT_VERSION > 233 234#if QT_VERSION > 233
197 Transformation e = DegToTrans( r ); 235 Transformation e = DegToTrans( r );
198 ::setenv( "QWS_DISPLAY", QString( "Transformed:Rot%1:0" ).arg( r ).latin1(), 1 ); 236 ::setenv( "QWS_DISPLAY", QString( "Transformed:Rot%1:0" ).arg( r ).latin1(), 1 );
199 qApp->desktop()->qwsDisplay()->setTransformation( e ); 237 qApp->desktop()->qwsDisplay()->setTransformation( e );
200#else 238#else
201 setDefaultRotation( r ); 239 setDefaultRotation( r );
202#endif 240#endif
203} 241}
204 242
205 243
206#endif 244#endif
diff --git a/library/styleinterface.h b/library/styleinterface.h
index 8a900c7..872a4a5 100644
--- a/library/styleinterface.h
+++ b/library/styleinterface.h
@@ -1,67 +1,67 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2002 Robert Griebl. All rights reserved. 2** Copyright (C) 2002 Robert Griebl. All rights reserved.
3** 3**
4** This file is part of OPIE (http://www.opie.info). 4** This file is part of OPIE (http://www.opie.info).
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**********************************************************************/ 14**********************************************************************/
15 15
16#ifndef STYLEINTERFACE_H 16#ifndef STYLEINTERFACE_H
17#define STYLEINTERFACE_H 17#define STYLEINTERFACE_H
18 18
19#include <qpe/qcom.h> 19#include <qpe/qcom.h>
20 20
21#ifndef QT_NO_COMPONENT 21#ifndef QT_NO_COMPONENT
22 22
23// {17AF792C-E461-49A9-9B71-068B9A8DDAE4} 23// {17AF792C-E461-49A9-9B71-068B9A8DDAE4}
24#ifndef IID_Style 24#ifndef IID_Style
25#define IID_Style QUuid( 0x17af792c, 0xe461, 0x49a9, 0x9b, 0x71, 0x06, 0x8b, 0x9a, 0x8d, 0xda, 0xe4) 25#define IID_Style QUuid( 0x17af792c, 0xe461, 0x49a9, 0x9b, 0x71, 0x06, 0x8b, 0x9a, 0x8d, 0xda, 0xe4)
26#endif 26#endif
27 27
28// {6C33B4F9-D529-453A-8FB3-DA42B21872BD} 28// {6C33B4F9-D529-453A-8FB3-DA42B21872BD}
29# ifndef IID_StyleExtended 29# ifndef IID_StyleExtended
30# define IID_StyleExtended QUuid( 0x6c33b4f9, 0xd529, 0x453a, 0x8f, 0xb3, 0xda, 0x42, 0xb2, 0x18, 0x72, 0xbd) 30# define IID_StyleExtended QUuid( 0x6c33b4f9, 0xd529, 0x453a, 0x8f, 0xb3, 0xda, 0x42, 0xb2, 0x18, 0x72, 0xbd)
31#endif 31#endif
32 32
33#endif 33#endif
34 34
35class QWidget; 35class QWidget;
36class QStyle; 36class QStyle;
37 37
38 38
39class QStyle; 39class QStyle;
40 40
41struct StyleInterface : public QUnknownInterface 41struct StyleInterface : public QUnknownInterface
42{ 42{
43 //! Return a new style. 43 /*! Return a new style.*/
44 virtual QStyle *style() = 0; 44 virtual QStyle *style() = 0;
45 //! Return a short name for the style. 45 /*! Return a short name for the style. */
46 virtual QString name() const = 0; 46 virtual QString name() const = 0;
47}; 47};
48 48
49struct StyleExtendedInterface : public StyleInterface 49struct StyleExtendedInterface : public StyleInterface
50{ 50{
51 //! Return a (longer) description for the style. 51 /*! Return a (longer) description for the style. */
52 virtual QString description ( ) const = 0; 52 virtual QString description ( ) const = 0;
53 53
54 //! Does this style support customization 54 /*! Does this style support customization */
55 virtual bool hasSettings ( ) const = 0; 55 virtual bool hasSettings ( ) const = 0;
56 56
57 //! Return a new settings page. 57 /*! Return a new settings page. */
58 virtual QWidget *create ( QWidget *parent, const char *name = 0 ) = 0; 58 virtual QWidget *create ( QWidget *parent, const char *name = 0 ) = 0;
59 59
60 //! Callback for appearance app when OK is clicked (return true when style has to re-applied). 60 /*! Callback for appearance app when OK is clicked (return true when style has to re-applied). */
61 virtual bool accept ( ) = 0; 61 virtual bool accept ( ) = 0;
62 62
63 //! Callback for appeaeance app when Cancel is clicked. 63 /*! Callback for appeaeance app when Cancel is clicked. */
64 virtual void reject ( ) = 0; 64 virtual void reject ( ) = 0;
65}; 65};
66 66
67#endif 67#endif