| Line | Source Code | Coverage |
|---|
| 1 | /**************************************************************************** | - |
| 2 | ** | - |
| 3 | ** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies). | - |
| 4 | ** Contact: http://www.qt-project.org/legal | - |
| 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 Digia. For licensing terms and | - |
| 14 | ** conditions see http://qt.digia.com/licensing. For further information | - |
| 15 | ** use the contact form at http://qt.digia.com/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 2.1 as published by the Free Software | - |
| 20 | ** Foundation and appearing in the file LICENSE.LGPL included in the | - |
| 21 | ** packaging of this file. Please review the following information to | - |
| 22 | ** ensure the GNU Lesser General Public License version 2.1 requirements | - |
| 23 | ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. | - |
| 24 | ** | - |
| 25 | ** In addition, as a special exception, Digia gives you certain additional | - |
| 26 | ** rights. These rights are described in the Digia Qt LGPL Exception | - |
| 27 | ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. | - |
| 28 | ** | - |
| 29 | ** GNU General Public License Usage | - |
| 30 | ** Alternatively, this file may be used under the terms of the GNU | - |
| 31 | ** General Public License version 3.0 as published by the Free Software | - |
| 32 | ** Foundation and appearing in the file LICENSE.GPL included in the | - |
| 33 | ** packaging of this file. Please review the following information to | - |
| 34 | ** ensure the GNU General Public License version 3.0 requirements will be | - |
| 35 | ** met: http://www.gnu.org/copyleft/gpl.html. | - |
| 36 | ** | - |
| 37 | ** | - |
| 38 | ** $QT_END_LICENSE$ | - |
| 39 | ** | - |
| 40 | ****************************************************************************/ | - |
| 41 | | - |
| 42 | #include <qstylehints.h> | - |
| 43 | #include <qpa/qplatformintegration.h> | - |
| 44 | #include <qpa/qplatformtheme.h> | - |
| 45 | #include <private/qguiapplication_p.h> | - |
| 46 | | - |
| 47 | QT_BEGIN_NAMESPACE | - |
| 48 | | - |
| 49 | static inline QVariant hint(QPlatformIntegration::StyleHint h) | - |
| 50 | { | - |
| 51 | return QGuiApplicationPrivate::platformIntegration()->styleHint(h); executed: return QGuiApplicationPrivate::platformIntegration()->styleHint(h);Execution Count:2869 | 2869 |
| 52 | } | - |
| 53 | | - |
| 54 | static inline QVariant themeableHint(QPlatformTheme::ThemeHint th, | - |
| 55 | QPlatformIntegration::StyleHint ih) | - |
| 56 | { | - |
| 57 | if (const QPlatformTheme *theme = QGuiApplicationPrivate::platformTheme()) { partially evaluated: const QPlatformTheme *theme = QGuiApplicationPrivate::platformTheme()| yes Evaluation Count:5015 | no Evaluation Count:0 |
| 0-5015 |
| 58 | const QVariant themeHint = theme->themeHint(th); executed (the execution status of this line is deduced): const QVariant themeHint = theme->themeHint(th); | - |
| 59 | if (themeHint.isValid()) partially evaluated: themeHint.isValid()| yes Evaluation Count:5015 | no Evaluation Count:0 |
| 0-5015 |
| 60 | return themeHint; executed: return themeHint;Execution Count:5015 | 5015 |
| 61 | } | 0 |
| 62 | return QGuiApplicationPrivate::platformIntegration()->styleHint(ih); never executed: return QGuiApplicationPrivate::platformIntegration()->styleHint(ih); | 0 |
| 63 | } | - |
| 64 | | - |
| 65 | /*! | - |
| 66 | \class QStyleHints | - |
| 67 | \since 5.0 | - |
| 68 | \brief The QStyleHints class contains platform specific hints and settings. | - |
| 69 | \inmodule QtGui | - |
| 70 | | - |
| 71 | An object of this class, obtained from QGuiApplication, provides access to certain global | - |
| 72 | user interface parameters of the current platform. | - |
| 73 | | - |
| 74 | Access is read only; typically the platform itself provides the user a way to tune these | - |
| 75 | parameters. | - |
| 76 | | - |
| 77 | Access to these parameters are useful when implementing custom user interface components, in that | - |
| 78 | they allow the components to exhibit the same behaviour and feel as other components. | - |
| 79 | | - |
| 80 | \sa QGuiApplication::styleHints(), QPlatformTheme | - |
| 81 | */ | - |
| 82 | QStyleHints::QStyleHints() | - |
| 83 | : QObject() | - |
| 84 | { | - |
| 85 | } executed: }Execution Count:117 | 117 |
| 86 | | - |
| 87 | /*! | - |
| 88 | Returns the time limit in milliseconds that distinguishes a double click | - |
| 89 | from two consecutive mouse clicks. | - |
| 90 | */ | - |
| 91 | int QStyleHints::mouseDoubleClickInterval() const | - |
| 92 | { | - |
| 93 | return themeableHint(QPlatformTheme::MouseDoubleClickInterval, QPlatformIntegration::MouseDoubleClickInterval).toInt(); executed: return themeableHint(QPlatformTheme::MouseDoubleClickInterval, QPlatformIntegration::MouseDoubleClickInterval).toInt();Execution Count:785 | 785 |
| 94 | } | - |
| 95 | | - |
| 96 | /*! | - |
| 97 | Returns the distance, in pixels, that the mouse must be moved with a button | - |
| 98 | held down before a drag and drop operation will begin. | - |
| 99 | | - |
| 100 | If you support drag and drop in your application, and want to start a drag | - |
| 101 | and drop operation after the user has moved the cursor a certain distance | - |
| 102 | with a button held down, you should use this property's value as the | - |
| 103 | minimum distance required. | - |
| 104 | | - |
| 105 | For example, if the mouse position of the click is stored in \c startPos | - |
| 106 | and the current position (e.g. in the mouse move event) is \c currentPos, | - |
| 107 | you can find out if a drag should be started with code like this: | - |
| 108 | | - |
| 109 | \snippet code/src_gui_kernel_qapplication.cpp 7 | - |
| 110 | | - |
| 111 | \sa startDragTime(), QPoint::manhattanLength(), {Drag and Drop} | - |
| 112 | */ | - |
| 113 | int QStyleHints::startDragDistance() const | - |
| 114 | { | - |
| 115 | return themeableHint(QPlatformTheme::StartDragDistance, QPlatformIntegration::StartDragDistance).toInt(); executed: return themeableHint(QPlatformTheme::StartDragDistance, QPlatformIntegration::StartDragDistance).toInt();Execution Count:9 | 9 |
| 116 | } | - |
| 117 | | - |
| 118 | /*! | - |
| 119 | Returns the time, in milliseconds, that a mouse button must be held down | - |
| 120 | before a drag and drop operation will begin. | - |
| 121 | | - |
| 122 | If you support drag and drop in your application, and want to start a drag | - |
| 123 | and drop operation after the user has held down a mouse button for a | - |
| 124 | certain amount of time, you should use this property's value as the delay. | - |
| 125 | | - |
| 126 | \sa startDragDistance(), {Drag and Drop} | - |
| 127 | */ | - |
| 128 | int QStyleHints::startDragTime() const | - |
| 129 | { | - |
| 130 | return themeableHint(QPlatformTheme::StartDragTime, QPlatformIntegration::StartDragTime).toInt(); never executed: return themeableHint(QPlatformTheme::StartDragTime, QPlatformIntegration::StartDragTime).toInt(); | 0 |
| 131 | } | - |
| 132 | | - |
| 133 | /*! | - |
| 134 | Returns the limit for the velocity, in pixels per second, that the mouse may | - |
| 135 | be moved, with a button held down, for a drag and drop operation to begin. | - |
| 136 | A value of 0 means there is no such limit. | - |
| 137 | | - |
| 138 | \sa startDragDistance(), {Drag and Drop} | - |
| 139 | */ | - |
| 140 | int QStyleHints::startDragVelocity() const | - |
| 141 | { | - |
| 142 | return themeableHint(QPlatformTheme::StartDragVelocity, QPlatformIntegration::StartDragVelocity).toInt(); never executed: return themeableHint(QPlatformTheme::StartDragVelocity, QPlatformIntegration::StartDragVelocity).toInt(); | 0 |
| 143 | } | - |
| 144 | | - |
| 145 | /*! | - |
| 146 | Returns the time limit, in milliseconds, that distinguishes a key press | - |
| 147 | from two consecutive key presses. | - |
| 148 | */ | - |
| 149 | int QStyleHints::keyboardInputInterval() const | - |
| 150 | { | - |
| 151 | return themeableHint(QPlatformTheme::KeyboardInputInterval, QPlatformIntegration::KeyboardInputInterval).toInt(); executed: return themeableHint(QPlatformTheme::KeyboardInputInterval, QPlatformIntegration::KeyboardInputInterval).toInt();Execution Count:19 | 19 |
| 152 | } | - |
| 153 | | - |
| 154 | /*! | - |
| 155 | Returns the rate, in events per second, in which additional repeated key | - |
| 156 | presses will automatically be generated if a key is being held down. | - |
| 157 | */ | - |
| 158 | int QStyleHints::keyboardAutoRepeatRate() const | - |
| 159 | { | - |
| 160 | return themeableHint(QPlatformTheme::KeyboardAutoRepeatRate, QPlatformIntegration::KeyboardAutoRepeatRate).toInt(); never executed: return themeableHint(QPlatformTheme::KeyboardAutoRepeatRate, QPlatformIntegration::KeyboardAutoRepeatRate).toInt(); | 0 |
| 161 | } | - |
| 162 | | - |
| 163 | /*! | - |
| 164 | Returns the text cursor's flash (blink) time in milliseconds. | - |
| 165 | | - |
| 166 | The flash time is the time used to display, invert and restore the | - |
| 167 | caret display. Usually the text cursor is displayed for half the cursor | - |
| 168 | flash time, then hidden for the same amount of time. | - |
| 169 | */ | - |
| 170 | int QStyleHints::cursorFlashTime() const | - |
| 171 | { | - |
| 172 | return themeableHint(QPlatformTheme::CursorFlashTime, QPlatformIntegration::CursorFlashTime).toInt(); executed: return themeableHint(QPlatformTheme::CursorFlashTime, QPlatformIntegration::CursorFlashTime).toInt();Execution Count:4198 | 4198 |
| 173 | } | - |
| 174 | | - |
| 175 | /*! | - |
| 176 | Returns \c true if the platform defaults to windows being fullscreen, | - |
| 177 | otherwise \c false. | - |
| 178 | | - |
| 179 | \sa QWindow::show() | - |
| 180 | */ | - |
| 181 | bool QStyleHints::showIsFullScreen() const | - |
| 182 | { | - |
| 183 | return hint(QPlatformIntegration::ShowIsFullScreen).toBool(); executed: return hint(QPlatformIntegration::ShowIsFullScreen).toBool();Execution Count:2867 | 2867 |
| 184 | } | - |
| 185 | | - |
| 186 | /*! | - |
| 187 | Returns the time, in milliseconds, a typed letter is displayed unshrouded | - |
| 188 | in a text input field in password mode. | - |
| 189 | */ | - |
| 190 | int QStyleHints::passwordMaskDelay() const | - |
| 191 | { | - |
| 192 | return themeableHint(QPlatformTheme::PasswordMaskDelay, QPlatformIntegration::PasswordMaskDelay).toInt(); executed: return themeableHint(QPlatformTheme::PasswordMaskDelay, QPlatformIntegration::PasswordMaskDelay).toInt();Execution Count:4 | 4 |
| 193 | } | - |
| 194 | | - |
| 195 | /*! | - |
| 196 | Returns the gamma value used in font smoothing. | - |
| 197 | */ | - |
| 198 | qreal QStyleHints::fontSmoothingGamma() const | - |
| 199 | { | - |
| 200 | return hint(QPlatformIntegration::FontSmoothingGamma).toReal(); never executed: return hint(QPlatformIntegration::FontSmoothingGamma).toReal(); | 0 |
| 201 | } | - |
| 202 | | - |
| 203 | /*! | - |
| 204 | Returns \c true if right-to-left writing direction is enabled, | - |
| 205 | otherwise \c false. | - |
| 206 | */ | - |
| 207 | bool QStyleHints::useRtlExtensions() const | - |
| 208 | { | - |
| 209 | return hint(QPlatformIntegration::UseRtlExtensions).toBool(); executed: return hint(QPlatformIntegration::UseRtlExtensions).toBool();Execution Count:2 | 2 |
| 210 | } | - |
| 211 | | - |
| 212 | QT_END_NAMESPACE | - |
| 213 | | - |
| | |