author | wimpie <wimpie> | 2004-08-25 01:47:35 (UTC) |
---|---|---|
committer | wimpie <wimpie> | 2004-08-25 01:47:35 (UTC) |
commit | f6a6fe57c9e0047379f4b8b40da4776f1c4d7b25 (patch) (unidiff) | |
tree | 2db64e885b1a67058fa45533819993c8dcb4fb96 | |
parent | 49c47e98bed6e35d0bdc8e1e4cc40bdbb07eab06 (diff) | |
download | opie-f6a6fe57c9e0047379f4b8b40da4776f1c4d7b25.zip opie-f6a6fe57c9e0047379f4b8b40da4776f1c4d7b25.tar.gz opie-f6a6fe57c9e0047379f4b8b40da4776f1c4d7b25.tar.bz2 |
Final changes for RoH Feedback
- changed *.pro file to compile in backend
- some more fixes to rohfeedback and qpeapplication
-rw-r--r-- | library/backend/rohfeedback.cpp | 28 | ||||
-rw-r--r-- | library/backend/rohfeedback.h | 3 | ||||
-rw-r--r-- | library/config.in | 4 | ||||
-rw-r--r-- | library/library.pro | 6 | ||||
-rw-r--r-- | library/qpeapplication.cpp | 58 | ||||
-rw-r--r-- | library/qpeapplication.h | 2 |
6 files changed, 57 insertions, 44 deletions
diff --git a/library/backend/rohfeedback.cpp b/library/backend/rohfeedback.cpp index ff76a36..21aad34 100644 --- a/library/backend/rohfeedback.cpp +++ b/library/backend/rohfeedback.cpp | |||
@@ -1,19 +1,19 @@ | |||
1 | #include <rohfeedback.h> | 1 | #ifdef OPIE_WITHROHFEEDBACK |
2 | |||
3 | 2 | ||
3 | #include <rohfeedback.h> | ||
4 | #include <stdio.h> | 4 | #include <stdio.h> |
5 | #include <qpeapplication.h> | 5 | #include <qpeapplication.h> |
6 | #include <qevent.h> | 6 | #include <qevent.h> |
7 | #include <resource.h> | 7 | #include <resource.h> |
8 | #include <qpixmap.h> | 8 | #include <qpixmap.h> |
9 | #include <qbitmap.h> | 9 | #include <qbitmap.h> |
10 | 10 | ||
11 | #define SPEED 600 | 11 | #define SPEED 600 |
12 | #define DELAY 500 | 12 | #define DELAY 500 |
13 | 13 | ||
14 | namespace Opie { | 14 | namespace Opie { |
15 | namespace Internal { | 15 | namespace Internal { |
16 | /* | 16 | /* |
17 | 17 | ||
18 | RightOnHold feedback | 18 | RightOnHold feedback |
19 | 19 | ||
@@ -22,104 +22,104 @@ namespace Internal { | |||
22 | QPixmap * RoHFeedback::Imgs[NOOFICONS] = { 0, 0, 0, 0, 0 }; | 22 | QPixmap * RoHFeedback::Imgs[NOOFICONS] = { 0, 0, 0, 0, 0 }; |
23 | QBitmap * RoHFeedback::Masks[NOOFICONS]; | 23 | QBitmap * RoHFeedback::Masks[NOOFICONS]; |
24 | int RoHFeedback::IconWidth; | 24 | int RoHFeedback::IconWidth; |
25 | int RoHFeedback::IconHeight; | 25 | int RoHFeedback::IconHeight; |
26 | 26 | ||
27 | RoHFeedback::RoHFeedback() : | 27 | RoHFeedback::RoHFeedback() : |
28 | QLabel( 0, 0, Qt::WType_Popup ), Timer() { | 28 | QLabel( 0, 0, Qt::WType_Popup ), Timer() { |
29 | 29 | ||
30 | Receiver = 0l; | 30 | Receiver = 0l; |
31 | connect( &Timer, SIGNAL( timeout() ), this, SLOT( iconShow() ) ); | 31 | connect( &Timer, SIGNAL( timeout() ), this, SLOT( iconShow() ) ); |
32 | 32 | ||
33 | if( Imgs[0] == 0 ) { | 33 | if( Imgs[0] == 0 ) { |
34 | QString S; | 34 | QString S; |
35 | 35 | ||
36 | 36 | ||
37 | for( int i = 0; i < NOOFICONS ; i ++ ) { | 37 | for( int i = 0; i < NOOFICONS ; i ++ ) { |
38 | Imgs[i] = new QPixmap( Resource::loadPixmap("RoH/star/"+ | 38 | Imgs[i] = new QPixmap( Resource::loadPixmap( |
39 | QString::number(i+1) + | 39 | "RoH/star/"+ QString::number(i+1) + ".png" )); |
40 | ".png" )); | ||
41 | Masks[i] = new QBitmap(); | 40 | Masks[i] = new QBitmap(); |
42 | (*Masks[i]) = Resource::loadPixmap("RoH/star/"+QString::number(i+1) + | 41 | (*Masks[i]) = Resource::loadPixmap( |
43 | ".png" ); | 42 | "RoH/star/"+QString::number(i+1) + "-mask.png" ); |
44 | } | 43 | } |
45 | } | 44 | } |
46 | 45 | ||
47 | IconWidth = Imgs[0]->size().width(); | 46 | IconWidth = Imgs[0]->size().width(); |
48 | IconHeight = Imgs[0]->size().height(); | 47 | IconHeight = Imgs[0]->size().height(); |
49 | 48 | ||
50 | resize( IconWidth, IconHeight ); | 49 | resize( IconWidth, IconHeight ); |
51 | } | 50 | } |
52 | 51 | ||
53 | int RoHFeedback::delay( void ) { | 52 | int RoHFeedback::delay( void ) { |
54 | return DELAY+SPEED+50; | 53 | return DELAY+SPEED+50; |
55 | } | 54 | } |
56 | 55 | ||
57 | RoHFeedback::~RoHFeedback() { | 56 | RoHFeedback::~RoHFeedback() { |
58 | for ( int i = 0; i < NOOFICONS; ++i ) { | 57 | for ( int i = 0; i < NOOFICONS; ++i ) { |
59 | delete Imgs [i]; | 58 | delete Imgs [i]; |
60 | delete Masks[i]; | 59 | delete Masks[i]; |
61 | } | 60 | } |
62 | } | 61 | } |
63 | 62 | ||
64 | void RoHFeedback::init( const QPoint & P, QWidget* wid ) { | 63 | void RoHFeedback::init( const QPoint & P, QWidget* wid ) { |
65 | if( ! IconWidth ) | 64 | if( ! IconWidth ) |
66 | return; | 65 | return; |
67 | 66 | ||
68 | Receiver = wid; | 67 | Receiver = wid; |
69 | IconNr = -1; | 68 | IconNr = FeedbackTimerStart; |
70 | move( P.x()-IconWidth/2, P.y() - IconHeight/2 ); | 69 | move( P.x()-IconWidth/2, P.y() - IconHeight/2 ); |
71 | // to initialize | 70 | // to initialize |
72 | Timer.start( DELAY - SPEED/NOOFICONS ); | 71 | Timer.start( DELAY ); |
73 | } | 72 | } |
74 | 73 | ||
75 | void RoHFeedback::stop( void ) { | 74 | void RoHFeedback::stop( void ) { |
76 | IconNr = -2; // stop | 75 | IconNr = FeedbackStopped; // stop |
77 | hide(); | ||
78 | Timer.stop(); | ||
79 | } | 76 | } |
80 | 77 | ||
81 | bool RoHFeedback::event( QEvent * E ) { | 78 | bool RoHFeedback::event( QEvent * E ) { |
82 | 79 | ||
83 | if( E->type() >= QEvent::MouseButtonPress && | 80 | if( E->type() >= QEvent::MouseButtonPress && |
84 | E->type() <= QEvent::MouseMove ) { | 81 | E->type() <= QEvent::MouseMove ) { |
85 | // pass the event to the receiver with translated coord | 82 | // pass the event to the receiver with translated coord |
86 | QMouseEvent QME( ((QMouseEvent *)E)->type(), | 83 | QMouseEvent QME( ((QMouseEvent *)E)->type(), |
87 | Receiver->mapFromGlobal( | 84 | Receiver->mapFromGlobal( |
88 | ((QMouseEvent *)E)->globalPos() ), | 85 | ((QMouseEvent *)E)->globalPos() ), |
89 | ((QMouseEvent *)E)->globalPos(), | 86 | ((QMouseEvent *)E)->globalPos(), |
90 | ((QMouseEvent *)E)->button(), | 87 | ((QMouseEvent *)E)->button(), |
91 | ((QMouseEvent *)E)->state() | 88 | ((QMouseEvent *)E)->state() |
92 | ); | 89 | ); |
93 | return QPEApplication::sendEvent( Receiver, &QME ); | 90 | return QPEApplication::sendEvent( Receiver, &QME ); |
94 | } | 91 | } |
95 | 92 | ||
96 | // first let the label treat the event | 93 | // first let the label treat the event |
97 | return QLabel::event( E ); | 94 | return QLabel::event( E ); |
98 | } | 95 | } |
99 | 96 | ||
100 | void RoHFeedback::iconShow( void ) { | 97 | void RoHFeedback::iconShow( void ) { |
101 | switch( IconNr ) { | 98 | switch( IconNr ) { |
102 | case FeedbackTimerStart: | 99 | case FeedbackTimerStart: |
103 | IconNr = 0; | 100 | IconNr = FeedbackShow; |
104 | Timer.start( SPEED/NOOFICONS ); | 101 | Timer.start( SPEED/NOOFICONS ); |
105 | break; | 102 | break; |
106 | case FeedbackStopped: | 103 | case FeedbackStopped: |
107 | // stopped | 104 | // stopped |
108 | IconNr = FeedbackTimerStart; | 105 | IconNr = FeedbackTimerStart; |
109 | hide(); | 106 | hide(); |
107 | Timer.stop(); | ||
110 | break; | 108 | break; |
111 | case FeedbackShow: // first | 109 | case FeedbackShow: // first |
112 | show(); | 110 | show(); |
113 | // FT | 111 | // FT |
114 | default : | 112 | default : |
115 | // show | 113 | // show |
116 | 114 | ||
117 | setPixmap( *(Imgs[IconNr]) ); | 115 | setPixmap( *(Imgs[IconNr]) ); |
118 | setMask( *(Masks[IconNr]) ); | 116 | setMask( *(Masks[IconNr]) ); |
119 | IconNr = (IconNr+1)%NOOFICONS; // rotate | 117 | IconNr = (IconNr+1)%NOOFICONS; // rotate |
120 | break; | 118 | break; |
121 | } | 119 | } |
122 | } | 120 | } |
123 | 121 | ||
124 | } | 122 | } |
125 | } \ No newline at end of file | 123 | } |
124 | |||
125 | #endif | ||
diff --git a/library/backend/rohfeedback.h b/library/backend/rohfeedback.h index f38a095..9ffd35a 100644 --- a/library/backend/rohfeedback.h +++ b/library/backend/rohfeedback.h | |||
@@ -1,19 +1,21 @@ | |||
1 | #ifndef ROHFEEDBACK_H | 1 | #ifndef ROHFEEDBACK_H |
2 | #define ROHFEEDBACK_H | 2 | #define ROHFEEDBACK_H |
3 | 3 | ||
4 | #ifdef OPIE_WITHROHFEEDBACK | ||
5 | |||
4 | /* | 6 | /* |
5 | 7 | ||
6 | RightOnHold feedback show | 8 | RightOnHold feedback show |
7 | 9 | ||
8 | */ | 10 | */ |
9 | 11 | ||
10 | #define NOOFICONS 5 | 12 | #define NOOFICONS 5 |
11 | 13 | ||
12 | #include <qlabel.h> | 14 | #include <qlabel.h> |
13 | #include <qtimer.h> | 15 | #include <qtimer.h> |
14 | 16 | ||
15 | class QEvent; | 17 | class QEvent; |
16 | class QPixmap; | 18 | class QPixmap; |
17 | class QBitmap; | 19 | class QBitmap; |
18 | class QMouseEvent; | 20 | class QMouseEvent; |
19 | 21 | ||
@@ -47,16 +49,17 @@ protected : | |||
47 | 49 | ||
48 | bool event( QEvent * E ); | 50 | bool event( QEvent * E ); |
49 | 51 | ||
50 | QTimer Timer; | 52 | QTimer Timer; |
51 | int IconNr; | 53 | int IconNr; |
52 | QWidget * Receiver; | 54 | QWidget * Receiver; |
53 | 55 | ||
54 | static int IconWidth; | 56 | static int IconWidth; |
55 | static int IconHeight; | 57 | static int IconHeight; |
56 | static QPixmap * Imgs[NOOFICONS]; | 58 | static QPixmap * Imgs[NOOFICONS]; |
57 | static QBitmap * Masks[NOOFICONS]; | 59 | static QBitmap * Masks[NOOFICONS]; |
58 | }; | 60 | }; |
59 | } | 61 | } |
60 | } | 62 | } |
61 | 63 | ||
62 | #endif | 64 | #endif |
65 | #endif | ||
diff --git a/library/config.in b/library/config.in index ea69ccb..5273976 100644 --- a/library/config.in +++ b/library/config.in | |||
@@ -1,2 +1,6 @@ | |||
1 | config LIBQPE | 1 | config LIBQPE |
2 | boolean "Qpe Library (Qt/Embedded version)" | 2 | boolean "Qpe Library (Qt/Embedded version)" |
3 | |||
4 | config LIBQPE_WITHROHFEEDBACK | ||
5 | boolean "Give visual feedback for RightOnHold" | ||
6 | depends LIBQPE | ||
diff --git a/library/library.pro b/library/library.pro index eb4bde3..af07fa3 100644 --- a/library/library.pro +++ b/library/library.pro | |||
@@ -34,32 +34,33 @@ HEADERS = calendar.h \ | |||
34 | timestring.h \ | 34 | timestring.h \ |
35 | fontfactoryinterface.h \ | 35 | fontfactoryinterface.h \ |
36 | fontdatabase.h \ | 36 | fontdatabase.h \ |
37 | power.h \ | 37 | power.h \ |
38 | storage.h \ | 38 | storage.h \ |
39 | qpemessagebox.h \ | 39 | qpemessagebox.h \ |
40 | timeconversion.h \ | 40 | timeconversion.h \ |
41 | qpedebug.h \ | 41 | qpedebug.h \ |
42 | qpemenubar.h \ | 42 | qpemenubar.h \ |
43 | qpetoolbar.h \ | 43 | qpetoolbar.h \ |
44 | backend/categories.h \ | 44 | backend/categories.h \ |
45 | stringutil.h \ | 45 | stringutil.h \ |
46 | backend/palmtoprecord.h \ | 46 | backend/palmtoprecord.h \ |
47 | backend/task.h \ | 47 | backend/task.h \ |
48 | backend/event.h \ | 48 | backend/event.h \ |
49 | backend/contact.h\ | 49 | backend/contact.h\ |
50 | backend/rohfeedback.h \ | ||
50 | categorymenu.h \ | 51 | categorymenu.h \ |
51 | categoryedit_p.h \ | 52 | categoryedit_p.h \ |
52 | categoryselect.h \ | 53 | categoryselect.h \ |
53 | categorywidget.h \ | 54 | categorywidget.h \ |
54 | ir.h \ | 55 | ir.h \ |
55 | backend/vobject_p.h \ | 56 | backend/vobject_p.h \ |
56 | findwidget_p.h \ | 57 | findwidget_p.h \ |
57 | finddialog.h \ | 58 | finddialog.h \ |
58 | lnkproperties.h \ | 59 | lnkproperties.h \ |
59 | windowdecorationinterface.h \ | 60 | windowdecorationinterface.h \ |
60 | textcodecinterface.h \ | 61 | textcodecinterface.h \ |
61 | imagecodecinterface.h \ | 62 | imagecodecinterface.h \ |
62 | qt_override_p.h | 63 | qt_override_p.h |
63 | 64 | ||
64 | SOURCES= calendar.cpp \ | 65 | SOURCES= calendar.cpp \ |
65 | global.cpp \ | 66 | global.cpp \ |
@@ -93,45 +94,50 @@ SOURCES = calendar.cpp \ | |||
93 | process_unix.cpp \ | 94 | process_unix.cpp \ |
94 | timestring.cpp \ | 95 | timestring.cpp \ |
95 | fontdatabase.cpp \ | 96 | fontdatabase.cpp \ |
96 | power.cpp \ | 97 | power.cpp \ |
97 | storage.cpp \ | 98 | storage.cpp \ |
98 | qpemessagebox.cpp \ | 99 | qpemessagebox.cpp \ |
99 | backend/timeconversion.cpp \ | 100 | backend/timeconversion.cpp \ |
100 | qpedebug.cpp \ | 101 | qpedebug.cpp \ |
101 | qpemenubar.cpp \ | 102 | qpemenubar.cpp \ |
102 | qpetoolbar.cpp \ | 103 | qpetoolbar.cpp \ |
103 | backend/categories.cpp \ | 104 | backend/categories.cpp \ |
104 | backend/stringutil.cpp \ | 105 | backend/stringutil.cpp \ |
105 | backend/palmtoprecord.cpp \ | 106 | backend/palmtoprecord.cpp \ |
106 | backend/task.cpp \ | 107 | backend/task.cpp \ |
107 | backend/event.cpp \ | 108 | backend/event.cpp \ |
108 | backend/contact.cpp \ | 109 | backend/contact.cpp \ |
110 | backend/rohfeedback.cpp \ | ||
109 | categorymenu.cpp \ | 111 | categorymenu.cpp \ |
110 | categoryedit_p.cpp \ | 112 | categoryedit_p.cpp \ |
111 | categoryselect.cpp \ | 113 | categoryselect.cpp \ |
112 | categorywidget.cpp \ | 114 | categorywidget.cpp \ |
113 | ir.cpp \ | 115 | ir.cpp \ |
114 | backend/vcc_yacc.cpp \ | 116 | backend/vcc_yacc.cpp \ |
115 | backend/vobject.cpp \ | 117 | backend/vobject.cpp \ |
116 | findwidget_p.cpp \ | 118 | findwidget_p.cpp \ |
117 | finddialog.cpp \ | 119 | finddialog.cpp \ |
118 | lnkproperties.cpp \ | 120 | lnkproperties.cpp \ |
119 | qt_override.cpp | 121 | qt_override.cpp |
120 | 122 | ||
121 | 123 | ||
122 | 124 | ||
123 | # Qt 3 compatibility | 125 | # Qt 3 compatibility |
124 | HEADERS += quuid.h qcom.h qlibrary.h qlibrary_p.h | 126 | HEADERS += quuid.h qcom.h qlibrary.h qlibrary_p.h |
125 | SOURCES += quuid.cpp qlibrary.cpp qlibrary_unix.cpp | 127 | SOURCES += quuid.cpp qlibrary.cpp qlibrary_unix.cpp |
126 | INCLUDEPATH += $(OPIEDIR)/include backend | 128 | INCLUDEPATH += $(OPIEDIR)/include backend |
127 | LIBS += -ldl -lcrypt -lm | 129 | LIBS += -ldl -lcrypt -lm |
128 | INTERFACES = passwordbase_p.ui categoryeditbase_p.ui findwidgetbase_p.ui lnkpropertiesbase_p.ui | 130 | INTERFACES = passwordbase_p.ui categoryeditbase_p.ui findwidgetbase_p.ui lnkpropertiesbase_p.ui |
129 | TARGET = qpe | 131 | TARGET = qpe |
130 | DESTDIR = $(OPIEDIR)/lib$(PROJMAK) | 132 | DESTDIR = $(OPIEDIR)/lib$(PROJMAK) |
131 | VERSION = 1.5.0.1 | 133 | VERSION = 1.5.0.1 |
132 | 134 | ||
133 | include ( $(OPIEDIR)/include.pro ) | 135 | include ( $(OPIEDIR)/include.pro ) |
134 | 136 | ||
135 | contains( CONFIG, no-override ){ | 137 | contains( CONFIG, no-override ){ |
136 | DEFINES += OPIE_NO_OVERRIDE_QT | 138 | DEFINES += OPIE_NO_OVERRIDE_QT |
137 | } | 139 | } |
140 | |||
141 | contains( CONFIG, LIBQPE_WITHROHFEEDBACK ){ | ||
142 | DEFINES += WITHROHFEEDBACK | ||
143 | } | ||
diff --git a/library/qpeapplication.cpp b/library/qpeapplication.cpp index 35f433c..c6d9cfd 100644 --- a/library/qpeapplication.cpp +++ b/library/qpeapplication.cpp | |||
@@ -84,74 +84,73 @@ | |||
84 | #endif | 84 | #endif |
85 | 85 | ||
86 | #include "alarmserver.h" | 86 | #include "alarmserver.h" |
87 | #include "applnk.h" | 87 | #include "applnk.h" |
88 | #include "qpemenubar.h" | 88 | #include "qpemenubar.h" |
89 | #include "textcodecinterface.h" | 89 | #include "textcodecinterface.h" |
90 | #include "imagecodecinterface.h" | 90 | #include "imagecodecinterface.h" |
91 | 91 | ||
92 | #include <unistd.h> | 92 | #include <unistd.h> |
93 | #include <sys/file.h> | 93 | #include <sys/file.h> |
94 | #include <sys/ioctl.h> | 94 | #include <sys/ioctl.h> |
95 | #ifndef QT_NO_SOUND | 95 | #ifndef QT_NO_SOUND |
96 | #include <sys/soundcard.h> | 96 | #include <sys/soundcard.h> |
97 | #endif | 97 | #endif |
98 | #include "qt_override_p.h" | 98 | #include "qt_override_p.h" |
99 | 99 | ||
100 | #include <qpe/rohfeedback.h> | 100 | #include <backend/rohfeedback.h> |
101 | 101 | ||
102 | 102 | ||
103 | static bool useBigPixmaps = 0; | 103 | static bool useBigPixmaps = 0; |
104 | 104 | ||
105 | |||
106 | class HackWidget : public QWidget | 105 | class HackWidget : public QWidget |
107 | { | 106 | { |
108 | public: | 107 | public: |
109 | bool needsOk() | 108 | bool needsOk() |
110 | { return (getWState() & WState_Reserved1 ); } | 109 | { return (getWState() & WState_Reserved1 ); } |
111 | 110 | ||
112 | QRect normalGeometry() | 111 | QRect normalGeometry() |
113 | { return topData()->normalGeometry; }; | 112 | { return topData()->normalGeometry; }; |
114 | }; | 113 | }; |
115 | 114 | ||
116 | class QPEApplicationData | 115 | class QPEApplicationData |
117 | { | 116 | { |
118 | public: | 117 | public: |
119 | QPEApplicationData ( ) | 118 | QPEApplicationData ( ) : |
120 | : presstimer( 0 ), presswidget( 0 ), rightpressed( false ), kbgrabbed( false ), | 119 | presstimer( 0 ), presswidget( 0 ), rightpressed( false ), kbgrabbed( false ), |
121 | notbusysent( false ), preloaded( false ), forceshow( false ), nomaximize( false ), | 120 | notbusysent( false ), preloaded( false ), forceshow( false ), nomaximize( false ), |
122 | keep_running( true ), qcopQok( false ), | 121 | keep_running( true ), qcopQok( false ), |
123 | fontFamily( "Vera" ), fontSize( 10 ), smallIconSize( 14 ), | 122 | fontFamily( "Vera" ), fontSize( 10 ), smallIconSize( 14 ), |
124 | bigIconSize( 32 ), qpe_main_widget( 0 ) | 123 | bigIconSize( 32 ), qpe_main_widget( 0 ) |
125 | { | 124 | { |
126 | Config cfg( "qpe" ); | 125 | Config cfg( "qpe" ); |
127 | cfg.setGroup( "Appearance" ); | 126 | cfg.setGroup( "Appearance" ); |
128 | useBigPixmaps = cfg.readBoolEntry( "useBigPixmaps", false ); | 127 | useBigPixmaps = cfg.readBoolEntry( "useBigPixmaps", false ); |
129 | fontFamily = cfg.readEntry( "FontFamily", "Vera" ); | 128 | fontFamily = cfg.readEntry( "FontFamily", "Vera" ); |
130 | fontSize = cfg.readNumEntry( "FontSize", 10 ); | 129 | fontSize = cfg.readNumEntry( "FontSize", 10 ); |
131 | smallIconSize = cfg.readNumEntry( "SmallIconSize", 14 ); | 130 | smallIconSize = cfg.readNumEntry( "SmallIconSize", 14 ); |
132 | bigIconSize = cfg.readNumEntry( "BigIconSize", 32 ); | 131 | bigIconSize = cfg.readNumEntry( "BigIconSize", 32 ); |
133 | #ifdef OPIE_ROHFEEDBACK | 132 | #ifdef OPIE_WITHROHFEEDBACK |
134 | RoH = 0; | 133 | RoH = 0; |
135 | #endif | 134 | #endif |
136 | } | 135 | } |
137 | 136 | ||
138 | int presstimer; | 137 | int presstimer; |
139 | QWidget* presswidget; | 138 | QWidget* presswidget; |
140 | QPoint presspos; | 139 | QPoint presspos; |
141 | #ifdef OPIE_ROHFEEDBACK | 140 | #ifdef OPIE_WITHROHFEEDBACK |
142 | Opie::Internal::RoHFeedback *RoH; | 141 | Opie::Internal::RoHFeedback *RoH; |
143 | #endif | 142 | #endif |
144 | 143 | ||
145 | bool rightpressed : 1; | 144 | bool rightpressed : 1; |
146 | bool kbgrabbed : 1; | 145 | bool kbgrabbed : 1; |
147 | bool notbusysent : 1; | 146 | bool notbusysent : 1; |
148 | bool preloaded : 1; | 147 | bool preloaded : 1; |
149 | bool forceshow : 1; | 148 | bool forceshow : 1; |
150 | bool nomaximize : 1; | 149 | bool nomaximize : 1; |
151 | bool keep_running : 1; | 150 | bool keep_running : 1; |
152 | bool qcopQok : 1; | 151 | bool qcopQok : 1; |
153 | 152 | ||
154 | QCString fontFamily; | 153 | QCString fontFamily; |
155 | int fontSize; | 154 | int fontSize; |
156 | int smallIconSize; | 155 | int smallIconSize; |
157 | int bigIconSize; | 156 | int bigIconSize; |
@@ -489,32 +488,33 @@ static void qpe_show_dialog( QDialog* d, bool nomax ) | |||
489 | for ( it = list.begin(); it != list.end(); ++it ) { | 488 | for ( it = list.begin(); it != list.end(); ++it ) { |
490 | ImageCodecInterface *iface = 0; | 489 | ImageCodecInterface *iface = 0; |
491 | QLibrary *lib = new QLibrary( path + "/" + *it ); | 490 | QLibrary *lib = new QLibrary( path + "/" + *it ); |
492 | if ( lib->queryInterface( IID_QtopiaImageCodec, (QUnknownInterface**)&iface ) == QS_OK && iface ) { | 491 | if ( lib->queryInterface( IID_QtopiaImageCodec, (QUnknownInterface**)&iface ) == QS_OK && iface ) { |
493 | QStringList formats = iface->keys(); | 492 | QStringList formats = iface->keys(); |
494 | for (QStringList::ConstIterator i = formats.begin(); i != formats.end(); ++i) { | 493 | for (QStringList::ConstIterator i = formats.begin(); i != formats.end(); ++i) { |
495 | (void)iface->installIOHandler(*i); | 494 | (void)iface->installIOHandler(*i); |
496 | // ### it exists now; need to remember if we can delete it | 495 | // ### it exists now; need to remember if we can delete it |
497 | } | 496 | } |
498 | } | 497 | } |
499 | else { | 498 | else { |
500 | lib->unload(); | 499 | lib->unload(); |
501 | delete lib; | 500 | delete lib; |
502 | } | 501 | } |
503 | } | 502 | } |
504 | } | 503 | } |
504 | |||
505 | }; | 505 | }; |
506 | 506 | ||
507 | class ResourceMimeFactory : public QMimeSourceFactory | 507 | class ResourceMimeFactory : public QMimeSourceFactory |
508 | { | 508 | { |
509 | public: | 509 | public: |
510 | ResourceMimeFactory() : resImage( 0 ) | 510 | ResourceMimeFactory() : resImage( 0 ) |
511 | { | 511 | { |
512 | setFilePath( Global::helpPath() ); | 512 | setFilePath( Global::helpPath() ); |
513 | setExtensionType( "html", "text/html;charset=UTF-8" ); | 513 | setExtensionType( "html", "text/html;charset=UTF-8" ); |
514 | } | 514 | } |
515 | ~ResourceMimeFactory() { | 515 | ~ResourceMimeFactory() { |
516 | delete resImage; | 516 | delete resImage; |
517 | } | 517 | } |
518 | 518 | ||
519 | const QMimeSource* data( const QString& abs_name ) const | 519 | const QMimeSource* data( const QString& abs_name ) const |
520 | { | 520 | { |
@@ -1202,34 +1202,36 @@ bool QPEApplication::qwsEventFilter( QWSEvent * e ) | |||
1202 | return QApplication::qwsEventFilter( e ); | 1202 | return QApplication::qwsEventFilter( e ); |
1203 | } | 1203 | } |
1204 | #endif | 1204 | #endif |
1205 | 1205 | ||
1206 | /*! | 1206 | /*! |
1207 | Destroys the QPEApplication. | 1207 | Destroys the QPEApplication. |
1208 | */ | 1208 | */ |
1209 | QPEApplication::~QPEApplication() | 1209 | QPEApplication::~QPEApplication() |
1210 | { | 1210 | { |
1211 | ungrabKeyboard(); | 1211 | ungrabKeyboard(); |
1212 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 1212 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
1213 | // Need to delete QCopChannels early, since the display will | 1213 | // Need to delete QCopChannels early, since the display will |
1214 | // be gone by the time we get to ~QObject(). | 1214 | // be gone by the time we get to ~QObject(). |
1215 | delete sysChannel; | 1215 | delete sysChannel; |
1216 | delete pidChannel; | 1216 | delete pidChannel; |
1217 | #endif | 1217 | #endif |
1218 | #ifdef OPIE_ROHFEEDBACK | 1218 | |
1219 | delete d->RoH; | 1219 | #ifdef OPIE_WITHROHFEEDBACK |
1220 | if( d->RoH ) | ||
1221 | delete d->RoH; | ||
1220 | #endif | 1222 | #endif |
1221 | delete d; | 1223 | delete d; |
1222 | } | 1224 | } |
1223 | 1225 | ||
1224 | /*! | 1226 | /*! |
1225 | Returns <tt>$OPIEDIR/</tt>. | 1227 | Returns <tt>$OPIEDIR/</tt>. |
1226 | */ | 1228 | */ |
1227 | QString QPEApplication::qpeDir() | 1229 | QString QPEApplication::qpeDir() |
1228 | { | 1230 | { |
1229 | const char * base = getenv( "OPIEDIR" ); | 1231 | const char * base = getenv( "OPIEDIR" ); |
1230 | if ( base ) | 1232 | if ( base ) |
1231 | return QString( base ) + "/"; | 1233 | return QString( base ) + "/"; |
1232 | 1234 | ||
1233 | return QString( "../" ); | 1235 | return QString( "../" ); |
1234 | } | 1236 | } |
1235 | 1237 | ||
@@ -2022,70 +2024,69 @@ void QPEApplication::setStylusOperation( QWidget * w, StylusMode mode ) | |||
2022 | /*! | 2024 | /*! |
2023 | \reimp | 2025 | \reimp |
2024 | */ | 2026 | */ |
2025 | bool QPEApplication::eventFilter( QObject *o, QEvent *e ) | 2027 | bool QPEApplication::eventFilter( QObject *o, QEvent *e ) |
2026 | { | 2028 | { |
2027 | if ( !o->isWidgetType() ) | 2029 | if ( !o->isWidgetType() ) |
2028 | return FALSE; | 2030 | return FALSE; |
2029 | 2031 | ||
2030 | if ( stylusDict && e->type() >= QEvent::MouseButtonPress && e->type() <= QEvent::MouseMove ) { | 2032 | if ( stylusDict && e->type() >= QEvent::MouseButtonPress && e->type() <= QEvent::MouseMove ) { |
2031 | QMouseEvent * me = ( QMouseEvent* ) e; | 2033 | QMouseEvent * me = ( QMouseEvent* ) e; |
2032 | StylusMode mode = (StylusMode)(int)stylusDict->find(o); | 2034 | StylusMode mode = (StylusMode)(int)stylusDict->find(o); |
2033 | switch (mode) { | 2035 | switch (mode) { |
2034 | case RightOnHold: | 2036 | case RightOnHold: |
2035 | switch ( me->type() ) { | 2037 | switch ( me->type() ) { |
2036 | case QEvent::MouseButtonPress: | 2038 | case QEvent::MouseButtonPress: |
2037 | if ( me->button() == LeftButton ) { | 2039 | if ( me->button() == LeftButton ) { |
2040 | static long Pref = 500; // #### pref. | ||
2038 | d->presswidget = (QWidget*)o; | 2041 | d->presswidget = (QWidget*)o; |
2039 | d->presspos = me->pos(); | 2042 | d->presspos = me->pos(); |
2040 | d->rightpressed = FALSE; | 2043 | d->rightpressed = FALSE; |
2041 | // just for the time being | 2044 | #ifdef OPIE_WITHROHFEEDBACK |
2042 | static int pref = 500; | ||
2043 | #ifdef OPIE_ROHFEEDBACK | ||
2044 | if( ! d->RoH ) | 2045 | if( ! d->RoH ) |
2045 | d->RoH = new Opie::Internal::RoHFeedback; | 2046 | d->RoH = new Opie::Internal::RoHFeedback; |
2046 | 2047 | ||
2047 | d->RoH->init( me->globalPos(), d->presswidget ); | 2048 | d->RoH->init( me->globalPos(), d->presswidget ); |
2048 | pref = d->RoH->delay(); | 2049 | Pref = d->RoH->delay(); |
2050 | |||
2049 | #endif | 2051 | #endif |
2050 | if (!d->presstimer ) | 2052 | if (!d->presstimer ) |
2051 | d->presstimer = startTimer( pref ); // #### pref. | 2053 | d->presstimer = startTimer( Pref ); // #### pref. |
2052 | 2054 | ||
2053 | } | 2055 | } |
2054 | break; | 2056 | break; |
2055 | case QEvent::MouseMove: | 2057 | case QEvent::MouseMove: |
2056 | if (d->presstimer && (me->pos() - d->presspos).manhattanLength() > 8) { | 2058 | if (d->presstimer && (me->pos() - d->presspos).manhattanLength() > 8) { |
2057 | killTimer(d->presstimer); | 2059 | killTimer(d->presstimer); |
2058 | #ifdef OPIE_ROHFEEDBACK | 2060 | #ifdef OPIE_WITHROHFEEDBACK |
2059 | if( d->RoH ) | 2061 | d->RoH->stop(); |
2060 | d->RoH->stop( ); | ||
2061 | #endif | 2062 | #endif |
2062 | d->presstimer = 0; | 2063 | d->presstimer = 0; |
2063 | } | 2064 | } |
2064 | break; | 2065 | break; |
2065 | case QEvent::MouseButtonRelease: | 2066 | case QEvent::MouseButtonRelease: |
2066 | if ( me->button() == LeftButton ) { | 2067 | if ( me->button() == LeftButton ) { |
2067 | if ( d->presstimer ) { | 2068 | if ( d->presstimer ) { |
2068 | killTimer(d->presstimer); | 2069 | killTimer(d->presstimer); |
2069 | #ifdef OPIE_ROHFEEDBACK | 2070 | #ifdef OPIE_WITHROHFEEDBACK |
2070 | if( d->RoH ) | 2071 | d->RoH->stop( ); |
2071 | d->RoH->stop( ); | ||
2072 | #endif | 2072 | #endif |
2073 | d->presstimer = 0; | 2073 | d->presstimer = 0; |
2074 | } | 2074 | } |
2075 | if ( d->rightpressed && d->presswidget ) { | 2075 | if ( d->rightpressed && d->presswidget ) { |
2076 | printf( "Send ButtonRelease\n" ); | ||
2076 | // Right released | 2077 | // Right released |
2077 | postEvent( d->presswidget, | 2078 | postEvent( d->presswidget, |
2078 | new QMouseEvent( QEvent::MouseButtonRelease, me->pos(), | 2079 | new QMouseEvent( QEvent::MouseButtonRelease, me->pos(), |
2079 | RightButton, LeftButton + RightButton ) ); | 2080 | RightButton, LeftButton + RightButton ) ); |
2080 | // Left released, off-widget | 2081 | // Left released, off-widget |
2081 | postEvent( d->presswidget, | 2082 | postEvent( d->presswidget, |
2082 | new QMouseEvent( QEvent::MouseMove, QPoint( -1, -1), | 2083 | new QMouseEvent( QEvent::MouseMove, QPoint( -1, -1), |
2083 | LeftButton, LeftButton ) ); | 2084 | LeftButton, LeftButton ) ); |
2084 | postEvent( d->presswidget, | 2085 | postEvent( d->presswidget, |
2085 | new QMouseEvent( QEvent::MouseButtonRelease, QPoint( -1, -1), | 2086 | new QMouseEvent( QEvent::MouseButtonRelease, QPoint( -1, -1), |
2086 | LeftButton, LeftButton ) ); | 2087 | LeftButton, LeftButton ) ); |
2087 | d->rightpressed = FALSE; | 2088 | d->rightpressed = FALSE; |
2088 | return TRUE; // don't send the real Left release | 2089 | return TRUE; // don't send the real Left release |
2089 | } | 2090 | } |
2090 | } | 2091 | } |
2091 | break; | 2092 | break; |
@@ -2103,41 +2104,42 @@ bool QPEApplication::eventFilter( QObject *o, QEvent *e ) | |||
2103 | if ( o->isA( "QRadioButton" ) || o->isA( "QCheckBox" ) ) { | 2104 | if ( o->isA( "QRadioButton" ) || o->isA( "QCheckBox" ) ) { |
2104 | postEvent( o, new QKeyEvent( e->type(), Key_Space, ' ', | 2105 | postEvent( o, new QKeyEvent( e->type(), Key_Space, ' ', |
2105 | ke->state(), " ", ke->isAutoRepeat(), ke->count() ) ); | 2106 | ke->state(), " ", ke->isAutoRepeat(), ke->count() ) ); |
2106 | return TRUE; | 2107 | return TRUE; |
2107 | } | 2108 | } |
2108 | } | 2109 | } |
2109 | } | 2110 | } |
2110 | return FALSE; | 2111 | return FALSE; |
2111 | } | 2112 | } |
2112 | 2113 | ||
2113 | /*! | 2114 | /*! |
2114 | \reimp | 2115 | \reimp |
2115 | */ | 2116 | */ |
2116 | void QPEApplication::timerEvent( QTimerEvent *e ) | 2117 | void QPEApplication::timerEvent( QTimerEvent *e ) |
2117 | { | 2118 | { |
2118 | if ( e->timerId() == d->presstimer && d->presswidget ) { | 2119 | if ( e->timerId() == d->presstimer && d->presswidget ) { |
2119 | // Right pressed | 2120 | |
2120 | postEvent( d->presswidget, | 2121 | // Right pressed |
2121 | new QMouseEvent( QEvent::MouseButtonPress, d->presspos, | 2122 | postEvent( d->presswidget, |
2122 | RightButton, LeftButton ) ); | 2123 | new QMouseEvent( QEvent::MouseButtonPress, d->presspos, |
2123 | killTimer( d->presstimer ); | 2124 | RightButton, LeftButton ) ); |
2124 | d->presstimer = 0; | 2125 | killTimer( d->presstimer ); |
2125 | d->rightpressed = TRUE; | 2126 | d->presstimer = 0; |
2126 | #ifdef OPIE_ROHFEEDBACK | 2127 | d->rightpressed = TRUE; |
2127 | d->RoH->stop(); | 2128 | #ifdef OPIE_WITHROHFEEDBACK |
2129 | d->RoH->stop(); | ||
2128 | #endif | 2130 | #endif |
2129 | } | 2131 | } |
2130 | } | 2132 | } |
2131 | 2133 | ||
2132 | void QPEApplication::removeSenderFromStylusDict() | 2134 | void QPEApplication::removeSenderFromStylusDict() |
2133 | { | 2135 | { |
2134 | stylusDict->remove | 2136 | stylusDict->remove |
2135 | ( ( void* ) sender() ); | 2137 | ( ( void* ) sender() ); |
2136 | if ( d->presswidget == sender() ) | 2138 | if ( d->presswidget == sender() ) |
2137 | d->presswidget = 0; | 2139 | d->presswidget = 0; |
2138 | } | 2140 | } |
2139 | 2141 | ||
2140 | /*! | 2142 | /*! |
2141 | \internal | 2143 | \internal |
2142 | */ | 2144 | */ |
2143 | bool QPEApplication::keyboardGrabbed() const | 2145 | bool QPEApplication::keyboardGrabbed() const |
diff --git a/library/qpeapplication.h b/library/qpeapplication.h index d2782e4..b07802f 100644 --- a/library/qpeapplication.h +++ b/library/qpeapplication.h | |||
@@ -171,34 +171,32 @@ protected: | |||
171 | #endif | 171 | #endif |
172 | private: | 172 | private: |
173 | #ifndef QT_NO_TRANSLATION | 173 | #ifndef QT_NO_TRANSLATION |
174 | void installTranslation( const QString& baseName ); | 174 | void installTranslation( const QString& baseName ); |
175 | #endif | 175 | #endif |
176 | void mapToDefaultAction( QWSKeyEvent *ke, int defKey ); | 176 | void mapToDefaultAction( QWSKeyEvent *ke, int defKey ); |
177 | void processQCopFile(); | 177 | void processQCopFile(); |
178 | 178 | ||
179 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 179 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
180 | QCopChannel *sysChannel; | 180 | QCopChannel *sysChannel; |
181 | QCopChannel *pidChannel; | 181 | QCopChannel *pidChannel; |
182 | #endif | 182 | #endif |
183 | QPEApplicationData *d; | 183 | QPEApplicationData *d; |
184 | 184 | ||
185 | bool reserved_sh; | 185 | bool reserved_sh; |
186 | 186 | ||
187 | |||
188 | |||
189 | }; | 187 | }; |
190 | 188 | ||
191 | inline void QPEApplication::showDialog( QDialog* d, bool nomax ) | 189 | inline void QPEApplication::showDialog( QDialog* d, bool nomax ) |
192 | { | 190 | { |
193 | showWidget( d, nomax ); | 191 | showWidget( d, nomax ); |
194 | } | 192 | } |
195 | 193 | ||
196 | inline int QPEApplication::execDialog( QDialog* d, bool nomax ) | 194 | inline int QPEApplication::execDialog( QDialog* d, bool nomax ) |
197 | { | 195 | { |
198 | showDialog( d, nomax ); | 196 | showDialog( d, nomax ); |
199 | return d->exec(); | 197 | return d->exec(); |
200 | } | 198 | } |
201 | 199 | ||
202 | #ifdef Q_WS_QWS | 200 | #ifdef Q_WS_QWS |
203 | extern Q_EXPORT QRect qt_maxWindowRect; | 201 | extern Q_EXPORT QRect qt_maxWindowRect; |
204 | #endif | 202 | #endif |