| Absolute File Name: | /home/qt/qt5_coco/qt5/qtbase/src/gui/kernel/qplatformscreen.cpp |
| Source code | Switch to Preprocessed file |
| Line | Source | Count | ||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1 | /**************************************************************************** | - | ||||||||||||||||||
| 2 | ** | - | ||||||||||||||||||
| 3 | ** Copyright (C) 2016 The Qt Company Ltd. | - | ||||||||||||||||||
| 4 | ** Contact: https://www.qt.io/licensing/ | - | ||||||||||||||||||
| 5 | ** | - | ||||||||||||||||||
| 6 | ** This file is part of the QtGui module of the Qt Toolkit. | - | ||||||||||||||||||
| 7 | ** | - | ||||||||||||||||||
| 8 | ** $QT_BEGIN_LICENSE:LGPL$ | - | ||||||||||||||||||
| 9 | ** Commercial License Usage | - | ||||||||||||||||||
| 10 | ** Licensees holding valid commercial Qt licenses may use this file in | - | ||||||||||||||||||
| 11 | ** accordance with the commercial license agreement provided with the | - | ||||||||||||||||||
| 12 | ** Software or, alternatively, in accordance with the terms contained in | - | ||||||||||||||||||
| 13 | ** a written agreement between you and The Qt Company. For licensing terms | - | ||||||||||||||||||
| 14 | ** and conditions see https://www.qt.io/terms-conditions. For further | - | ||||||||||||||||||
| 15 | ** information use the contact form at https://www.qt.io/contact-us. | - | ||||||||||||||||||
| 16 | ** | - | ||||||||||||||||||
| 17 | ** GNU Lesser General Public License Usage | - | ||||||||||||||||||
| 18 | ** Alternatively, this file may be used under the terms of the GNU Lesser | - | ||||||||||||||||||
| 19 | ** General Public License version 3 as published by the Free Software | - | ||||||||||||||||||
| 20 | ** Foundation and appearing in the file LICENSE.LGPL3 included in the | - | ||||||||||||||||||
| 21 | ** packaging of this file. Please review the following information to | - | ||||||||||||||||||
| 22 | ** ensure the GNU Lesser General Public License version 3 requirements | - | ||||||||||||||||||
| 23 | ** will be met: https://www.gnu.org/licenses/lgpl-3.0.html. | - | ||||||||||||||||||
| 24 | ** | - | ||||||||||||||||||
| 25 | ** GNU General Public License Usage | - | ||||||||||||||||||
| 26 | ** Alternatively, this file may be used under the terms of the GNU | - | ||||||||||||||||||
| 27 | ** General Public License version 2.0 or (at your option) the GNU General | - | ||||||||||||||||||
| 28 | ** Public license version 3 or any later version approved by the KDE Free | - | ||||||||||||||||||
| 29 | ** Qt Foundation. The licenses are as published by the Free Software | - | ||||||||||||||||||
| 30 | ** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3 | - | ||||||||||||||||||
| 31 | ** included in the packaging of this file. Please review the following | - | ||||||||||||||||||
| 32 | ** information to ensure the GNU General Public License requirements will | - | ||||||||||||||||||
| 33 | ** be met: https://www.gnu.org/licenses/gpl-2.0.html and | - | ||||||||||||||||||
| 34 | ** https://www.gnu.org/licenses/gpl-3.0.html. | - | ||||||||||||||||||
| 35 | ** | - | ||||||||||||||||||
| 36 | ** $QT_END_LICENSE$ | - | ||||||||||||||||||
| 37 | ** | - | ||||||||||||||||||
| 38 | ****************************************************************************/ | - | ||||||||||||||||||
| 39 | - | |||||||||||||||||||
| 40 | #include "qplatformscreen.h" | - | ||||||||||||||||||
| 41 | #include <QtCore/qdebug.h> | - | ||||||||||||||||||
| 42 | #include <QtGui/qguiapplication.h> | - | ||||||||||||||||||
| 43 | #include <qpa/qplatformcursor.h> | - | ||||||||||||||||||
| 44 | #include <QtGui/private/qguiapplication_p.h> | - | ||||||||||||||||||
| 45 | #include <qpa/qplatformscreen_p.h> | - | ||||||||||||||||||
| 46 | #include <qpa/qplatformintegration.h> | - | ||||||||||||||||||
| 47 | #include <QtGui/qscreen.h> | - | ||||||||||||||||||
| 48 | #include <QtGui/qwindow.h> | - | ||||||||||||||||||
| 49 | #include <private/qhighdpiscaling_p.h> | - | ||||||||||||||||||
| 50 | - | |||||||||||||||||||
| 51 | QT_BEGIN_NAMESPACE | - | ||||||||||||||||||
| 52 | - | |||||||||||||||||||
| 53 | QPlatformScreen::QPlatformScreen() | - | ||||||||||||||||||
| 54 | : d_ptr(new QPlatformScreenPrivate) | - | ||||||||||||||||||
| 55 | { | - | ||||||||||||||||||
| 56 | Q_D(QPlatformScreen); | - | ||||||||||||||||||
| 57 | d->screen = 0; | - | ||||||||||||||||||
| 58 | } never executed: end of block | 0 | ||||||||||||||||||
| 59 | - | |||||||||||||||||||
| 60 | QPlatformScreen::~QPlatformScreen() | - | ||||||||||||||||||
| 61 | { | - | ||||||||||||||||||
| 62 | Q_D(QPlatformScreen); | - | ||||||||||||||||||
| 63 | if (d->screen) {
| 0 | ||||||||||||||||||
| 64 | qWarning("Manually deleting a QPlatformScreen. Call QPlatformIntegration::destroyScreen instead."); | - | ||||||||||||||||||
| 65 | QGuiApplicationPrivate::platformIntegration()->removeScreen(d->screen); | - | ||||||||||||||||||
| 66 | delete d->screen; | - | ||||||||||||||||||
| 67 | } never executed: end of block | 0 | ||||||||||||||||||
| 68 | } never executed: end of block | 0 | ||||||||||||||||||
| 69 | - | |||||||||||||||||||
| 70 | /*! | - | ||||||||||||||||||
| 71 | \fn QPixmap QPlatformScreen::grabWindow(WId window, int x, int y, int width, int height) const | - | ||||||||||||||||||
| 72 | - | |||||||||||||||||||
| 73 | This function is called when Qt needs to be able to grab the content of a window. | - | ||||||||||||||||||
| 74 | - | |||||||||||||||||||
| 75 | Returnes the content of the window specified with the WId handle within the boundaries of | - | ||||||||||||||||||
| 76 | QRect(x,y,width,height). | - | ||||||||||||||||||
| 77 | */ | - | ||||||||||||||||||
| 78 | QPixmap QPlatformScreen::grabWindow(WId window, int x, int y, int width, int height) const | - | ||||||||||||||||||
| 79 | { | - | ||||||||||||||||||
| 80 | Q_UNUSED(window); | - | ||||||||||||||||||
| 81 | Q_UNUSED(x); | - | ||||||||||||||||||
| 82 | Q_UNUSED(y); | - | ||||||||||||||||||
| 83 | Q_UNUSED(width); | - | ||||||||||||||||||
| 84 | Q_UNUSED(height); | - | ||||||||||||||||||
| 85 | return QPixmap(); never executed: return QPixmap(); | 0 | ||||||||||||||||||
| 86 | } | - | ||||||||||||||||||
| 87 | - | |||||||||||||||||||
| 88 | /*! | - | ||||||||||||||||||
| 89 | Return the given top level window for a given position. | - | ||||||||||||||||||
| 90 | - | |||||||||||||||||||
| 91 | Default implementation retrieves a list of all top level windows and finds the first window | - | ||||||||||||||||||
| 92 | which contains point \a pos | - | ||||||||||||||||||
| 93 | */ | - | ||||||||||||||||||
| 94 | QWindow *QPlatformScreen::topLevelAt(const QPoint & pos) const | - | ||||||||||||||||||
| 95 | { | - | ||||||||||||||||||
| 96 | const QWindowList list = QGuiApplication::topLevelWindows(); | - | ||||||||||||||||||
| 97 | for (int i = list.size()-1; i >= 0; --i) {
| 0 | ||||||||||||||||||
| 98 | QWindow *w = list[i]; | - | ||||||||||||||||||
| 99 | if (w->isVisible() && QHighDpi::toNativePixels(w->geometry(), w).contains(pos))
| 0 | ||||||||||||||||||
| 100 | return w; never executed: return w; | 0 | ||||||||||||||||||
| 101 | } never executed: end of block | 0 | ||||||||||||||||||
| 102 | - | |||||||||||||||||||
| 103 | return 0; never executed: return 0; | 0 | ||||||||||||||||||
| 104 | } | - | ||||||||||||||||||
| 105 | - | |||||||||||||||||||
| 106 | /*! | - | ||||||||||||||||||
| 107 | Find the sibling screen corresponding to \a globalPos. | - | ||||||||||||||||||
| 108 | - | |||||||||||||||||||
| 109 | Returns this screen if no suitable screen is found at the position. | - | ||||||||||||||||||
| 110 | */ | - | ||||||||||||||||||
| 111 | const QPlatformScreen *QPlatformScreen::screenForPosition(const QPoint &point) const | - | ||||||||||||||||||
| 112 | { | - | ||||||||||||||||||
| 113 | if (!geometry().contains(point)) {
| 0 | ||||||||||||||||||
| 114 | const auto screens = virtualSiblings(); | - | ||||||||||||||||||
| 115 | for (const QPlatformScreen *screen : screens) { | - | ||||||||||||||||||
| 116 | if (screen->geometry().contains(point))
| 0 | ||||||||||||||||||
| 117 | return screen; never executed: return screen; | 0 | ||||||||||||||||||
| 118 | } never executed: end of block | 0 | ||||||||||||||||||
| 119 | } never executed: end of block | 0 | ||||||||||||||||||
| 120 | return this; never executed: return this; | 0 | ||||||||||||||||||
| 121 | } | - | ||||||||||||||||||
| 122 | - | |||||||||||||||||||
| 123 | - | |||||||||||||||||||
| 124 | /*! | - | ||||||||||||||||||
| 125 | Returns a list of all the platform screens that are part of the same | - | ||||||||||||||||||
| 126 | virtual desktop. | - | ||||||||||||||||||
| 127 | - | |||||||||||||||||||
| 128 | Screens part of the same virtual desktop share a common coordinate system, | - | ||||||||||||||||||
| 129 | and windows can be freely moved between them. | - | ||||||||||||||||||
| 130 | */ | - | ||||||||||||||||||
| 131 | QList<QPlatformScreen *> QPlatformScreen::virtualSiblings() const | - | ||||||||||||||||||
| 132 | { | - | ||||||||||||||||||
| 133 | QList<QPlatformScreen *> list; | - | ||||||||||||||||||
| 134 | list << const_cast<QPlatformScreen *>(this); | - | ||||||||||||||||||
| 135 | return list; never executed: return list; | 0 | ||||||||||||||||||
| 136 | } | - | ||||||||||||||||||
| 137 | - | |||||||||||||||||||
| 138 | QScreen *QPlatformScreen::screen() const | - | ||||||||||||||||||
| 139 | { | - | ||||||||||||||||||
| 140 | Q_D(const QPlatformScreen); | - | ||||||||||||||||||
| 141 | return d->screen; never executed: return d->screen; | 0 | ||||||||||||||||||
| 142 | } | - | ||||||||||||||||||
| 143 | - | |||||||||||||||||||
| 144 | /*! | - | ||||||||||||||||||
| 145 | Reimplement this function in subclass to return the physical size of the | - | ||||||||||||||||||
| 146 | screen, in millimeters. The physical size represents the actual physical | - | ||||||||||||||||||
| 147 | dimensions of the display. | - | ||||||||||||||||||
| 148 | - | |||||||||||||||||||
| 149 | The default implementation takes the pixel size of the screen, considers a | - | ||||||||||||||||||
| 150 | resolution of 100 dots per inch, and returns the calculated physical size. | - | ||||||||||||||||||
| 151 | A device with a screen that has different resolutions will need to be | - | ||||||||||||||||||
| 152 | supported by a suitable reimplementation of this function. | - | ||||||||||||||||||
| 153 | - | |||||||||||||||||||
| 154 | \sa logcalDpi | - | ||||||||||||||||||
| 155 | */ | - | ||||||||||||||||||
| 156 | QSizeF QPlatformScreen::physicalSize() const | - | ||||||||||||||||||
| 157 | { | - | ||||||||||||||||||
| 158 | static const int dpi = 100; | - | ||||||||||||||||||
| 159 | return QSizeF(geometry().size()) / dpi * qreal(25.4); never executed: return QSizeF(geometry().size()) / dpi * qreal(25.4); | 0 | ||||||||||||||||||
| 160 | } | - | ||||||||||||||||||
| 161 | - | |||||||||||||||||||
| 162 | /*! | - | ||||||||||||||||||
| 163 | Reimplement this function in subclass to return the logical horizontal | - | ||||||||||||||||||
| 164 | and vertical dots per inch metrics of the screen. | - | ||||||||||||||||||
| 165 | - | |||||||||||||||||||
| 166 | The logical dots per inch metrics are used by QFont to convert point sizes | - | ||||||||||||||||||
| 167 | to pixel sizes. | - | ||||||||||||||||||
| 168 | - | |||||||||||||||||||
| 169 | The default implementation uses the screen pixel size and physical size to | - | ||||||||||||||||||
| 170 | compute the metrics. | - | ||||||||||||||||||
| 171 | - | |||||||||||||||||||
| 172 | \sa physicalSize | - | ||||||||||||||||||
| 173 | */ | - | ||||||||||||||||||
| 174 | QDpi QPlatformScreen::logicalDpi() const | - | ||||||||||||||||||
| 175 | { | - | ||||||||||||||||||
| 176 | QSizeF ps = physicalSize(); | - | ||||||||||||||||||
| 177 | QSize s = geometry().size(); | - | ||||||||||||||||||
| 178 | - | |||||||||||||||||||
| 179 | return QDpi(25.4 * s.width() / ps.width(), never executed: return QDpi(25.4 * s.width() / ps.width(), 25.4 * s.height() / ps.height()); | 0 | ||||||||||||||||||
| 180 | 25.4 * s.height() / ps.height()); never executed: return QDpi(25.4 * s.width() / ps.width(), 25.4 * s.height() / ps.height()); | 0 | ||||||||||||||||||
| 181 | } | - | ||||||||||||||||||
| 182 | - | |||||||||||||||||||
| 183 | /*! | - | ||||||||||||||||||
| 184 | Reimplement this function in subclass to return the device pixel ratio | - | ||||||||||||||||||
| 185 | for the screen. This is the ratio between physical pixels and the | - | ||||||||||||||||||
| 186 | device-independent pixels of the windowing system. The default | - | ||||||||||||||||||
| 187 | implementation returns 1.0. | - | ||||||||||||||||||
| 188 | - | |||||||||||||||||||
| 189 | \sa QPlatformWindow::devicePixelRatio() | - | ||||||||||||||||||
| 190 | \sa QPlatformScreen::pixelDensity() | - | ||||||||||||||||||
| 191 | */ | - | ||||||||||||||||||
| 192 | qreal QPlatformScreen::devicePixelRatio() const | - | ||||||||||||||||||
| 193 | { | - | ||||||||||||||||||
| 194 | return 1.0; never executed: return 1.0; | 0 | ||||||||||||||||||
| 195 | } | - | ||||||||||||||||||
| 196 | - | |||||||||||||||||||
| 197 | /*! | - | ||||||||||||||||||
| 198 | Reimplement this function in subclass to return the pixel density of the | - | ||||||||||||||||||
| 199 | screen. This is the scale factor needed to make a low-dpi application | - | ||||||||||||||||||
| 200 | usable on this screen. The default implementation returns 1.0. | - | ||||||||||||||||||
| 201 | - | |||||||||||||||||||
| 202 | Returning something else than 1.0 from this function causes Qt to | - | ||||||||||||||||||
| 203 | apply the scale factor to the application's coordinate system. | - | ||||||||||||||||||
| 204 | This is different from devicePixelRatio, which reports a scale | - | ||||||||||||||||||
| 205 | factor already applied by the windowing system. A platform plugin | - | ||||||||||||||||||
| 206 | typically implements one (or none) of these two functions. | - | ||||||||||||||||||
| 207 | - | |||||||||||||||||||
| 208 | \sa QPlatformWindow::devicePixelRatio() | - | ||||||||||||||||||
| 209 | */ | - | ||||||||||||||||||
| 210 | qreal QPlatformScreen::pixelDensity() const | - | ||||||||||||||||||
| 211 | { | - | ||||||||||||||||||
| 212 | return 1.0; never executed: return 1.0; | 0 | ||||||||||||||||||
| 213 | } | - | ||||||||||||||||||
| 214 | - | |||||||||||||||||||
| 215 | /*! | - | ||||||||||||||||||
| 216 | Reimplement this function in subclass to return the vertical refresh rate | - | ||||||||||||||||||
| 217 | of the screen, in Hz. | - | ||||||||||||||||||
| 218 | - | |||||||||||||||||||
| 219 | The default returns 60, a sensible default for modern displays. | - | ||||||||||||||||||
| 220 | */ | - | ||||||||||||||||||
| 221 | qreal QPlatformScreen::refreshRate() const | - | ||||||||||||||||||
| 222 | { | - | ||||||||||||||||||
| 223 | return 60; never executed: return 60; | 0 | ||||||||||||||||||
| 224 | } | - | ||||||||||||||||||
| 225 | - | |||||||||||||||||||
| 226 | /*! | - | ||||||||||||||||||
| 227 | Reimplement this function in subclass to return the native orientation | - | ||||||||||||||||||
| 228 | of the screen, e.g. the orientation where the logo sticker of the device | - | ||||||||||||||||||
| 229 | appears the right way up. | - | ||||||||||||||||||
| 230 | - | |||||||||||||||||||
| 231 | The default implementation returns Qt::PrimaryOrientation. | - | ||||||||||||||||||
| 232 | */ | - | ||||||||||||||||||
| 233 | Qt::ScreenOrientation QPlatformScreen::nativeOrientation() const | - | ||||||||||||||||||
| 234 | { | - | ||||||||||||||||||
| 235 | return Qt::PrimaryOrientation; never executed: return Qt::PrimaryOrientation; | 0 | ||||||||||||||||||
| 236 | } | - | ||||||||||||||||||
| 237 | - | |||||||||||||||||||
| 238 | /*! | - | ||||||||||||||||||
| 239 | Reimplement this function in subclass to return the current orientation | - | ||||||||||||||||||
| 240 | of the screen, for example based on accelerometer data to determine | - | ||||||||||||||||||
| 241 | the device orientation. | - | ||||||||||||||||||
| 242 | - | |||||||||||||||||||
| 243 | The default implementation returns Qt::PrimaryOrientation. | - | ||||||||||||||||||
| 244 | */ | - | ||||||||||||||||||
| 245 | Qt::ScreenOrientation QPlatformScreen::orientation() const | - | ||||||||||||||||||
| 246 | { | - | ||||||||||||||||||
| 247 | return Qt::PrimaryOrientation; never executed: return Qt::PrimaryOrientation; | 0 | ||||||||||||||||||
| 248 | } | - | ||||||||||||||||||
| 249 | - | |||||||||||||||||||
| 250 | /* | - | ||||||||||||||||||
| 251 | Reimplement this function in subclass to filter out unneeded screen | - | ||||||||||||||||||
| 252 | orientation updates. | - | ||||||||||||||||||
| 253 | - | |||||||||||||||||||
| 254 | The orientations will anyway be filtered before QScreen::orientationChanged() | - | ||||||||||||||||||
| 255 | is emitted, but the mask can be used by the platform plugin for example to | - | ||||||||||||||||||
| 256 | prevent having to have an accelerometer sensor running all the time, or to | - | ||||||||||||||||||
| 257 | improve the reported values. As an example of the latter, in case of only | - | ||||||||||||||||||
| 258 | Landscape | InvertedLandscape being set in the mask, on a platform that gets | - | ||||||||||||||||||
| 259 | its orientation readings from an accelerometer sensor embedded in a handheld | - | ||||||||||||||||||
| 260 | device, the platform can report transitions between the two even when the | - | ||||||||||||||||||
| 261 | device is held in an orientation that's closer to portrait. | - | ||||||||||||||||||
| 262 | - | |||||||||||||||||||
| 263 | By default, the orientation update mask is empty, so unless this function | - | ||||||||||||||||||
| 264 | has been called with a non-empty mask the platform does not need to report | - | ||||||||||||||||||
| 265 | any orientation updates through | - | ||||||||||||||||||
| 266 | QWindowSystemInterface::handleScreenOrientationChange(). | - | ||||||||||||||||||
| 267 | */ | - | ||||||||||||||||||
| 268 | void QPlatformScreen::setOrientationUpdateMask(Qt::ScreenOrientations mask) | - | ||||||||||||||||||
| 269 | { | - | ||||||||||||||||||
| 270 | Q_UNUSED(mask); | - | ||||||||||||||||||
| 271 | } never executed: end of block | 0 | ||||||||||||||||||
| 272 | - | |||||||||||||||||||
| 273 | QPlatformScreen * QPlatformScreen::platformScreenForWindow(const QWindow *window) | - | ||||||||||||||||||
| 274 | { | - | ||||||||||||||||||
| 275 | // QTBUG 32681: It can happen during the transition between screens | - | ||||||||||||||||||
| 276 | // when one screen is disconnected that the window doesn't have a screen. | - | ||||||||||||||||||
| 277 | if (!window->screen())
| 0 | ||||||||||||||||||
| 278 | return 0; never executed: return 0; | 0 | ||||||||||||||||||
| 279 | return window->screen()->handle(); never executed: return window->screen()->handle(); | 0 | ||||||||||||||||||
| 280 | } | - | ||||||||||||||||||
| 281 | - | |||||||||||||||||||
| 282 | /*! | - | ||||||||||||||||||
| 283 | \class QPlatformScreen | - | ||||||||||||||||||
| 284 | \since 4.8 | - | ||||||||||||||||||
| 285 | \internal | - | ||||||||||||||||||
| 286 | \preliminary | - | ||||||||||||||||||
| 287 | \ingroup qpa | - | ||||||||||||||||||
| 288 | - | |||||||||||||||||||
| 289 | \brief The QPlatformScreen class provides an abstraction for visual displays. | - | ||||||||||||||||||
| 290 | - | |||||||||||||||||||
| 291 | Many window systems has support for retrieving information on the attached displays. To be able | - | ||||||||||||||||||
| 292 | to query the display QPA uses QPlatformScreen. Qt its self is most dependent on the | - | ||||||||||||||||||
| 293 | physicalSize() function, since this is the function it uses to calculate the dpi to use when | - | ||||||||||||||||||
| 294 | converting point sizes to pixels sizes. However, this is unfortunate on some systems, as the | - | ||||||||||||||||||
| 295 | native system fakes its dpi size. | - | ||||||||||||||||||
| 296 | - | |||||||||||||||||||
| 297 | QPlatformScreen is also used by the public api QDesktopWidget for information about the desktop. | - | ||||||||||||||||||
| 298 | */ | - | ||||||||||||||||||
| 299 | - | |||||||||||||||||||
| 300 | /*! \fn QRect QPlatformScreen::geometry() const = 0 | - | ||||||||||||||||||
| 301 | Reimplement in subclass to return the pixel geometry of the screen | - | ||||||||||||||||||
| 302 | */ | - | ||||||||||||||||||
| 303 | - | |||||||||||||||||||
| 304 | /*! \fn QRect QPlatformScreen::availableGeometry() const | - | ||||||||||||||||||
| 305 | Reimplement in subclass to return the pixel geometry of the available space | - | ||||||||||||||||||
| 306 | This normally is the desktop screen minus the task manager, global menubar etc. | - | ||||||||||||||||||
| 307 | */ | - | ||||||||||||||||||
| 308 | - | |||||||||||||||||||
| 309 | /*! \fn int QPlatformScreen::depth() const = 0 | - | ||||||||||||||||||
| 310 | Reimplement in subclass to return current depth of the screen | - | ||||||||||||||||||
| 311 | */ | - | ||||||||||||||||||
| 312 | - | |||||||||||||||||||
| 313 | /*! \fn QImage::Format QPlatformScreen::format() const = 0 | - | ||||||||||||||||||
| 314 | Reimplement in subclass to return the image format which corresponds to the screen format | - | ||||||||||||||||||
| 315 | */ | - | ||||||||||||||||||
| 316 | - | |||||||||||||||||||
| 317 | /*! | - | ||||||||||||||||||
| 318 | Reimplement this function in subclass to return the cursor of the screen. | - | ||||||||||||||||||
| 319 | - | |||||||||||||||||||
| 320 | The default implementation returns 0. | - | ||||||||||||||||||
| 321 | */ | - | ||||||||||||||||||
| 322 | QPlatformCursor *QPlatformScreen::cursor() const | - | ||||||||||||||||||
| 323 | { | - | ||||||||||||||||||
| 324 | return 0; never executed: return 0; | 0 | ||||||||||||||||||
| 325 | } | - | ||||||||||||||||||
| 326 | - | |||||||||||||||||||
| 327 | /*! | - | ||||||||||||||||||
| 328 | Convenience method to resize all the maximized and fullscreen windows | - | ||||||||||||||||||
| 329 | of this platform screen. | - | ||||||||||||||||||
| 330 | */ | - | ||||||||||||||||||
| 331 | void QPlatformScreen::resizeMaximizedWindows() | - | ||||||||||||||||||
| 332 | { | - | ||||||||||||||||||
| 333 | QList<QWindow*> windows = QGuiApplication::allWindows(); | - | ||||||||||||||||||
| 334 | - | |||||||||||||||||||
| 335 | // 'screen()' still has the old geometry info while 'this' has the new geometry info | - | ||||||||||||||||||
| 336 | const QRect oldGeometry = screen()->geometry(); | - | ||||||||||||||||||
| 337 | const QRect oldAvailableGeometry = screen()->availableGeometry(); | - | ||||||||||||||||||
| 338 | const QRect newGeometry = deviceIndependentGeometry(); | - | ||||||||||||||||||
| 339 | const QRect newAvailableGeometry = QHighDpi::fromNative(availableGeometry(), QHighDpiScaling::factor(this), newGeometry.topLeft()); | - | ||||||||||||||||||
| 340 | - | |||||||||||||||||||
| 341 | // make sure maximized and fullscreen windows are updated | - | ||||||||||||||||||
| 342 | for (int i = 0; i < windows.size(); ++i) {
| 0 | ||||||||||||||||||
| 343 | QWindow *w = windows.at(i); | - | ||||||||||||||||||
| 344 | - | |||||||||||||||||||
| 345 | // Skip non-platform windows, e.g., offscreen windows. | - | ||||||||||||||||||
| 346 | if (!w->handle())
| 0 | ||||||||||||||||||
| 347 | continue; never executed: continue; | 0 | ||||||||||||||||||
| 348 | - | |||||||||||||||||||
| 349 | if (platformScreenForWindow(w) != this)
| 0 | ||||||||||||||||||
| 350 | continue; never executed: continue; | 0 | ||||||||||||||||||
| 351 | - | |||||||||||||||||||
| 352 | if (w->windowState() & Qt::WindowMaximized || w->geometry() == oldAvailableGeometry)
| 0 | ||||||||||||||||||
| 353 | w->setGeometry(newAvailableGeometry); never executed: w->setGeometry(newAvailableGeometry); | 0 | ||||||||||||||||||
| 354 | else if (w->windowState() & Qt::WindowFullScreen || w->geometry() == oldGeometry)
| 0 | ||||||||||||||||||
| 355 | w->setGeometry(newGeometry); never executed: w->setGeometry(newGeometry); | 0 | ||||||||||||||||||
| 356 | } never executed: end of block | 0 | ||||||||||||||||||
| 357 | } never executed: end of block | 0 | ||||||||||||||||||
| 358 | - | |||||||||||||||||||
| 359 | // i must be power of two | - | ||||||||||||||||||
| 360 | static int log2(uint i) | - | ||||||||||||||||||
| 361 | { | - | ||||||||||||||||||
| 362 | if (i == 0)
| 0 | ||||||||||||||||||
| 363 | return -1; never executed: return -1; | 0 | ||||||||||||||||||
| 364 | - | |||||||||||||||||||
| 365 | int result = 0; | - | ||||||||||||||||||
| 366 | while (!(i & 1)) {
| 0 | ||||||||||||||||||
| 367 | ++result; | - | ||||||||||||||||||
| 368 | i >>= 1; | - | ||||||||||||||||||
| 369 | } never executed: end of block | 0 | ||||||||||||||||||
| 370 | return result; never executed: return result; | 0 | ||||||||||||||||||
| 371 | } | - | ||||||||||||||||||
| 372 | - | |||||||||||||||||||
| 373 | int QPlatformScreen::angleBetween(Qt::ScreenOrientation a, Qt::ScreenOrientation b) | - | ||||||||||||||||||
| 374 | { | - | ||||||||||||||||||
| 375 | if (a == Qt::PrimaryOrientation || b == Qt::PrimaryOrientation) {
| 0 | ||||||||||||||||||
| 376 | qWarning("Use QScreen version of %sBetween() when passing Qt::PrimaryOrientation", "angle"); | - | ||||||||||||||||||
| 377 | return 0; never executed: return 0; | 0 | ||||||||||||||||||
| 378 | } | - | ||||||||||||||||||
| 379 | - | |||||||||||||||||||
| 380 | if (a == b)
| 0 | ||||||||||||||||||
| 381 | return 0; never executed: return 0; | 0 | ||||||||||||||||||
| 382 | - | |||||||||||||||||||
| 383 | int ia = log2(uint(a)); | - | ||||||||||||||||||
| 384 | int ib = log2(uint(b)); | - | ||||||||||||||||||
| 385 | - | |||||||||||||||||||
| 386 | int delta = ia - ib; | - | ||||||||||||||||||
| 387 | - | |||||||||||||||||||
| 388 | if (delta < 0)
| 0 | ||||||||||||||||||
| 389 | delta = delta + 4; never executed: delta = delta + 4; | 0 | ||||||||||||||||||
| 390 | - | |||||||||||||||||||
| 391 | int angles[] = { 0, 90, 180, 270 }; | - | ||||||||||||||||||
| 392 | return angles[delta]; never executed: return angles[delta]; | 0 | ||||||||||||||||||
| 393 | } | - | ||||||||||||||||||
| 394 | - | |||||||||||||||||||
| 395 | QTransform QPlatformScreen::transformBetween(Qt::ScreenOrientation a, Qt::ScreenOrientation b, const QRect &target) | - | ||||||||||||||||||
| 396 | { | - | ||||||||||||||||||
| 397 | if (a == Qt::PrimaryOrientation || b == Qt::PrimaryOrientation) {
| 0 | ||||||||||||||||||
| 398 | qWarning("Use QScreen version of %sBetween() when passing Qt::PrimaryOrientation", "transform"); | - | ||||||||||||||||||
| 399 | return QTransform(); never executed: return QTransform(); | 0 | ||||||||||||||||||
| 400 | } | - | ||||||||||||||||||
| 401 | - | |||||||||||||||||||
| 402 | if (a == b)
| 0 | ||||||||||||||||||
| 403 | return QTransform(); never executed: return QTransform(); | 0 | ||||||||||||||||||
| 404 | - | |||||||||||||||||||
| 405 | int angle = angleBetween(a, b); | - | ||||||||||||||||||
| 406 | - | |||||||||||||||||||
| 407 | QTransform result; | - | ||||||||||||||||||
| 408 | switch (angle) { | - | ||||||||||||||||||
| 409 | case 90: never executed: case 90: | 0 | ||||||||||||||||||
| 410 | result.translate(target.width(), 0); | - | ||||||||||||||||||
| 411 | break; never executed: break; | 0 | ||||||||||||||||||
| 412 | case 180: never executed: case 180: | 0 | ||||||||||||||||||
| 413 | result.translate(target.width(), target.height()); | - | ||||||||||||||||||
| 414 | break; never executed: break; | 0 | ||||||||||||||||||
| 415 | case 270: never executed: case 270: | 0 | ||||||||||||||||||
| 416 | result.translate(0, target.height()); | - | ||||||||||||||||||
| 417 | break; never executed: break; | 0 | ||||||||||||||||||
| 418 | default: never executed: default: | 0 | ||||||||||||||||||
| 419 | Q_ASSERT(false); | - | ||||||||||||||||||
| 420 | } never executed: end of block | 0 | ||||||||||||||||||
| 421 | result.rotate(angle); | - | ||||||||||||||||||
| 422 | - | |||||||||||||||||||
| 423 | return result; never executed: return result; | 0 | ||||||||||||||||||
| 424 | } | - | ||||||||||||||||||
| 425 | - | |||||||||||||||||||
| 426 | QRect QPlatformScreen::mapBetween(Qt::ScreenOrientation a, Qt::ScreenOrientation b, const QRect &rect) | - | ||||||||||||||||||
| 427 | { | - | ||||||||||||||||||
| 428 | if (a == Qt::PrimaryOrientation || b == Qt::PrimaryOrientation) {
| 0 | ||||||||||||||||||
| 429 | qWarning("Use QScreen version of %sBetween() when passing Qt::PrimaryOrientation", "map"); | - | ||||||||||||||||||
| 430 | return rect; never executed: return rect; | 0 | ||||||||||||||||||
| 431 | } | - | ||||||||||||||||||
| 432 | - | |||||||||||||||||||
| 433 | if (a == b)
| 0 | ||||||||||||||||||
| 434 | return rect; never executed: return rect; | 0 | ||||||||||||||||||
| 435 | - | |||||||||||||||||||
| 436 | if ((a == Qt::PortraitOrientation || a == Qt::InvertedPortraitOrientation)
| 0 | ||||||||||||||||||
| 437 | != (b == Qt::PortraitOrientation || b == Qt::InvertedPortraitOrientation))
| 0 | ||||||||||||||||||
| 438 | { | - | ||||||||||||||||||
| 439 | return QRect(rect.y(), rect.x(), rect.height(), rect.width()); never executed: return QRect(rect.y(), rect.x(), rect.height(), rect.width()); | 0 | ||||||||||||||||||
| 440 | } | - | ||||||||||||||||||
| 441 | - | |||||||||||||||||||
| 442 | return rect; never executed: return rect; | 0 | ||||||||||||||||||
| 443 | } | - | ||||||||||||||||||
| 444 | - | |||||||||||||||||||
| 445 | QRect QPlatformScreen::deviceIndependentGeometry() const | - | ||||||||||||||||||
| 446 | { | - | ||||||||||||||||||
| 447 | qreal scaleFactor = QHighDpiScaling::factor(this); | - | ||||||||||||||||||
| 448 | QRect nativeGeometry = geometry(); | - | ||||||||||||||||||
| 449 | return QRect(nativeGeometry.topLeft(), QHighDpi::fromNative(nativeGeometry.size(), scaleFactor)); never executed: return QRect(nativeGeometry.topLeft(), QHighDpi::fromNative(nativeGeometry.size(), scaleFactor)); | 0 | ||||||||||||||||||
| 450 | } | - | ||||||||||||||||||
| 451 | - | |||||||||||||||||||
| 452 | /*! | - | ||||||||||||||||||
| 453 | Returns a hint about this screen's subpixel layout structure. | - | ||||||||||||||||||
| 454 | - | |||||||||||||||||||
| 455 | The default implementation queries the \b{QT_SUBPIXEL_AA_TYPE} env variable. | - | ||||||||||||||||||
| 456 | This is just a hint because most platforms don't have a way to retrieve the correct value from hardware | - | ||||||||||||||||||
| 457 | and instead rely on font configurations. | - | ||||||||||||||||||
| 458 | */ | - | ||||||||||||||||||
| 459 | QPlatformScreen::SubpixelAntialiasingType QPlatformScreen::subpixelAntialiasingTypeHint() const | - | ||||||||||||||||||
| 460 | { | - | ||||||||||||||||||
| 461 | static int type = -1; | - | ||||||||||||||||||
| 462 | if (type == -1) {
| 0 | ||||||||||||||||||
| 463 | QByteArray env = qgetenv("QT_SUBPIXEL_AA_TYPE"); | - | ||||||||||||||||||
| 464 | if (env == "RGB")
| 0 | ||||||||||||||||||
| 465 | type = QPlatformScreen::Subpixel_RGB; never executed: type = QPlatformScreen::Subpixel_RGB; | 0 | ||||||||||||||||||
| 466 | else if (env == "BGR")
| 0 | ||||||||||||||||||
| 467 | type = QPlatformScreen::Subpixel_BGR; never executed: type = QPlatformScreen::Subpixel_BGR; | 0 | ||||||||||||||||||
| 468 | else if (env == "VRGB")
| 0 | ||||||||||||||||||
| 469 | type = QPlatformScreen::Subpixel_VRGB; never executed: type = QPlatformScreen::Subpixel_VRGB; | 0 | ||||||||||||||||||
| 470 | else if (env == "VBGR")
| 0 | ||||||||||||||||||
| 471 | type = QPlatformScreen::Subpixel_VBGR; never executed: type = QPlatformScreen::Subpixel_VBGR; | 0 | ||||||||||||||||||
| 472 | else | - | ||||||||||||||||||
| 473 | type = QPlatformScreen::Subpixel_None; never executed: type = QPlatformScreen::Subpixel_None; | 0 | ||||||||||||||||||
| 474 | } | - | ||||||||||||||||||
| 475 | - | |||||||||||||||||||
| 476 | return static_cast<QPlatformScreen::SubpixelAntialiasingType>(type); never executed: return static_cast<QPlatformScreen::SubpixelAntialiasingType>(type); | 0 | ||||||||||||||||||
| 477 | } | - | ||||||||||||||||||
| 478 | - | |||||||||||||||||||
| 479 | /*! | - | ||||||||||||||||||
| 480 | Returns the current power state. | - | ||||||||||||||||||
| 481 | - | |||||||||||||||||||
| 482 | The default implementation always returns PowerStateOn. | - | ||||||||||||||||||
| 483 | */ | - | ||||||||||||||||||
| 484 | QPlatformScreen::PowerState QPlatformScreen::powerState() const | - | ||||||||||||||||||
| 485 | { | - | ||||||||||||||||||
| 486 | return PowerStateOn; never executed: return PowerStateOn; | 0 | ||||||||||||||||||
| 487 | } | - | ||||||||||||||||||
| 488 | - | |||||||||||||||||||
| 489 | /*! | - | ||||||||||||||||||
| 490 | Sets the power state for this screen. | - | ||||||||||||||||||
| 491 | */ | - | ||||||||||||||||||
| 492 | void QPlatformScreen::setPowerState(PowerState state) | - | ||||||||||||||||||
| 493 | { | - | ||||||||||||||||||
| 494 | Q_UNUSED(state); | - | ||||||||||||||||||
| 495 | } never executed: end of block | 0 | ||||||||||||||||||
| 496 | - | |||||||||||||||||||
| 497 | QT_END_NAMESPACE | - | ||||||||||||||||||
| Source code | Switch to Preprocessed file |