qt6-bb10/examples/widgets
Volker Hilsheimer 95d4e6baba ColorScheme: make QStyleHints::colorScheme writable for applications
Applications can request the color scheme to be either explicitly light
or dark, or to follow the system default by setting the scheme to
Qt::ColorScheme::Unknown.

Setting the color scheme will make the request to the QPlatformTheme
implementation, which can then use the appropriate implementation to
set the application's appearance so that both palette and window
decoration follow the requested color scheme. This should trigger
theme change and palette change events. A change to the effective
scheme should then call back into QStyleHintsPrivate::updateColorScheme,
which will emit the changed signal for the property.

Implement this for macOS (Cocoa), iOS, Android, and Windows.

On macOS, we have to use deprecated AppKit APIs; the replacements for
those APIs are not suitable for this use case. On iOS, the setting is
for each UIWindow, which we can update or initialize based on an
explicitly requested scheme.

On Android we can piggy-back on the logic added when dark theme support
was introduced in b4a9bb1f6a.

On Windows, we have to fake a dark palette if the dark scheme is
requested on a light system, as there is no API to read a dark palette.
However, we also have to ignore any application preference if a high-
contrast accessibility theme is selected by the user (we report the
color scheme as unknown; there are both light and dark high-contrast
themes), and read the system palette using the GetSysColor API, which
is used for light mode. And we need to initialize windows with the
correct frame if the application explicitly overrides the system color
scheme.

Add an auto-test to the QApplication test, as that gives us the most
coverage to confirm that QStyleHints emits the changed signal, and that
Theme- and PaletteChange events are received by the toplevel widget
when the color scheme actually changes. This test has to be skipped
on platforms where we cannot set the color scheme programmatically.

Add the option to explicitly select the color scheme to the widget
gallery example, and default it to dark mode.

Fixes: QTBUG-124490
Change-Id: I7302993c0121284bf9d3b72e3149c6abbe6bd261
Reviewed-by: Tor Arne Vestbø <tor.arne.vestbo@qt.io>
2024-05-10 01:15:12 +02:00
..
animation CMake: Add deployment API to our examples 2024-03-22 20:23:52 +01:00
desktop CMake: Add deployment API to our examples 2024-03-22 20:23:52 +01:00
dialogs CMake: Add deployment API to our examples 2024-03-22 20:23:52 +01:00
doc Convert "Color Editor Factory" Example to snippets 2024-04-19 13:39:41 +02:00
draganddrop CMake: Add deployment API to our examples 2024-03-22 20:23:52 +01:00
gallery ColorScheme: make QStyleHints::colorScheme writable for applications 2024-05-10 01:15:12 +02:00
gestures CMake: Add deployment API to our examples 2024-03-22 20:23:52 +01:00
graphicsview CMake: Add deployment API to our examples 2024-03-22 20:23:52 +01:00
itemviews Convert "Color Editor Factory" Example to snippets 2024-04-19 13:39:41 +02:00
layouts CMake: Add deployment API to our examples 2024-03-22 20:23:52 +01:00
mainwindows CMake: Add deployment API to our examples 2024-03-22 20:23:52 +01:00
painting CMake: Add deployment API to our examples 2024-03-22 20:23:52 +01:00
qnx/foreignwindows Doc: Fix license of foreignwindows example 2023-06-30 18:46:54 +02:00
rhi CMake: Add deployment API to our examples 2024-03-22 20:23:52 +01:00
richtext CMake: Add deployment API to our examples 2024-03-22 20:23:52 +01:00
tools CMake: Add deployment API to our examples 2024-03-22 20:23:52 +01:00
touch CMake: Add deployment API to our examples 2024-03-22 20:23:52 +01:00
tutorials CMake: Add deployment API to our examples 2024-03-22 20:23:52 +01:00
widgets Convert Group Box Example to snippets and screenshots 2024-04-18 20:11:14 +02:00
CMakeLists.txt Correct license for examples files 2024-03-07 11:06:43 +01:00
widgets.pro Add QRhiWidget 2023-08-14 17:05:36 +02:00