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/qpeapplication.h | |
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 | |||
@@ -190,52 +190,57 @@ 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 | } |