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()
funktionale Notation drückt eine gegebene Farbe im Oklab-Farbraum aus. oklch()
ist die zylindrische Form von oklab()
, die dieselbe L
-Achse verwendet, aber mit den polaren Chroma- (C
) und Farbton- (h
) Koordinaten arbeitet.
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 finden Sie Beschreibungen der erlaubten Werte für sowohl absolute als auch relative Farben.
Hinweis:
Normalerweise entspricht in CSS bei Prozentwerten 100%
der Zahl 1
.
Dies gilt nicht für alle oklch()
-Komponentenwerte. Hier entspricht 100%
dem Wert 0.4
für den C
-Wert.
Syntax für absolute Werte
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%
). Hierbei entspricht die Zahl0
0%
(schwarz) und die Zahl1
100%
(weiß). Dieser Wert gibt die wahrgenommene Helligkeit, oder "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 unterscheidet sich von demL
inhsl()
, wo es die Helligkeit im Vergleich zu anderen Farben darstellt. C
-
Eine
<number>
, ein<percentage>
, oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). Dieser Wert ist ein Maß für das Chroma des Farbtons (ungefähr die "Farbmenge"). Sein minimaler nützlicher Wert ist0
, während der maximale theoretisch unbegrenzt ist (aber in der Praxis nicht0.5
überschreitet). Hierbei ist0%
0
und100%
ist die Zahl0.4
. H
-
Eine
<number>
, ein<angle>
, oder das Schlüsselwortnone
(entspricht in diesem Fall0deg
), welches den<hue>
-Winkel der Farbe repräsentiert.Hinweis: Die Winkel, die bestimmten Farbtönen entsprechen, unterscheiden sich in den sRGB-Farbräumen (verwendet von
hsl()
undhwb()
), CIELAB (verwendet vonlch()
) und Oklab (verwendet vonoklch()
). Siehe das Beispiel zu Farbtönen inoklch()
unten und die Referenzseite zum<hue>
für weitere Details und Beispiele. A
Optional-
Ein
<alpha-value>
, der den Alphakanalwert der Farbe darstellt, wobei die Zahl0
0%
(vollständig transparent) und1
100%
(vollständig opak) entspricht. Zusätzlich kann das Schlüsselwortnone
verwendet werden, um explizit keinen Alphakanal anzugeben. Falls derA
-Kanalwert nicht explizit angegeben wird, wird er auf 100% standardisiert. Falls er enthalten ist, geht dem Wert ein Schrägstrich (/
) voraus.
Hinweis:
Siehe Fehlende Farbkomponenten für weitere Informationen über die Auswirkungen von none
.
Syntax für relative Werte
oklch(from <color> L C H[ / A])
Die Parameter sind wie folgt:
from <color>
-
Das Schlüsselwort
from
wird immer verwendet, wenn eine relative Farbe definiert wird, gefolgt von einem<color>
-Wert, das die Ursprungsfarbe darstellt: Dies ist die ursprüngliche Farbe, auf der die relative Farbe basiert. Die Ursprungsfarbe kann jede gültige<color>
-Syntax sein, einschließlich einer anderen relativen Farbe. L
-
Eine
<number>
zwischen0
und1
, ein<percentage>
zwischen0%
und100%
oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). Dies stellt den Helligkeitswert der Ausgabefarbe dar. Hierbei entspricht die Zahl0
0%
(schwarz) und die Zahl1
100%
(weiß). C
-
Eine
<number>
, ein<percentage>
, oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). Dieser Wert stellt den Chromawert der Ausgabefarbe dar (ungefähr die "Farbmenge"). Sein minimaler nützlicher Wert ist0
, während sein maximaler theoretisch unbegrenzt ist (aber in der Praxis nicht0.5
überschreitet). Hierbei ist0%
0
und100%
ist die Zahl0.4
. H
-
Eine
<number>
, ein<angle>
, oder das Schlüsselwortnone
(entspricht in diesem Fall0deg
), welches den<hue>
-Winkel der Ausgabefarbe repräsentiert. Siehe ein Beispiel verschiedener Farbtöne im Abschnitt Beispiele weiter unten. A
Optional-
Ein
<alpha-value>
, der den Alphakanalwert der Ausgabefarbe darstellt, wobei die Zahl0
0%
(vollständig transparent) und1
100%
(vollständig opak) entspricht. Zusätzlich kann das Schlüsselwortnone
verwendet werden, um explizit keinen Alphakanal anzugeben. Falls derA
-Kanalwert nicht explizit angegeben wird, wird er auf den Alphakanalwert der Ursprungsfarbe standardisiert. Falls er enthalten ist, geht dem Wert ein Schrägstrich (/
) voraus.
Definition von Ausgabekanal-Komponenten für relative Farben
Wenn die relative Farbsyntax innerhalb einer oklch()
-Funktion verwendet wird, konvertiert der Browser die Ursprungsfarbe in eine äquivalente OkLCh-Farbe (falls sie nicht bereits so angegeben ist). Die Farbe wird als drei separate Farbkanalwerte definiert — l
(Helligkeit), c
(Chroma) und h
(Farbton) — sowie ein Alphakanalwert (alpha
). Diese Kanalwerte stehen innerhalb der Funktion zur Verfügung, um bei der Definition der Ausgabefarbkanalwerte verwendet zu werden:
- Der
l
-Kanalwert wird zu einem<number>
zwischen0
und1
aufgelöst, einschließlich. - Der
c
-Kanalwert wird zu einem<number>
zwischen0
und0.4
aufgelöst, einschließlich. - Der
h
-Kanalwert wird zu einem<number>
zwischen0
und360
aufgelöst, einschließlich. - Der
alpha
-Kanal wird zu einem<number>
zwischen0
und1
aufgelöst, einschließlich.
Beim Definieren einer relativen Farbe können die verschiedenen Kanäle der Ausgabefarbe auf mehrere verschiedene Arten ausgedrückt werden. Im Folgenden werden wir einige Beispiele untersuchen, um diese zu veranschaulichen.
In den ersten beiden Beispielen unten verwenden wir die relative Farbsyntax. Das erste gibt jedoch die gleiche Farbe wie die Ursprungsfarbe aus und das zweite gibt eine nicht auf der Ursprungsfarbe basierende Farbe aus. Sie erzeugen keine wirklichen relativen Farben! In einem echten Codebasis würden Sie diese wahrscheinlich nie verwenden und stattdessen einen absoluten Farbwert verwenden. Wir haben diese Beispiele als Ausgangspunkt für das Erlernen der relativen oklch()
-Syntax mit aufgenommen.
Beginnen wir mit einer Ursprungsfarbe von hsl(0 100% 50%)
(entspricht rot
). Die folgende Funktion gibt die gleiche Farbe wie die Ursprungsfarbe aus — sie verwendet die l
-, c
- und h
-Kanalwerte der Ursprungsfarbe (0.627966
, 0.257704
und 29.2346
) als Ausgabekanalwerte:
oklch(from hsl(0 100% 50%) l c h)
Die Ausgabe dieser Funktion ist oklch(0.627966 0.257704 29.2346)
.
Die nächste Funktion verwendet absolute Werte für die Kanäle der Ausgabefarbe 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 erstellt eine relative Farbe basierend auf 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 für die Ausgabefarbe auf denH
-Kanalwert der äquivalentenoklch()
-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, wenn die Ausgabefarbe ein anderes Farbmodell als die Ursprungsfarbe verwendet, wird die Ursprungsfarbe im Hintergrund in das gleiche Modell wie die Ausgabefarbe konvertiert, sodass sie auf eine Weise dargestellt werden kann, die kompatibel ist (d.h. unter Verwendung derselben Kanäle).
In den bisherigen Beispielen in diesem Abschnitt wurden die Alphakanäle weder für die Ursprungs- noch für die Ausgabefarben explizit angegeben. Wenn der Alphakanal der Ausgabefarbe nicht angegeben ist, wird er standardmäßig auf den gleichen Wert wie der Alphakanal der Ursprungsfarbe gesetzt. Wenn der Alphakanal der Ursprungsfarbe nicht angegeben ist (und es sich nicht um eine relative Farbe handelt), wird er auf 1
standardisiert. Daher sind die Alphakanalwerte der Ursprungs- und Ausgabefarben für die obigen Beispiele 1
.
Sehen wir uns einige Beispiele an, die die Ursprungs- und Ausgabefarbenalphakanalwerte angeben. Das erste Beispiel gibt den Alphakanalwert der Ausgabefarbe an, der mit dem Alphakanalwert der Ursprungsfarbe identisch ist, während das zweite Beispiel einen anderen Ausgabefarbenalphakanalwert angibt, der nicht mit dem Alphakanalwert der Ursprungsfarbe zusammenhängt.
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 ihre oklch()
-Äquivalente 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 Ursprungsfarbkanalwerte zu <number>
-Werten aufgelöst werden, müssen Sie Zahlen zu diesen hinzufügen, wenn Sie sie in Berechnungen verwenden, auch in Fällen, in denen ein Kanal normalerweise <percentage>
, <angle>
oder andere Werttypen akzeptieren würde. Das Hinzufügen eines <percentage>
zu einem <number>
, beispielsweise, 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
>Anpassung der Helligkeit einer Farbe
Dieses Beispiel zeigt die Wirkung der Variation des L
- (Helligkeits-)Wertes der oklch()
-Funktion.
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
Anpassung der Farbintensität über Chroma
Das folgende Beispiel zeigt die Auswirkung der Variation des C
- (Chroma-)Wertes der oklch()
-Funktion, wobei die Farbsättigung abnimmt, wenn der C
-Wert von vollständig 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 Ausgangsfarben Blau, Rot und Grün definieren wir fortschreitend kleinere Chroma-Werte für sie: beginnend mit voller Farbsättigung beim hohen Wert von 0.4
(entspricht 100%
) bis 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
Hätten wir 0
anstelle von 0.01
und 2%
verwendet, mit denselben Helligkeitswerten, wären die Farben in diesem Beispiel alle in derselben Grauschattierung. In diesem Beispiel sind sie fast grau.
Farbtöne in OkLCh
Das folgende Beispiel zeigt Farbproben mit unterschiedlichen H
- (Farbton-)Werten der oklch()
-Funktion.
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()
. Siehe <hue>
für weitere Informationen. In hsl()
repräsentiert die sRGB-Farbe 0deg
rot. Im CIELab-Farbraum entspricht 0deg
jedoch magenta, während rot ungefähr 41deg
entspricht.
Anpassung des Alphawerts einer Farbe
Das folgende Beispiel zeigt die Auswirkungen der Variation des A
- (Alpha-)Wertes der oklch()
-Farbfunktion. Die red
- und red-alpha
-Elemente überlappen das #background-div
-Element, um den Effekt der Deckkraft zu demonstrieren. Ein Wert von 0.4
für A
macht die Farbe zu 40% undurchsichtig.
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
Verwendung 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 abgedunkelte 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 lassen ihren Helligkeitskanal modifizieren, um den gewünschten Effekt über eine calc()
-Funktion zu erzielen. Die aufgehellte Farbe hat 0.15
(15%) zum Helligkeitskanal hinzugefügt und die abgedunkelte Farbe 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 Farbnationen
- Verwendung relativer Farben
- CSS-Farben Modul
<hue>
Datentyplch()
undoklab()
Farbfunktionen- Interaktiver Beitrag zum OkLCh-Farbraum (2024)
- OKLCH in CSS: warum wir von RGB und HSL gewechselt sind (2024)
- Ein perceptueller Farbraum für die Bildverarbeitung (2020)