Skip to main content

Detect OS Dark Mode from Python

Project description

Darkdetect

This package allows to detect if the user is using Dark Mode on:

The main application of this package is to detect the Dark mode from your GUI Python application (Tkinter/wx/pyqt/qt for python (pyside)/...) and apply the needed adjustments to your interface. Darkdetect is particularly useful if your GUI library does not provide a public API for this detection (I am looking at you, Qt). In addition, this package does not depend on other modules or packages that are not already included in standard Python distributions.

Usage

import darkdetect

>>> darkdetect.theme()
'Dark'

>>> darkdetect.isDark()
True

>>> darkdetect.isLight()
False

It's that easy.

You can create a dark mode switch listener daemon thread with darkdetect.listener and pass a callback function. The function will be called with string "Dark" or "Light" when the OS switches the dark mode setting.

import threading
import darkdetect

# def listener(callback: typing.Callable[[str], None]) -> None: ...

t = threading.Thread(target=darkdetect.listener, args=(print,))
t.daemon = True
t.start()

Install

The preferred channel is PyPI:

pip install darkdetect

Alternatively, you are free to vendor directly a copy of Darkdetect in your app. Further information on vendoring can be found here.

Optional Installs

To enable the macOS listener, additional components are required, these can be installed via:

pip install darkdetect[macos-listener]

Notes

  • This software is licensed under the terms of the 3-clause BSD License.
  • This package can be installed on any operative system, but it will always return None unless executed on a OS that supports Dark Mode, including older versions of macOS and Windows.
  • On macOS, detection of the dark menu bar and dock option (available from macOS 10.10) is not supported.
  • Details on the detection method used on macOS.
  • Details on the experimental detection method used on Linux.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

darkdetect-0.8.0.tar.gz (7.7 kB view details)

Uploaded Source

Built Distribution

darkdetect-0.8.0-py3-none-any.whl (9.0 kB view details)

Uploaded Python 3

File details

Details for the file darkdetect-0.8.0.tar.gz.

File metadata

  • Download URL: darkdetect-0.8.0.tar.gz
  • Upload date:
  • Size: 7.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.0

File hashes

Hashes for darkdetect-0.8.0.tar.gz
Algorithm Hash digest
SHA256 b5428e1170263eb5dea44c25dc3895edd75e6f52300986353cd63533fe7df8b1
MD5 62fcc7a3e8d75c542c088314880ccba8
BLAKE2b-256 45777575be73bf12dee231d0c6e60ce7fb7a7be4fcd58823374fc59a6e48262e

See more details on using hashes here.

File details

Details for the file darkdetect-0.8.0-py3-none-any.whl.

File metadata

  • Download URL: darkdetect-0.8.0-py3-none-any.whl
  • Upload date:
  • Size: 9.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.0

File hashes

Hashes for darkdetect-0.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a7509ccf517eaad92b31c214f593dbcf138ea8a43b2935406bbd565e15527a85
MD5 7a9813627d3175e012d582133b5a13c9
BLAKE2b-256 f2f2728f041460f1b9739b85ee23b45fa5a505962ea11fd85bdbe2a02b021373

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page