oklch()
Baseline
2023
Newly available
Since May 2023, this feature works across the latest devices and browser versions. This feature might not work in older devices or browsers.
Die oklch()
Funktionsnotation drückt eine bestimmte Farbe im Oklab-Farbraum aus. oklch()
ist die zylindrische Form von oklab()
, die dieselbe L
-Achse verwendet, jedoch mit polaren Chroma (C
) und Farbton (h
) Koordinaten.
Syntax
/* Absolute values */
oklch(40.1% 0.123 21.57)
oklch(59.69% 0.156 49.77)
oklch(59.69% 0.156 49.77 / .5)
/* Relative values */
oklch(from green l c h / 0.5)
oklch(from #123456 calc(l + 0.1) c h)
oklch(from hsl(180 100% 50%) calc(l - 0.1) c h)
oklch(from var(--color) l c h / calc(alpha - 0.1))
Werte
Nachfolgend sind die Beschreibungen der zulässigen Werte für sowohl absolute als auch relative Farben aufgeführt.
Hinweis:
Normalerweise entspricht 100%
bei Prozentwerten, die in CSS einen numerischen Äquivalent haben, der Zahl 1
.
Dies ist nicht der Fall für alle oklch()
Komponentenwerte. Hier entspricht 100%
dem Wert 0.4
für den C
-Wert.
Absolute Wertsyntax
oklch(L C H[ / A])
Die Parameter sind wie folgt:
L
-
Eine
<number>
zwischen0
und1
, ein<percentage>
zwischen0%
und100%
oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). In diesem Fall entspricht die Zahl0
0%
(schwarz) und die Zahl1
100%
(weiß). Dieser Wert gibt die wahrgenommene Helligkeit der Farbe an.Hinweis: Das
L
inoklch()
ist die wahrgenommene Helligkeit, die sich auf die "Helligkeit" bezieht, die wir mit unseren Augen visuell wahrnehmen. Dies ist anders als dasL
inhsl()
, wo es die Helligkeit im Vergleich zu anderen Farben darstellt. C
-
Ein
<number>
, ein<percentage>
, oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). Dieser Wert ist ein Maß für das Chroma der Farbe (ungefähr die "Menge der Farbe"). Der minimal nützliche Wert ist0
, während der maximale theoretisch ungebunden ist (in der Praxis jedoch nicht über0.5
hinausgeht). In diesem Fall ist0%
0
und100%
ist die Zahl0.4
. H
-
Ein
<number>
, ein<angle>
, oder das Schlüsselwortnone
(entspricht in diesem Fall0deg
), das den<hue>
Winkel der Farbe darstellt.Hinweis: Die Winkel, die bestimmten Farbtönen entsprechen, unterscheiden sich zwischen dem sRGB-Farbraum (verwendet von
hsl()
undhwb()
), CIELAB (verwendet vonlch()
) und Oklab (verwendet vonoklch()
). Siehe das Beispiel zu Farbtönen inoklch()
unten und die<hue>
Referenzseite für weitere Details und Beispiele. A
Optional-
Ein
<alpha-value>
, das den Alpha-Kanal-Wert der Farbe darstellt, wobei die Zahl0
0%
(vollständig transparent) und1
100%
(vollständig deckend) entspricht. Zusätzlich kann das Schlüsselwortnone
verwendet werden, um explizit keinen Alpha-Kanal anzugeben. Wenn derA
Kanalwert nicht explizit angegeben wird, ist der Standardwert 100%. Wenn enthalten, wird der Wert von einem Schrägstrich (/
) eingeführt.
Hinweis: Weitere Informationen zu fehlenden Farbkomponenten finden Sie unter Fehlende Farbkomponenten.
Relative Wertsyntax
oklch(from <color> L C H[ / A])
Die Parameter sind wie folgt:
from <color>
-
Das Schlüsselwort
from
wird immer bei der Definition einer relativen Farbe angegeben, gefolgt von einem<color>
-Wert, der die Ursprungsfarbe darstellt: Dies ist die ursprüngliche Farbe, auf der die relative Farbe basiert. Die Ursprungsfarbe kann eine beliebige gültige<color>
-Syntax sein, einschließlich einer anderen relativen Farbe. L
-
Eine
<number>
zwischen0
und1
, eine<percentage>
zwischen0%
und100%
, oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). Dies stellt den Helligkeitswert der Ausgabefarbe dar. Hier entspricht die Zahl0
0%
(schwarz) und die Zahl1
100%
(weiß). C
-
Ein
<number>
, ein<percentage>
, oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). Dieser Wert repräsentiert den Chroma-Wert der Ausgabefarbe (ungefähr die "Menge der Farbe"). Der minimal nützliche Wert ist0
, während der maximale theoretisch ungebunden ist (in der Praxis jedoch nicht über0.5
hinausgeht). In diesem Fall ist0%
0
und100%
ist die Zahl0.4
. H
-
Ein
<number>
, ein<angle>
, oder das Schlüsselwortnone
(entspricht in diesem Fall0deg
), das den<hue>
Winkel der Ausgabefarbe darstellt. Siehe ein Beispiel für verschiedene Farbtöne im Abschnitt Beispiele unten. A
Optional-
Ein
<alpha-value>
, das den Alpha-Kanal-Wert der Ausgabefarbe darstellt, wobei die Zahl0
0%
(vollständig transparent) und1
100%
(vollständig deckend) entspricht. Zusätzlich kann das Schlüsselwortnone
verwendet werden, um explizit keinen Alpha-Kanal anzugeben. Wenn derA
Kanalwert nicht explizit angegeben wird, übernimmt er den Alpha-Kanal-Wert der Ursprungsfarbe. Wenn enthalten, wird der Wert von einem Schrägstrich (/
) eingeführt.
Definition von relativen Farb-Ausgabekanalkomponenten
Beim Verwenden der relativen Farbsyntax innerhalb einer oklch()
Funktion, konvertiert der Browser die Ursprungsfarbe in eine äquivalente Oklch-Farbe (wenn sie nicht bereits als solche angegeben ist). Die Farbe wird als drei unterschiedliche Farbkanalwerte definiert — l
(Helligkeit), c
(Chroma) und h
(Farbton) — sowie ein Alpha-Kanal-Wert (alpha
). Diese Kanalwerte sind innerhalb der Funktion verfügbar, um bei der Definition der Ausgabefarbkanalwerte verwendet zu werden:
- Der
l
Kanalwert wird auf eine<number>
zwischen0
und1
aufgelöst. - Der
c
Kanalwert wird auf eine<number>
zwischen0
und0.4
aufgelöst. - Der
h
Kanalwert wird auf eine<number>
zwischen0
und360
aufgelöst. - Der
alpha
Kanal wird auf eine<number>
zwischen0
und1
aufgelöst.
Bei der Definition einer relativen Farbe können die verschiedenen Kanäle der Ausgabefarbe auf mehrere verschiedene Weisen ausgedrückt werden. Im Folgenden werden wir einige Beispiele betrachten, um diese zu veranschaulichen.
In den ersten beiden Beispielen unten verwenden wir die relative Farbsyntax. Das erste gibt jedoch dieselbe Farbe wie die Ursprungsfarbe aus, und das zweite gibt eine Farbe aus, die überhaupt nicht auf der Ursprungsfarbe basiert. Sie erzeugen nicht wirklich relative Farben! Es ist unwahrscheinlich, dass Sie diese jemals in einem echten Code verwenden würden, und würden wahrscheinlich stattdessen einfach einen absoluten Farbwert verwenden. Wir haben diese Beispiele als Ausgangspunkt für das Erlernen der relativen oklch()
Syntax aufgenommen.
Lassen Sie uns mit einer Ursprungsfarbe von hsl(0 100% 50%)
(entspricht rot
) beginnen. Die folgende Funktion gibt dieselbe Farbe wie die Ursprungsfarbe aus — sie verwendet die l
, c
und h
Kanalwerte der Ursprungsfarbe (0.627966
, 0.257704
, und 29.2346
) als Ausgabekanäle:
oklch(from hsl(0 100% 50%) l c h)
Diese Funktion gibt die Farbe oklch(0.627966 0.257704 29.2346)
aus.
Die nächste Funktion verwendet absolute Werte für die Ausgabefarbkanalwerte und gibt eine völlig andere Farbe aus, die nicht auf der Ursprungsfarbe basiert:
oklch(from hsl(0 100% 50%) 42.1% 0.25 328.363)
In diesem Fall ist die Ausgabefarbe oklch(0.421 0.25 328.363)
.
Die folgende Funktion erzeugt eine relative Farbe auf Basis der Ursprungsfarbe:
oklch(from hsl(0 100% 50%) 0.8 0.4 h)
Dieses Beispiel:
- Konvertiert die
hsl()
Ursprungsfarbe in eine äquivalenteoklch()
Farbe —oklch(0.627966 0.257704 29.2346)
. - Setzt den
H
Kanalwert der Ausgabefarbe auf denH
Kanalwert desoklch()
Äquivalents der Ursprungsfarbe —29.2346
. - Setzt die
L
- undC
-Kanalwerte der Ausgabefarbe auf neue Werte, die nicht auf der Ursprungsfarbe basieren:0.8
und0.4
jeweils.
Die endgültige Ausgabefarbe ist oklch(0.8 0.4 29.2346)
.
Hinweis: Wie oben erwähnt, wird die Ursprungsfarbe in den Hintergrund in dasselbe Farbmodell wie die Ausgabefarbe umgewandelt, wenn die Ausgabefarbe ein anderes Farbmodell als die Ursprungsfarbe verwendet, damit sie auf eine kompatible Weise dargestellt werden kann (d.h. unter Verwendung derselben Kanäle).
In den bisherigen Beispielen in diesem Abschnitt wurden die Alpha-Kanäle weder für die Ursprungs- noch für die Ausgabefarben explizit angegeben. Wenn der Alpha-Kanal der Ausgabefarbe nicht angegeben ist, übernimmt er denselben Wert wie der Alpha-Kanal der Ursprungsfarbe. Wenn der Alpha-Kanal der Ursprungsfarbe nicht angegeben ist (und es sich nicht um eine relative Farbe handelt), ist der Standardwert 1
. Daher sind die Alpha-Kanalwerte von Ursprung und Ausgabe 1
für die obigen Beispiele.
Schauen wir uns einige Beispiele an, die Ursprung und Ausgabe der Alpha-Kanal-Werte spezifisch spezifizieren. Das erste Beispiel spezifiziert den Alpha-Kanalwert der Ausgabe als denselben wie den Alpha-Kanalwert der Ursprungsfarbe, während das zweite einen anderen Alpha-Kanalwert der Ausgabe angibt, der nichts mit dem Alpha-Kanalwert der Ursprungsfarbe zu tun hat.
oklch(from hsl(0 100% 50% / 0.8) l c h / alpha)
/* Computed output color: oklch(0.627966 0.257704 29.2346 / 0.8) */
oklch(from hsl(0 100% 50% / 0.8) l c h / 0.5)
/* Computed output color: oklch(0.627966 0.257704 29.2346 / 0.5) */
Im folgenden Beispiel wird die hsl()
Ursprungsfarbe erneut in das oklch()
Äquivalent konvertiert — oklch(0.627966 0.257704 29.2346)
. calc()
Berechnungen werden auf die L
-, C
-, H
- und A
-Werte angewendet, was zu einer Ausgabefarbe von oklch(0.827966 0.357704 9.23462 / 0.9)
führt:
oklch(from hsl(0 100% 50%) calc(l + 0.2) calc(c + 0.1) calc(h - 20) / calc(alpha - 0.1))
Hinweis:
Da die Ursprungskanäle in <number>
Werte aufgelöst werden, müssen Sie ihnen Zahlen hinzufügen, wenn Sie sie in Berechnungen verwenden, selbst in Fällen, in denen ein Kanal normalerweise <percentage>
, <angle>
oder andere Werttypen akzeptieren würde. Das Hinzufügen eines <percentage>
zu einem <number>
, zum Beispiel, funktioniert nicht.
Formale Syntax
<oklch()> =
oklch( [ <percentage> | <number> | none ] [ <percentage> | <number> | none ] [ <hue> | none ] [ / [ <alpha-value> | none ] ]? )
<hue> =
<number> |
<angle>
<alpha-value> =
<number> |
<percentage>
Beispiele
>Anpassen der Helligkeit einer Farbe
Dieses Beispiel zeigt die Wirkung des Variierens des L
(Helligkeits-) Wertes der oklch()
Funktionsnotation.
HTML
<div data-color="blue-dark"></div>
<div data-color="blue"></div>
<div data-color="blue-light"></div>
<div data-color="red-dark"></div>
<div data-color="red"></div>
<div data-color="red-light"></div>
<div data-color="green-dark"></div>
<div data-color="green"></div>
<div data-color="green-light"></div>
CSS
[data-color="blue-dark"] {
background-color: oklch(10% 0.4 240);
}
[data-color="blue"] {
background-color: oklch(50% 0.4 240);
}
[data-color="blue-light"] {
background-color: oklch(90% 0.4 240);
}
[data-color="red-dark"] {
background-color: oklch(10% 0.4 20);
}
[data-color="red"] {
background-color: oklch(50% 0.4 20);
}
[data-color="red-light"] {
background-color: oklch(90% 0.4 20);
}
[data-color="green-dark"] {
background-color: oklch(10% 0.4 130);
}
[data-color="green"] {
background-color: oklch(50% 0.4 130);
}
[data-color="green-light"] {
background-color: oklch(90% 0.4 130);
}
Ergebnis
Anpassen der Farbintensität über Chroma
Das folgende Beispiel zeigt die Wirkung des Variierens des C
(Chroma) Wertes der oklch()
Funktionsnotation, wobei die Farben an Intensität abnehmen, wenn der C
-Wert von voll gesättigt zu fast grau abnimmt.
HTML
<div data-color="blue"></div>
<div data-color="blue-chroma1"></div>
<div data-color="blue-chroma2"></div>
<div data-color="blue-chroma3"></div>
<div data-color="red"></div>
<div data-color="red-chroma1"></div>
<div data-color="red-chroma2"></div>
<div data-color="red-chroma3"></div>
<div data-color="green"></div>
<div data-color="green-chroma1"></div>
<div data-color="green-chroma2"></div>
<div data-color="green-chroma3"></div>
CSS
Mit den anfänglichen Startfarben Blau, Rot und Grün deklarieren wir zunehmend kleinere Werte für Chroma: beginnend bei voller Farbsättigung beim hohen Wert von 0.4
(entspricht 100%
) bis hin zu 0.01
(entspricht 2%
), was für alle Farben fast grau ist.
[data-color="blue"] {
background-color: oklch(50% 0.4 240);
}
[data-color="blue-chroma1"] {
background-color: oklch(50% 0.2 240);
}
[data-color="blue-chroma2"] {
background-color: oklch(50% 0.1 240);
}
[data-color="blue-chroma3"] {
background-color: oklch(50% 0.01 240);
}
[data-color="red"] {
background-color: oklch(50% 100% 20deg);
}
[data-color="red-chroma1"] {
background-color: oklch(50% 50% 20deg);
}
[data-color="red-chroma2"] {
background-color: oklch(50% 25% 20deg);
}
[data-color="red-chroma3"] {
background-color: oklch(50% 2% 20deg);
}
[data-color="green"] {
background-color: oklch(50% 0.4 130);
}
[data-color="green-chroma1"] {
background-color: oklch(50% 0.2 130);
}
[data-color="green-chroma2"] {
background-color: oklch(50% 0.1 130);
}
[data-color="green-chroma3"] {
background-color: oklch(50% 0.01 130);
}
Ergebnis
Wenn wir 0
anstelle von 0.01
und 2%
bei denselben Helligkeitswerten verwendet hätten, wären die Farben alle im selben Grauton gewesen. In diesem Beispiel sind sie jedoch fast grau.
Farbtöne in oklch
Das folgende Beispiel zeigt Muster mit unterschiedlichen H
(Farbton-) Werten der oklch()
Funktionsnotation.
HTML
<div data-color="0">0deg</div>
<div data-color="20">20deg</div>
<div data-color="40">40deg</div>
<div data-color="60">60deg</div>
und so weiter.
CSS
[data-color="0"] {
background-color: oklch(50% 0.4 0deg);
}
[data-color="20"] {
background-color: oklch(50% 0.4 20deg);
}
[data-color="40"] {
background-color: oklch(50% 0.4 40deg);
}
[data-color="60"] {
background-color: oklch(50% 0.4 60deg);
}
und so weiter.
Ergebnis
Die Farbtonwinkel in oklch()
unterscheiden sich von denen in hsl()
. Weitere Informationen finden Sie in <hue>
. In hsl()
stellt der sRGB-Farbton 0deg
rot dar. Im CIELab-Farbraum hingegen entspricht 0deg
magenta, während rot etwa 41deg
ist.
Anpassen des Alpha-Werts einer Farbe
Das folgende Beispiel zeigt die Wirkung des Variierens des A
(Alpha-) Wertes der oklch()
Farb-Funktion.
Die red
- und red-alpha
-Elemente überlappen das #background-div
-Element, um die Wirkung von Opazität zu demonstrieren.
Wenn A
ein Wert von 0.4
gegeben wird, macht es die Farbe zu 40% deckend.
HTML
<div id="background-div">
<div data-color="red"></div>
<div data-color="red-alpha"></div>
</div>
CSS
[data-color="red"] {
background-color: oklch(50% 0.5 20);
}
[data-color="red-alpha"] {
background-color: oklch(50% 0.5 20 / 0.4);
}
Ergebnis
Verwenden relativer Farben mit oklch()
Dieses Beispiel gestaltet drei <div>
Elemente mit unterschiedlichen Hintergrundfarben. Das mittlere erhält die unveränderte --base-color
, während die linken und rechten jeweils aufgehellte und verdunkelte Varianten dieser --base-color
erhalten.
Diese Varianten werden unter Verwendung relativer Farben definiert — die --base-color
benutzerdefinierte Eigenschaft wird in eine oklch()
Funktion übergeben, und die Ausgabefarben haben ihre Helligkeitskanäle modifiziert, um den gewünschten Effekt zu erzielen, durch eine calc()
Funktion. Die aufgehellte Farbe hat zum Helligkeitskanal 0.15
(15%) hinzugefügt, und die verdunkelte Farbe hat 0.15
(15%) vom Helligkeitskanal subtrahiert.
CSS
:root {
--base-color: orange;
}
#one {
background-color: oklch(from var(--base-color) calc(l + 0.15) c h);
}
#two {
background-color: var(--base-color);
}
#three {
background-color: oklch(from var(--base-color) calc(l - 0.15) c h);
}
Ergebnis
Das Ergebnis ist wie folgt:
Spezifikationen
Specification |
---|
CSS Color Module Level 5> # relative-Oklch> |
CSS Color Module Level 4> # ok-lab> |
Browser-Kompatibilität
Loading…
Siehe auch
- Liste aller Farbnotationen
- Verwendung relativer Farben
- CSS Farben Modul
<hue>
Datentyplch()
undoklab()
Farb-Funktionen- Interaktiver Beitrag über OKLCH-Farbraum (2024)
- OKLCH in CSS: warum wir von RGB und HSL gewechselt sind (2024)
- Ein perceptueller Farbraum für die Bildverarbeitung (2020)