Tryb ciemny jest dostępny w Androidzie 10 (poziom interfejsu API 29) i nowszych. Zapewnia ona te korzyści:
- Zmniejsza zużycie energii w znacznym stopniu, w zależności od technologii ekranu.
- Poprawia widoczność dla użytkowników niedowidzących i wrażliwych na jasne światło.
- Ułatwia korzystanie z urządzenia przy słabym oświetleniu.
Ciemny motyw stosowany jest do interfejsu Androida i aplikacji działających na urządzeniu.
Tryb ciemny można włączyć na Androidzie 10 i nowszych na 3 sposoby:
- Aby włączyć ciemny motyw, otwórz ustawienia systemu (Ustawienia > Wyświetlacz > Motyw).
- Gdy ta opcja jest włączona, możesz przełączać motywy w kafelku Szybkich ustawień.
- Na urządzeniach Pixel włącz tryb oszczędzania baterii, aby jednocześnie włączyć ciemny motyw. Inne urządzenia mogą nie obsługiwać tej funkcji.
Instrukcje dotyczące stosowania ciemnego motywu do treści internetowych za pomocą komponentu WebView znajdziesz w artykule Ciemny motyw w komponencie WebView.
Obsługa ciemnego motywu w aplikacji
Aby obsługiwać tryb ciemny, ustaw motyw aplikacji (zwykle znajduje się on w sekcji res/values/styles.xml
), aby dziedziczył z motywu DayNight
:
<style name="AppTheme" parent="Theme.AppCompat.DayNight">
Możesz też użyć ciemnego motywu komponentów Material Design:
<style name="AppTheme" parent="Theme.MaterialComponents.DayNight">
Łączy to główny motyw aplikacji z kontrolowanymi przez system flagami trybu nocnego i nadaje aplikacji domyślny ciemny motyw, gdy jest włączony.
Motywy i style
Unikaj stosowania na stałe kolorów lub ikon przeznaczonych do użytku z jasnym motywem. Zamiast tego użyj atrybutów motywu lub zasobów z kwalifikacją „nocna”.
W przypadku ciemnego motywu najważniejsze są 2 atrybuty motywu:
?android:attr/textColorPrimary
: kolor tekstu ogólnego. W jasnym temacie jest ona prawie czarna, a w ciemnym – prawie biała. zawiera stan wyłączony.?attr/colorControlNormal
: kolor ikony ogólnego przeznaczenia. zawiera stan wyłączony.
Zalecamy korzystanie z komponentów Material Design, ponieważ ich system kolorów, np. atrybuty ?attr/colorSurface
i ?attr/colorOnSurface
, zapewnia łatwy dostęp do odpowiednich kolorów. Możesz dostosować te atrybuty w swoim motywie.
Zmień motywy w aplikacji
Możesz zezwolić użytkownikom na zmianę motywu aplikacji w trakcie jej działania. Te opcje są zalecane:
- Jasny
- Ciemny
- Ustawienie domyślne systemu (zalecana opcja domyślna)
Te opcje są bezpośrednio powiązane z tymi trybami: AppCompat.DayNight
.
Jasny:
MODE_NIGHT_NO
.Ciemny:
MODE_NIGHT_YES
.Ustawienie domyślne systemu:
MODE_NIGHT_FOLLOW_SYSTEM
.
Aby zmienić motyw, wykonaj te czynności:
Na poziomie interfejsu API 31 lub wyższym użyj elementu
UiModeManager#setApplicationNightMode
, aby poinformować system, w jakiej tematyce jest Twoja aplikacja. Dzięki temu system dopasuje motyw na ekranie powitalnym.W przypadku interfejsu API na poziomie 30 lub niższym do przełączania motywu użyj
AppCompatDelegate.setDefaultNightMode()
.
Wymuś ciemny kolor
Android 10 udostępnia funkcję Wymuszenie ciemnego motywu, która pozwala deweloperom szybko wdrażać ciemny motyw bez konieczności ręcznego ustawiania motywu DayNight
.
Funkcja wymuszania trybu ciemnego analizuje każdy widok aplikacji w jasnym kolorze i automatycznie stosuje ciemny motyw, zanim zostanie on wyświetlony na ekranie. Aby skrócić czas potrzebny na wdrożenie ciemnego motywu, możesz użyć zarówno zmuszania do ciemnego motywu, jak i implementacji natywnej.
Aplikacje muszą włączyć wymuszanie trybu ciemnego, ustawiając atrybut android:forceDarkAllowed="true"
w motywie aktywności. Ten atrybut jest ustawiany we wszystkich jasnych motywach dostępnych w systemie i w AndroidzieX, np. Theme.Material.Light
. Gdy używasz opcji Wymuś tryb ciemny, dokładnie przetestuj aplikację i w razie potrzeby wyklucz wyświetlenia.
Jeśli aplikacja używa ciemnego motywu (np. Theme.Material
), tryb ciemny nie jest stosowany. Podobnie, jeśli motyw Twojej aplikacji dziedziczy z motywu DayNight
, tryb ciemny nie zostanie zastosowany z powodu automatycznego przełączania motywów.
Wyłączanie trybu ciemnego w danym widoku
Wymuszenie ciemnego motywu można włączyć w przypadku określonych widoków za pomocą atrybutu android:forceDarkAllowed
lub za pomocą setForceDarkAllowed()
.
Treści z internetu
Informacje o używaniu ciemnych motywów w treściach internetowych znajdziesz w artykule Ciemny motyw w WebView. Przykład ciemnego motywu zastosowanego w komponencie WebView znajdziesz w wersji demonstracyjnej WebView w GitHubie.
Sprawdzone metody
W następnych sekcjach znajdziesz sprawdzone metody implementowania ciemnych motywów.
Powiadomienia i widżety
W przypadku interfejsów, które wyświetlasz na urządzeniu, ale nie kontrolujesz bezpośrednio, upewnij się, że widoki, których używasz, odzwierciedlają motyw aplikacji hosta. Są to na przykład powiadomienia i widżety uruchamiające.
Powiadomienia
Użyj szablonów powiadomień udostępnionych w systemie, np. MessagingStyle
. Oznacza to, że za stosowanie prawidłowego stylu widoku odpowiada system.
Widoki widżetów i powiadomień niestandardowych
W przypadku widżetów w wyszukiwarce lub jeśli Twoja aplikacja korzysta z niestandardowych widoków treści powiadomień przetestuj je w jasnym i ciemnym motywie.
Oto najczęstsze pułapki:
- Zakładamy, że kolor tła jest zawsze jasny.
- Stałe kodowanie kolorów tekstu.
- Ustawienie zakodowanego na stałe koloru tła z domyślnym kolorem tekstu.
- Używanie rysowanej ikony w statycznym kolorze.
We wszystkich tych przypadkach zamiast zakodowanych na stałe kolorów użyj odpowiednich atrybutów motywu.
Ekrany uruchamiania
Jeśli aplikacja ma niestandardowy ekran uruchamiania, być może trzeba go zmodyfikować, aby odzwierciedlał wybrany motyw.
Usuń wszystkie zakodowane na stałe kolory, takie jak kolory tła ustawione programowo na biały. Zamiast tego użyj atrybutu tematyka ?android:attr/colorBackground
.
Zmiany konfiguracji
Zmiana motywu aplikacji (za pomocą ustawienia systemu lub narzędzia AppCompat) powoduje zmianę konfiguracji uiMode
. Oznacza to, że aktywności są automatycznie odtwarzane.
W niektórych przypadkach możesz chcieć, aby zmiana konfiguracji została przeprowadzona przez aplikację. Możesz na przykład opóźnić zmianę konfiguracji, ponieważ w danym momencie odtwarzany jest film.
Aplikacja może obsługiwać implementację ciemnego motywu, deklarując, że każdy Activity
może obsługiwać zmianę konfiguracji uiMode
:
<activity
android:name=".MyActivity"
android:configChanges="uiMode" />
Gdy Activity
deklaruje, że obsługuje zmiany konfiguracji, jej metoda onConfigurationChanged()
jest wywoływana w przypadku zmiany motywu.
Aby sprawdzić, jaki jest bieżący motyw, aplikacje mogą uruchomić kod w takiej postaci:
Kotlin
val currentNightMode = configuration.uiMode and Configuration.UI_MODE_NIGHT_MASK when (currentNightMode) { Configuration.UI_MODE_NIGHT_NO -> {} // Night mode is not active, we're using the light theme. Configuration.UI_MODE_NIGHT_YES -> {} // Night mode is active, we're using dark theme. }
Java
int currentNightMode = configuration.uiMode & Configuration.UI_MODE_NIGHT_MASK; switch (currentNightMode) { case Configuration.UI_MODE_NIGHT_NO: // Night mode is not active, we're using the light theme break; case Configuration.UI_MODE_NIGHT_YES: // Night mode is active, we're using dark theme break; }