CSS color-mix()

Adam Argyle
Adam Argyle

Usługa porównywania cen: color-mix() umożliwia mieszanie kolorów w dowolnej z obsługiwanych przestrzeni kolorów bezpośrednio z CSS.

Obsługa przeglądarek

  • Chrome: 111.
  • Edge: 111.
  • Firefox: 113.
  • Safari: 16.2

Źródło

Przed color-mix() do przyciemnienia, rozjaśnienia lub zmniejszenia koloru deweloperzy używali procesy wstępnego przetwarzania danych CSS, calc() w kolorze kanałów.

Wcześniej w SCSS
.color-mixing-with-sass {
  /* Sass: equally mix red with white */
  --red-white-mix: color.mix(red, white);
}

Firma Sass świetnie sobie radzi wyprzedzając specyfikację CSS dotyczącą kolorów. Nie było jednak żadnego aby mieszać kolory w CSS. Aby zbliżyć się do siebie, musisz obliczyć cząstkę kolorów. Oto skrócony przykład tego, jak obecnie CSS może symulować mieszanie:

Wcześniej w przypadku HSL
.color-mixing-with-vanilla-css-before {
  --lightness: 50%;
  --red: hsl(0 50% var(--lightness));

  /* add "white" to red
     by adding 25% to the lightness channel
  */
  --lightred: hsl(0 50% calc(var(--lightness) + 25%);
}

color-mix() wprowadza które umożliwia mieszanie kolorów z kodem CSS. Deweloperzy mogą wybrać przestrzeń kolorów, którą chcą mieszać i jak dominujący ma być każdy z kolorów.

Po
.color-mixing-after {
  /* equally mix red with white */
  --red-white-mix: color-mix(in oklab, red, white);

  /* equally mix red with white in srgb */
  --red-white-mix-srgb: color-mix(in srgb, red, white);
}

Właśnie tego chcemy. Elastyczność, wydajność i w pełni funkcjonalne interfejsy API. pokochaj,

Łączenie kolorów w CSS

Arkusz CSS funkcjonuje w wielu przestrzeniach i gamie kolorów, określenie przestrzeni kolorów do mieszania nie jest opcjonalne. Co więcej, różnią się przestrzenie kolorów mogą diametralnie zmienić efekty ich mieszania, przestrzeni kolorów pomoże Ci uzyskać pożądane wyniki.

Aby uzyskać interaktywne wprowadzenie, wypróbuj to narzędzie color-mix(): - Poznaj efekty każdej przestrzeni kolorów. - Poznaj efekty interpolacji barw w przypadku mieszania koloru cylindrycznego pokój (lch, oklch, hsl i hwb). - Zmień mieszane kolory, klikając jedno z dwóch górnych pól kolorów. – Za pomocą suwaka zmień współczynnik miksowania. – Wygenerowany kod CSS color-mix() dostępny na dole.

Łączenie różnych przestrzeni kolorów

Domyślna przestrzeń kolorów do mieszania (i gradientów) to oklab. Zapewnia i uzyskiwanie spójnych wyników. Możesz też określić alternatywne przestrzenie kolorów, odpowiednio do swoich potrzeb.

Weźmy na przykład black i white. Przestrzeń kolorów, w której mieszają się kolory, to tak duża różnica, prawda? Błąd.

color-mix(in srgb, black, white);
color-mix(in srgb-linear, black, white);
color-mix(in lch, black, white);
color-mix(in oklch, black, white);
color-mix(in lab, black, white);
color-mix(in oklab, black, white);
color-mix(in xyz, black, white);
W 7 przestrzeniach kolorów (srgb, linear-srgb, lch, oklch, lab, oklab, xyz) pokazuje efekty połączenia czerni i bieli. Wyświetlanych jest mniej więcej 5 różnych odcieni, co pokazuje, że każda przestrzeń kolorów będzie nawet inaczej mieszać się z szarością.
Wypróbuj wersję demonstracyjną

To bardzo wymierne efekty!

Weźmy blue i white dla innego przykładu. Wybrałem tę opcję dlatego, jest tak, że na wyniki wpływa kształt przestrzeni kolorów. W tym przypadku większość przestrzeni kolorów zmienia kolor z białego na niebieski. it a także pokazuje, że oklab to niezawodna przestrzeń kolorów do mieszania. który odpowiada oczekiwaniom większości użytkowników, jakim jest mieszanie białego i niebieskiego (nie fioletowego).

color-mix(in srgb, blue, white);
color-mix(in srgb-linear, blue, white);
color-mix(in lch, blue, white);
color-mix(in oklch, blue, white);
color-mix(in lab, blue, white);
color-mix(in oklab, blue, white);
color-mix(in xyz, blue, white);
7 przestrzeni kolorów (srgb, linear-srgb, lch, oklch, lab, oklab, xyz) ma różne wyniki. Wiele z nich jest różowych lub fioletowych, a nieliczne w rzeczywistości są nadal niebieskie.
Wypróbuj wersję demonstracyjną

Nauka efektów przestrzeni kolorów za pomocą color-mix() to doskonały sposób na tworzenie gradientów . Składnia koloru 4 umożliwia też gradientom określenie przestrzeni kolorów, gdzie pokazuje mieszankę na obszarze przestrzeni.

.black-to-white-gradient-in-each-space {
  --srgb: linear-gradient(to right in srgb, black, white);
  --srgb-linear: linear-gradient(to right in srgb-linear, black, white);
  --lab: linear-gradient(to right in lab, black, white);
  --oklab: linear-gradient(to right in oklab, black, white);
  --lch: linear-gradient(to right in lch, black, white);
  --oklch: linear-gradient(to right in oklch, black, white);
  --hsl: linear-gradient(to right in hsl, black, white);
  --hwb: linear-gradient(to right in hwb, black, white);
  --xyz: linear-gradient(to right in xyz, black, white);
  --xyz-d50: linear-gradient(to right in xyz-d50, black, white);
  --xzy-d65: linear-gradient(to right in xyz-d65, black, white);
}
Gradienty od czerni do bieli w różnych przestrzeniach kolorów.
Wypróbuj wersję demonstracyjną

Jeśli zastanawiasz się, która przestrzeń kolorów jest „najlepsza”, nie ma żadnej. Dlatego jest tyle opcji! Nie powstały też żadne nowe przestrzenie kolorów (zobacz oklch i oklab), jeśli było „najlepsze”. Każdy kolor to właśnie miejsce, w którym warto się promować, może okazać się właściwym wyborem.

Jeśli na przykład chcesz uzyskać efekt żywej miksu, użyj hsl lub hwb. W następujących demo, dwa żywe kolory (purpurowy i limonkowy) są wymieszane ze sobą oraz hsl i hwb dają żywe kolory, natomiast soptout i oklab dają kolory nienasycone.

Wyniki są składane zgodnie z opisem powyżej.
Wypróbuj wersję demonstracyjną

Jeśli zależy Ci na spójności i subtelności, użyj Oklab. W tej prezentacji, która łączy niebieski i czarny, hsl i hWb dają zbyt żywe i zmieniające odcienie kolory, algorytm srgb i oklab dają ciemniejszy odcień niebieski.

Wyniki są składane zgodnie z opisem powyżej.
Wypróbuj wersję demonstracyjną

Poświęć pięć minut na przetestowanie color-mix()placu zabaw, aby przetestować różne kolory i miejsc, aby poznać zalety każdego z nich. Poza tym będziemy się więc spodziewać większej liczby wskazówek dotyczących przestrzeni kolorów, możliwości w naszych interfejsach.

Dostosowywanie metody interpolacji barw

Jeśli wybierzesz cylindryczną przestrzeń kolorów, praktycznie każdy kolor z kanałem odcienia h, który akceptuje kąt, możesz określić, czy interpolacja idzie shorter, longer, decreasing i increasing. To jest ale znajdziesz więcej informacji w tym przewodniku po kolorach HD.

Oto ten sam przykład mieszania kolorów od niebiesko-białej, ale tym razem jest on dostępny tylko w w przestrzeni walcowej z różnymi metodami interpolacji barw.

Wyniki są składane zgodnie z opisem powyżej.
Wypróbuj wersję demonstracyjną

Oto kolejny Codepen stworzony przeze mnie, który pomaga zwizualizować interpolację barw, zwłaszcza gradientów. Dzięki temu zrozumiesz, jak każda daje efekt mieszania, gdy określona jest interpolacja barw, przyjrzyj się temu!

Łączenie z różnymi składniami kolorów

Do tej pory mieszaliśmy głównie kolory CSS z nazwami, na przykład blue i white. Kolor CSS mieszanie jest gotowe do mieszania kolorów z dwóch różnych przestrzeni kolorów. To jest Innym powodem, dla którego warto określić przestrzeń kolorów mieszania, jest to, wspólnej przestrzeni, w której dwa kolory nie znajdują się w tej samej przestrzeni.

color-mix(in oklch, hsl(200deg 50% 50%), color(display-p3 .5 0 .5));

W poprzednim przykładzie wartości hsl i display-p3 zostaną przekonwertowane na wartości oklch. a potem mieszać. Dość fajny i elastyczny.

Dostosowywanie proporcji mieszania

Jest mało prawdopodobne, że za każdym razem, gdy mieszasz barwę, jak większość dotychczasowych przykładów. Mamy dobrą wiadomość. Dostępna jest składnia słowa kluczowego określając, jaka część każdego koloru powinna być widoczna w mieszaninie.

Na początek zobaczmy przykładowe składanki, które są równoważne ze specyfikacji:

.ratios-syntax-examples {
  /* omit the percentage for equal mixes */
  color: color-mix(in lch, purple, plum);
  color: color-mix(in lch, plum, purple);

  /* percentage can go on either side of the color */
  color: color-mix(in lch, purple 50%, plum 50%);
  color: color-mix(in lch, 50% purple, 50% plum);

  /* percentage on just one color? other color gets the remainder */
  color: color-mix(in lch, purple 50%, plum);
  color: color-mix(in lch, purple, plum 50%);

  /* percentages > 100% are equally clamped */
  color: color-mix(in lch, purple 80%, plum 80%);
  /* above mix is clamped to this */
  color: color-mix(in lch, purple 50%, plum 50%);
}

Myślę, że te przykłady dobrze ilustrują skrajne przypadki. Pierwszy zestaw Przykłady pokazują, że wartość 50% nie jest wymagana, ale można ją opcjonalnie określić. Ostatni Pokazuje interesujący przypadek, kiedy współczynniki przekroczą 100% ale ich wartości są jednakowo ograniczane do 100%.

Zwróć też uwagę, że jeśli tylko jeden kolor określa współczynnik, przyjmuje się, że drugi a reszta – do 100%. Oto kilka dodatkowych przykładów, które pomogą to zilustrować. zachowanie użytkownika.

color-mix(in lch, purple 40%, plum) /* plum assigned 60% */
color-mix(in lch, purple, 60% plum) /* purple assigned 40% */
color-mix(in lch, purple 40%, plum 60%) /* no auto assignments */

Poniższe przykłady ilustrują 2 reguły: 1. Gdy współczynniki przekraczają 100%, są one ograniczane i równomiernie rozłożone. 1. Jeśli podany jest tylko jeden współczynnik proporcji, drugi kolor jest ustawiany na wartość 100 minus ten współczynnik.

Ostatnia zasada jest nieco mniej oczywista. Co się dzieje, gdy procenty są podane dla obu kolorów i nie sumują się do 100%?

color-mix(in lch, purple 20%, plum 20%)

Ta kombinacja wartości color-mix() zapewnia przejrzystość, 40% oraz przezroczystość. Jeśli współczynniki nie sumują się do 100%, powstała mieszanka nie będzie nieprzezroczysta. Żaden z kolorów nie będzie w pełni wymieszany.

Zagnieżdżanie: color-mix()

Podobnie jak w przypadku wszystkich arkuszy CSS, zagnieżdżanie przebiega prawidłowo i zgodnie z oczekiwaniami. funkcje wewnętrzne będą jako pierwsze i zwracają wartości do kontekstu nadrzędnego.

color-mix(in lch, purple 40%, color-mix(plum, white))

Możesz umieścić dowolną ilość treści, aby osiągnąć zamierzony efekt.

Tworzę jasny i ciemny schemat kolorów

Twórzmy schematy kolorów z pomocą color-mix().

Podstawowy schemat kolorów

W tym przykładzie CSS jasny i ciemny motyw jest tworzony na podstawie wartości szesnastkowej marki koloru. Jasny motyw tworzy 2 ciemnoniebieskie kolory tekstu i bardzo jasny biały kolor powierzchni tła. W zapytaniu o multimedia w ustawieniach trybu ciemnego właściwości mają przypisane nowe kolory, tak aby tło było ciemne, a kolory tekstu są lekkie.

:root {
  /* a base brand color */
  --brand: #0af;

  /* very dark brand blue */
  --text1: color-mix(in oklab, var(--brand) 25%, black);
  --text2: color-mix(in oklab, var(--brand) 40%, black);

  /* very bright brand white */
  --surface1: color-mix(in oklab, var(--brand) 5%, white);
}

@media (prefers-color-scheme: dark) {
  :root {
    --text1: color-mix(in oklab, var(--brand) 15%, white);
    --text2: color-mix(in oklab, var(--brand) 40%, white);
    --surface1: color-mix(in oklab, var(--brand) 5%, black);
  }
}

Wszystko to jest możliwe dzięki połączeniu białego lub czarnego z kolorem marki.

Schemat kolorów dla średnio zaawansowanych

Możesz pójść o krok dalej i dodać więcej motywów niż jasne i ciemne. W w poniższej prezentacji, zmiany grupy opcji aktualizacji atrybutu w kodzie HTML [color-scheme="auto"], który umożliwia stosowanie warunkowego przez selektory motyw kolorystyczny.

Ta wersja demonstracyjna dla średnio zaawansowanych pokazuje również technikę motywów, w której wszystkie elementy kolory motywu są wymienione w :root. Dzięki temu łatwiej jest je zobaczyć, i dostosować w razie potrzeby. W dalszej części arkusza stylów można używać zmiennych zdefiniowano jego definicję. Dzięki temu nie trzeba tracić czasu na manipulowanie kolorami są one zawarte w początkowym bloku :root.

Więcej ciekawych przypadków użycia

Ana Tudor ma świetną wersję demonstracyjną z kilkoma przykładami użycia do badania:

Debugowanie funkcji color-mix() za pomocą Narzędzi deweloperskich

Narzędzia deweloperskie w Chrome świetnie obsługują color-mix(). Rozpoznaje wyróżnia składnię, tworzy podgląd składni tuż obok stylu w w panelu Style i umożliwia wybranie alternatywnych kolorów.

W Narzędziach deweloperskich będzie to wyglądać mniej więcej tak:

Zrzut ekranu pokazujący sprawdzanie składni mieszania kolorów w Narzędziach deweloperskich w Chrome.

Miłego miksowania!