author | ar <ar> | 2004-04-21 21:26:14 (UTC) |
---|---|---|
committer | ar <ar> | 2004-04-21 21:26:14 (UTC) |
commit | 2a04bf465c332f5e879470f7436852e2d9686083 (patch) (unidiff) | |
tree | 358bdc16f9948bc954380932fd9d1c92efe4e61b /library | |
parent | 8269dfa474065b986375de7c4fd380cbda837a12 (diff) | |
download | opie-2a04bf465c332f5e879470f7436852e2d9686083.zip opie-2a04bf465c332f5e879470f7436852e2d9686083.tar.gz opie-2a04bf465c332f5e879470f7436852e2d9686083.tar.bz2 |
BigScreen: don't resize widgets that always visible (for example on bring a widget to front)
-rw-r--r-- | library/qpeapplication.h | 43 |
1 files changed, 24 insertions, 19 deletions
diff --git a/library/qpeapplication.h b/library/qpeapplication.h index 9ea7e9d..8c85ad0 100644 --- a/library/qpeapplication.h +++ b/library/qpeapplication.h | |||
@@ -78,186 +78,191 @@ class QWSKeyEvent; | |||
78 | */ | 78 | */ |
79 | class QPEApplication : public QApplication | 79 | class QPEApplication : public QApplication |
80 | { | 80 | { |
81 | Q_OBJECT | 81 | Q_OBJECT |
82 | public: | 82 | public: |
83 | QPEApplication( int& argc, char **argv, Type=GuiClient ); | 83 | QPEApplication( int& argc, char **argv, Type=GuiClient ); |
84 | ~QPEApplication(); | 84 | ~QPEApplication(); |
85 | 85 | ||
86 | static QString qpeDir(); | 86 | static QString qpeDir(); |
87 | static QString documentDir(); | 87 | static QString documentDir(); |
88 | void applyStyle(); | 88 | void applyStyle(); |
89 | void reset(); | 89 | void reset(); |
90 | static int defaultRotation(); | 90 | static int defaultRotation(); |
91 | static void setDefaultRotation(int r); | 91 | static void setDefaultRotation(int r); |
92 | static void setCurrentRotation(int r); | 92 | static void setCurrentRotation(int r); |
93 | static void setCurrentMode(int x, int y, int depth ); | 93 | static void setCurrentMode(int x, int y, int depth ); |
94 | static void grabKeyboard(); | 94 | static void grabKeyboard(); |
95 | static void ungrabKeyboard(); | 95 | static void ungrabKeyboard(); |
96 | 96 | ||
97 | enum StylusMode { | 97 | enum StylusMode { |
98 | LeftOnly, | 98 | LeftOnly, |
99 | RightOnHold | 99 | RightOnHold |
100 | // RightOnHoldLeftDelayed, etc. | 100 | // RightOnHoldLeftDelayed, etc. |
101 | }; | 101 | }; |
102 | static void setStylusOperation( QWidget*, StylusMode ); | 102 | static void setStylusOperation( QWidget*, StylusMode ); |
103 | static StylusMode stylusOperation( QWidget* ); | 103 | static StylusMode stylusOperation( QWidget* ); |
104 | 104 | ||
105 | enum InputMethodHint { | 105 | enum InputMethodHint { |
106 | Normal, | 106 | Normal, |
107 | AlwaysOff, | 107 | AlwaysOff, |
108 | AlwaysOn | 108 | AlwaysOn |
109 | }; | 109 | }; |
110 | 110 | ||
111 | enum screenSaverHint { | 111 | enum screenSaverHint { |
112 | Disable = 0, | 112 | Disable = 0, |
113 | DisableLightOff = 1, | 113 | DisableLightOff = 1, |
114 | DisableSuspend = 2, | 114 | DisableSuspend = 2, |
115 | Enable = 100 | 115 | Enable = 100 |
116 | }; | 116 | }; |
117 | 117 | ||
118 | static void setInputMethodHint( QWidget *, InputMethodHint ); | 118 | static void setInputMethodHint( QWidget *, InputMethodHint ); |
119 | static InputMethodHint inputMethodHint( QWidget * ); | 119 | static InputMethodHint inputMethodHint( QWidget * ); |
120 | 120 | ||
121 | void showMainWidget( QWidget*, bool nomax=FALSE ); | 121 | void showMainWidget( QWidget*, bool nomax=FALSE ); |
122 | void showMainDocumentWidget( QWidget*, bool nomax=FALSE ); | 122 | void showMainDocumentWidget( QWidget*, bool nomax=FALSE ); |
123 | static void showDialog( QDialog*, bool nomax=FALSE ); | 123 | static void showDialog( QDialog*, bool nomax=FALSE ); |
124 | static int execDialog( QDialog*, bool nomax=FALSE ); | 124 | static int execDialog( QDialog*, bool nomax=FALSE ); |
125 | static void showWidget( QWidget*, bool nomax=FALSE ); | 125 | static void showWidget( QWidget*, bool nomax=FALSE ); |
126 | /* Merge setTempScreenSaverMode */ | 126 | /* Merge setTempScreenSaverMode */ |
127 | #ifdef QTOPIA_INTERNAL_INITAPP | 127 | #ifdef QTOPIA_INTERNAL_INITAPP |
128 | void initApp( int argv, char **argv ); | 128 | void initApp( int argv, char **argv ); |
129 | #endif | 129 | #endif |
130 | 130 | ||
131 | static void setKeepRunning(); | 131 | static void setKeepRunning(); |
132 | bool keepRunning() const; | 132 | bool keepRunning() const; |
133 | 133 | ||
134 | bool keyboardGrabbed() const; | 134 | bool keyboardGrabbed() const; |
135 | 135 | ||
136 | int exec(); | 136 | int exec(); |
137 | 137 | ||
138 | signals: | 138 | signals: |
139 | void clientMoused(); | 139 | void clientMoused(); |
140 | void timeChanged(); | 140 | void timeChanged(); |
141 | void clockChanged( bool pm ); | 141 | void clockChanged( bool pm ); |
142 | void micChanged( bool muted ); | 142 | void micChanged( bool muted ); |
143 | void volumeChanged( bool muted ); | 143 | void volumeChanged( bool muted ); |
144 | void appMessage( const QCString& msg, const QByteArray& data); | 144 | void appMessage( const QCString& msg, const QByteArray& data); |
145 | void weekChanged( bool startOnMonday ); | 145 | void weekChanged( bool startOnMonday ); |
146 | void dateFormatChanged( DateFormat ); | 146 | void dateFormatChanged( DateFormat ); |
147 | void flush(); | 147 | void flush(); |
148 | void reload(); | 148 | void reload(); |
149 | /* linkChanged signal */ | 149 | /* linkChanged signal */ |
150 | 150 | ||
151 | private slots: | 151 | private slots: |
152 | void systemMessage( const QCString &msg, const QByteArray &data ); | 152 | void systemMessage( const QCString &msg, const QByteArray &data ); |
153 | void pidMessage( const QCString &msg, const QByteArray &data ); | 153 | void pidMessage( const QCString &msg, const QByteArray &data ); |
154 | void removeSenderFromStylusDict(); | 154 | void removeSenderFromStylusDict(); |
155 | void hideOrQuit(); | 155 | void hideOrQuit(); |
156 | 156 | ||
157 | protected: | 157 | protected: |
158 | bool qwsEventFilter( QWSEvent * ); | 158 | bool qwsEventFilter( QWSEvent * ); |
159 | void internalSetStyle( const QString &style ); | 159 | void internalSetStyle( const QString &style ); |
160 | void prepareForTermination(bool willrestart); | 160 | void prepareForTermination(bool willrestart); |
161 | virtual void restart(); | 161 | virtual void restart(); |
162 | virtual void shutdown(); | 162 | virtual void shutdown(); |
163 | bool eventFilter( QObject *, QEvent * ); | 163 | bool eventFilter( QObject *, QEvent * ); |
164 | void timerEvent( QTimerEvent * ); | 164 | void timerEvent( QTimerEvent * ); |
165 | bool raiseAppropriateWindow(); | 165 | bool raiseAppropriateWindow(); |
166 | virtual void tryQuit(); | 166 | virtual void tryQuit(); |
167 | #if QT_VERSION > 233 | 167 | #if QT_VERSION > 233 |
168 | virtual void polish ( QWidget * ); // this is actually implemented in qt_override.cpp (!) | 168 | virtual void polish ( QWidget * ); // this is actually implemented in qt_override.cpp (!) |
169 | #endif | 169 | #endif |
170 | private: | 170 | private: |
171 | #ifndef QT_NO_TRANSLATION | 171 | #ifndef QT_NO_TRANSLATION |
172 | void installTranslation( const QString& baseName ); | 172 | void installTranslation( const QString& baseName ); |
173 | #endif | 173 | #endif |
174 | void mapToDefaultAction( QWSKeyEvent *ke, int defKey ); | 174 | void mapToDefaultAction( QWSKeyEvent *ke, int defKey ); |
175 | void processQCopFile(); | 175 | void processQCopFile(); |
176 | 176 | ||
177 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 177 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
178 | QCopChannel *sysChannel; | 178 | QCopChannel *sysChannel; |
179 | QCopChannel *pidChannel; | 179 | QCopChannel *pidChannel; |
180 | #endif | 180 | #endif |
181 | QPEApplicationData *d; | 181 | QPEApplicationData *d; |
182 | 182 | ||
183 | bool reserved_sh; | 183 | bool reserved_sh; |
184 | 184 | ||
185 | 185 | ||
186 | 186 | ||
187 | }; | 187 | }; |
188 | 188 | ||
189 | inline void QPEApplication::showDialog( QDialog* d, bool nomax ) | 189 | inline void QPEApplication::showDialog( QDialog* d, bool nomax ) |
190 | { | 190 | { |
191 | showWidget( d, nomax ); | 191 | showWidget( d, nomax ); |
192 | } | 192 | } |
193 | 193 | ||
194 | inline int QPEApplication::execDialog( QDialog* d, bool nomax ) | 194 | inline int QPEApplication::execDialog( QDialog* d, bool nomax ) |
195 | { | 195 | { |
196 | showDialog( d, nomax ); | 196 | showDialog( d, nomax ); |
197 | return d->exec(); | 197 | return d->exec(); |
198 | } | 198 | } |
199 | 199 | ||
200 | #ifdef Q_WS_QWS | 200 | #ifdef Q_WS_QWS |
201 | extern Q_EXPORT QRect qt_maxWindowRect; | 201 | extern Q_EXPORT QRect qt_maxWindowRect; |
202 | #endif | 202 | #endif |
203 | 203 | ||
204 | inline void QPEApplication::showWidget( QWidget* wg, bool nomax ) | 204 | inline void QPEApplication::showWidget( QWidget* wg, bool nomax ) |
205 | { | 205 | { |
206 | if ( !nomax | 206 | if ( wg->isVisible() ) |
207 | && ( qApp->desktop()->width() <= 320 ) ) | ||
208 | { | ||
209 | wg->showMaximized(); | ||
210 | } else { | ||
211 | #ifdef Q_WS_QWS | ||
212 | QSize desk = QSize( qApp->desktop()->width(), qApp->desktop()->height() ); | ||
213 | #else | ||
214 | QSize desk = QSize( qt_maxWindowRect.width(), qt_maxWindowRect.height() ); | ||
215 | #endif | ||
216 | |||
217 | QSize sh = wg->sizeHint(); | ||
218 | int w = QMAX( sh.width(), wg->width() ); | ||
219 | int h = QMAX( sh.height(), wg->height() ); | ||
220 | // desktop widget-frame taskbar | ||
221 | w = QMIN( w, ( desk.width() - ( wg->frameGeometry().width() - wg->geometry().width() ) - 25 ) ); | ||
222 | h = QMIN( h, ( desk.height() - ( wg->frameGeometry().height() - wg->geometry().height() ) - 25 ) ); | ||
223 | |||
224 | wg->resize( w, h ); | ||
225 | wg->show(); | 207 | wg->show(); |
208 | else | ||
209 | { | ||
210 | if ( !nomax | ||
211 | && ( qApp->desktop()->width() <= 320 ) ) | ||
212 | { | ||
213 | wg->showMaximized(); | ||
214 | } else { | ||
215 | #ifdef Q_WS_QWS | ||
216 | QSize desk = QSize( qApp->desktop()->width(), qApp->desktop()->height() ); | ||
217 | #else | ||
218 | QSize desk = QSize( qt_maxWindowRect.width(), qt_maxWindowRect.height() ); | ||
219 | #endif | ||
220 | |||
221 | QSize sh = wg->sizeHint(); | ||
222 | int w = QMAX( sh.width(), wg->width() ); | ||
223 | int h = QMAX( sh.height(), wg->height() ); | ||
224 | // desktop widget-frame taskbar | ||
225 | w = QMIN( w, ( desk.width() - ( wg->frameGeometry().width() - wg->geometry().width() ) - 25 ) ); | ||
226 | h = QMIN( h, ( desk.height() - ( wg->frameGeometry().height() - wg->geometry().height() ) - 25 ) ); | ||
227 | |||
228 | wg->resize( w, h ); | ||
229 | wg->show(); | ||
230 | } | ||
226 | } | 231 | } |
227 | } | 232 | } |
228 | 233 | ||
229 | enum Transformation { Rot0, Rot90, Rot180, Rot270 }; /* from qgfxtransformed_qws.cpp */ | 234 | enum Transformation { Rot0, Rot90, Rot180, Rot270 }; /* from qgfxtransformed_qws.cpp */ |
230 | 235 | ||
231 | inline int TransToDeg ( Transformation t ) | 236 | inline int TransToDeg ( Transformation t ) |
232 | { | 237 | { |
233 | int d = static_cast<int>( t ); | 238 | int d = static_cast<int>( t ); |
234 | return d * 90; | 239 | return d * 90; |
235 | } | 240 | } |
236 | 241 | ||
237 | inline Transformation DegToTrans ( int d ) | 242 | inline Transformation DegToTrans ( int d ) |
238 | { | 243 | { |
239 | Transformation t = static_cast<Transformation>( d / 90 ); | 244 | Transformation t = static_cast<Transformation>( d / 90 ); |
240 | return t; | 245 | return t; |
241 | } | 246 | } |
242 | 247 | ||
243 | /* | 248 | /* |
244 | * Set current rotation of Opie, and rotation for newly started apps. | 249 | * Set current rotation of Opie, and rotation for newly started apps. |
245 | * Differs from setDefaultRotation in that 1) it rotates currently running apps, | 250 | * Differs from setDefaultRotation in that 1) it rotates currently running apps, |
246 | * and 2) does not set deforient or save orientation to qpe.conf. | 251 | * and 2) does not set deforient or save orientation to qpe.conf. |
247 | */ | 252 | */ |
248 | 253 | ||
249 | inline void QPEApplication::setCurrentRotation( int r ) | 254 | inline void QPEApplication::setCurrentRotation( int r ) |
250 | { | 255 | { |
251 | // setTransformation has been introduced in Qt/Embedded 2.3.4 snapshots | 256 | // setTransformation has been introduced in Qt/Embedded 2.3.4 snapshots |
252 | // for compatibility with the SharpROM use fallback to setDefaultTransformation() | 257 | // for compatibility with the SharpROM use fallback to setDefaultTransformation() |
253 | #if QT_VERSION > 233 | 258 | #if QT_VERSION > 233 |
254 | Transformation e = DegToTrans( r ); | 259 | Transformation e = DegToTrans( r ); |
255 | ::setenv( "QWS_DISPLAY", QString( "Transformed:Rot%1:0" ).arg( r ).latin1(), 1 ); | 260 | ::setenv( "QWS_DISPLAY", QString( "Transformed:Rot%1:0" ).arg( r ).latin1(), 1 ); |
256 | qApp->desktop()->qwsDisplay()->setTransformation( e ); | 261 | qApp->desktop()->qwsDisplay()->setTransformation( e ); |
257 | #else | 262 | #else |
258 | setDefaultRotation( r ); | 263 | setDefaultRotation( r ); |
259 | #endif | 264 | #endif |
260 | } | 265 | } |
261 | 266 | ||
262 | 267 | ||
263 | #endif | 268 | #endif |