The <color-interpolation-method> CSS data type represents the color space used for interpolation between {{CSSXref("<color>")}} values. It can be used to override the default interpolation color space for color-related functional notations such as {{CSSXref("color_value/color-mix", "color-mix()")}} and {{CSSXref("gradient/linear-gradient", "linear-gradient()")}} .
When interpolating <color> values, the interpolation color space defaults to Oklab.
Syntax
The <color-interpolation-method> specifies whether interpolation should use a rectangular color space or a polar color space with an optional hue interpolation method:
in <rectangular-color-space>
// or
in <polar-color-space>[ <hue-interpolation method>]
Values
-
<rectangular-color-space>- : One of the keywords
srgb,srgb-linear,display-p3,a98-rgb,prophoto-rgb,rec2020,lab,oklab,xyz,xyz-d50, orxyz-d65.
- : One of the keywords
-
<polar-color-space>- : One of the keywords
hsl,hwb,lch, oroklch.
- : One of the keywords
-
{{CSSXref("<hue-interpolation-method>")}}{{optional_inline}}- : The algorithm for hue interpolation. It defaults to
shorter hue.
- : The algorithm for hue interpolation. It defaults to
-
<custom-color-space>- : A
<dashed-ident>referring to a custom @color profile.
- : A
Formal syntax
{{CSSSyntax}}
Examples
Comparing interpolation color spaces using gradients
The following example shows the effect of using different interpolation color spaces for {{CSSXref("gradient/linear-gradient", "linear-gradient()")}} .
HTML
<div>sRGB:</div>
<div class="gradient srgb"></div>
<div>Oklab:</div>
<div class="gradient oklab"></div>
<div>Oklch (with <code>longer hue</code>):</div>
<div class="gradient oklch-longer"></div>
CSS
.gradient {
height: 50px;
width: 100%;
}
.srgb {
background-image: linear-gradient(in srgb to right, blue, red);
}
.oklab {
background-image: linear-gradient(in oklab to right, blue, red);
}
.oklch-longer {
background-image: linear-gradient(in oklch longer hue to right, blue, red);
}
Result
{{EmbedLiveSample("comparing_interpolation_color_spaces_using_gradients", "100%", 250)}}
Color interpolation in repeating gradients
The following example shows how to specify a color space when interpolating colors in repeating gradients.
Three boxes show different types of repeating gradients using the repeating-conic-gradient(), repeating-linear-gradient(), and repeating-radial-gradient() functions.
The first box uses the Lab color space to interpolate between two color values.
The second and third boxes use OkLCh and additionally provide a <hue-interpolation-method> to specify how to interpolate between hue values.
HTML
<div class="gradient conic">conic</div>
<div class="gradient linear">linear</div>
<div class="gradient radial">radial</div>
CSS
We used the same two colors in each gradient to demonstrate the different effects of <hue-interpolation-method> and {{glossary("color space")}} on color interpolation in gradients.
.gradient {
height: 200px;
width: 200px;
display: inline-block;
font-family: monospace;
margin: 10px;
font-size: 16px;
}
.conic {
background-image: repeating-conic-gradient(
in lab,
burlywood,
blueviolet 120deg
);
}
.linear {
background-image: repeating-linear-gradient(
in oklch,
burlywood,
blueviolet 75px
);
}
.radial {
background-image: repeating-radial-gradient(
in oklch longer hue,
blueviolet 50px,
burlywood 100px
);
}
Result
{{EmbedLiveSample("hue_interpolation_in_repeating_gradients", "100%", 250)}}
Comparing the first and second boxes demonstrates the difference of interpolating between two colors in differing color spaces.
Comparing the second and third boxes shows the difference between <hue-interpolation-method>s, with the linear gradient using the shorter method (default) and the radial gradient using the longer method.
Specifications
{{Specifications}}
Browser compatibility
{{Compat}}
See also
{{CSSXref("<color>")}},{{CSSXref("<gradient>")}}{{CSSXref("<hue-interpolation-method>")}}