68 97 119 105 100 32 82 121 108 107 111

CSS Media Feature: Display Mode

02 sierpnia 2024 | Dawid Ryłko
Ilustracja przedstawia proste, przykładowe okno przeglądarki internetowej na trzech różnych urządzeniach: smartfonie, tablecie i komputerze stacjonarnym.

Ostatni wpis poświęcony był funkcji @media (scripting). Dzisiaj będziemy kontynuować podróż po Media Queries Level 5 i skupimy się na @media (display-mode).

Co to jest @media (display-mode)?

@media (display-mode) to funkcja, która umożliwia dostosowanie stylów w zależności od trybu wyświetlania aplikacji.

Progressive Web Apps (PWA) mogą ustawić tryb wyświetlania, ustawiając display w pliku manifestu aplikacji. @media (display-mode) pozwala na dostosowanie stylów CSS w zależności od ustawionego trybu wyświetlania. Warto jednak zauważyć, że żądana wartość może nie być zawsze obsługiwana przez przeglądarkę.

Składnia

  1. browser - Aplikacja otwiera się w standardowej karcie przeglądarki lub nowym oknie. Jest to domyślny tryb wyświetlania aplikacji internetowych.
@media (display-mode: browser) {
  /* Style dla sytuacji, gdy aplikacja działa w przeglądarce */
}
  1. fullscreen - Aplikacja uruchamia się na pełnym ekranie, ukrywając wszystkie elementy interfejsu przeglądarki (chrome). Tryb ten zapewnia użytkownikowi pełne zanurzenie w aplikacji.
@media (display-mode: fullscreen) {
  /* Style dla sytuacji, gdy aplikacja działa w pełnym ekranie */
}
  1. minimal-ui - Aplikacja działa w trybie przypominającym aplikacje natywne, z podstawowymi elementami interfejsu przeglądarki, takimi jak przyciski nawigacyjne. Elementy te mogą różnić się w zależności od przeglądarki.
@media (display-mode: minimal-ui) {
  /* Style dla sytuacji, gdy aplikacja działa w trybie minimal-ui */
}
  1. picture-in-picture - Aplikacja działa w trybie "obraz w obrazie", wyświetlając się w małym oknie na ekranie, co pozwala na jednoczesne korzystanie z innych aplikacji lub oglądanie innych treści.
@media (display-mode: picture-in-picture) {
  /* Style dla sytuacji, gdy aplikacja działa w trybie obraz w obrazie */
}
  1. standalone - Aplikacja działa jako samodzielna aplikacja, wyglądając i zachowując się jak aplikacja natywna, bez elementów interfejsu przeglądarki.
@media (display-mode: standalone) {
  /* Style dla sytuacji, gdy aplikacja działa jako samodzielna aplikacja */
}
  1. window-controls-overlay - Aplikacja działa jako okno z nakładką na kontrolki, które zawiera przyciski do minimalizacji, maksymalizacji i zamknięcia okna.
@media (display-mode: window-controls-overlay) {
  /* Style dla sytuacji, gdy aplikacja działa jako okno z nakładką na kontrolki */
}

Wsparcie przeglądarek

Wsparcie przeglądarek dla @media: display-mode

Funkcja @media (display-mode) jest wspierana przez większość nowoczesnych przeglądarek. Aktualny stan wsparcia można sprawdzić na Can I use.

Przykładowe zastosowanie

  • Personalizacja interfejsu: Dostosowanie interfejsu użytkownika w zależności od trybu wyświetlania aplikacji.
  • Optymalizacja wydajności: Dostosowanie stylów CSS do trybu wyświetlania, aby zoptymalizować wydajność aplikacji.
  • Zwiększenie użyteczności: Dostosowanie interfejsu użytkownika do trybu wyświetlania, aby zwiększyć użyteczność aplikacji.

Przykład

Przyjrzyjmy się przykładom użycia @media (display-mode):

@media all and (display-mode: fullscreen) {
  body {
    margin: 0;
    border: 2px dashed red;
  }
}

W powyższym przykładzie, kiedy aplikacja jest uruchomiona w trybie pełnoekranowym, marginesy ciała dokumentu są ustawione na 0, a ramka jest czerwona i przerywana.

@media (display-mode: picture-in-picture) and (prefers-color-scheme: light) {
  body {
    background: cyan;
  }
}

@media (display-mode: picture-in-picture) and (prefers-color-scheme: dark) {
  body {
    background: #3e3e3e;
  }

  a {
    color: cyan;
  }
}

W tym przykładzie dostosowujemy tło i kolor linków w zależności od trybu picture-in-picture oraz preferowanego schematu kolorów (jasny lub ciemny).

Podsumowanie

@media (display-mode) to interesująca funkcja, która pozwala na dostosowanie stylów CSS w zależności od trybu wyświetlania aplikacji. Dzięki niej możemy tworzyć bardziej spersonalizowane i zoptymalizowane interfejsy użytkownika, co zwiększa użyteczność i satysfakcję z korzystania z aplikacji.

Źródła


Profile picture

Dawid Ryłko

Software Engineer | Frontend Architect