<blend-mode> - CSS(层叠样式表) 编辑

<blend-mode> 是一种 CSS 数据类型,用于描述当元素重叠时,颜色应当如何呈现。它被用于 background-blend-modemix-blend-mode 属性。

当层重叠时,混合模式是计算像素最终颜色值的方法,每种混合模式采用前景和背景的颜色值,执行其计算并返回最终的颜色值。最终的可见层是对混合层中的每个重叠像素执行混合模式计算的结果。

语法

<blend-mode> 数据类型被定义为下列关键词中的任意一个。

属性值

normal

最终颜色永远是顶层颜色,无论底层颜色是什么。
其效果类似于两张不透明的纸重叠(overlapping)在一起。

<div id="div"></div>
#div {
  width: 300px;
  height: 300px;
  background: url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/br.png'),
              url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/tr.png');
  background-blend-mode: normal;
}

multiply

最终颜色为顶层颜色与底层颜色相乘的结果。
如果叠加黑色层,则最终层必为黑色层,叠加白色层不会造成变化。
其效果类似于在透明薄膜上重叠印刷的两个图像。

<div id="div"></div>
#div {
  width: 300px;
  height: 300px;
  background: url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/br.png'),
              url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/tr.png');
  background-blend-mode: multiply;
}

screen

最终的颜色是反转顶层颜色和底层颜色,将反转后的两个颜色相乘,再反转相加得到的和得到的结果。
黑色层不会造成变化,白色层导致白色最终层。
其效果类似于(被投影仪)投射到投影屏幕上的两个图像。

<div id="div"></div>
#div {
  width: 300px;
  height: 300px;
  background: url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/br.png'),
              url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/tr.png');
  background-blend-mode: screen;
}

overlay

如果底层颜色比顶层颜色深,则最终颜色是 multiply 的结果,如果底层颜色比顶层颜色浅,则最终颜色是 screen 的结果。
此混合模式相当于顶层与底层互换后的 hard-light

<div id="div"></div>
#div {
  width: 300px;
  height: 300px;
  background: url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/br.png'),
              url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/tr.png');
  background-blend-mode: overlay;
}

darken

最终颜色是由每个颜色通道下,顶底两层颜色中的最暗值所组成的颜色。

<div id="div"></div>
#div {
  width: 300px;
  height: 300px;
  background: url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/br.png'),
              url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/tr.png');
  background-blend-mode: darken;
}

lighten

最终颜色是每个颜色通道下,顶底两层颜色中的最亮值所组成的颜色。

<div id="div"></div>
#div {
  width: 300px;
  height: 300px;
  background: url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/br.png'),
              url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/tr.png');
  background-blend-mode: lighten;
}

color-dodge

最终颜色是将底部颜色除以顶部颜色的反色的结果。
黑色前景不会造成变化。前景如果是背景的反色,会得到白色(fully lit color,完全亮起的颜色,应当为白色)。
此混合模式类似于 screen,但是,前景只需要和背景的反色一样亮,最终图像就会变为全白。

<div id="div"></div>
#div {
  width: 300px;
  height: 300px;
  background: url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/br.png'),
              url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/tr.png');
  background-blend-mode: color-dodge;
}

color-burn

最终颜色是反转底部颜色,将反转后的值除以顶部颜色,再反转除以后的值得到的结果。
白色的前景不会导致变化,前景如果是背景的反色,会得到黑色。
此混合模式类似于 multiply,但是,前景只需要和背景的反色一样暗,最终图像就会变为全黑。

<div id="div"></div>
#div {
  width: 300px;
  height: 300px;
  background: url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/br.png'),
              url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/tr.png');
  background-blend-mode: color-burn;
}

hard-light

如果顶层颜色比底层颜色深,则最终颜色是 multiply 的结果,如果顶层颜色比底层颜色浅,则最终颜色是 screen 的结果。
此混合模式相当于顶层与底层互换后的 overlay
其效果类似于在背景层上(用前景层)打出一片刺眼的聚光灯。

<div id="div"></div>
#div {
  width: 300px;
  height: 300px;
  background: url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/br.png'),
              url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/tr.png');
  background-blend-mode: hard-light;
}

soft-light

最终颜色类似于 hard-light 的结果,但更加柔和一些。
此混合模式的表现类似 hard-light
其效果类似于在背景层上(用前景层)打出一片发散的聚光灯。

<div id="div"></div>
#div {
  width: 300px;
  height: 300px;
  background: url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/br.png'),
              url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/tr.png');
  background-blend-mode: soft-light;
}

difference

最终颜色是 两种颜色中较浅的颜色 减去 两种颜色中较深的颜色 得到的结果。
黑色层不会造成变化,而白色层会反转另一层的颜色。

<div id="div"></div>
#div {
  width: 300px;
  height: 300px;
  background: url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/br.png'),
              url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/tr.png');
  background-blend-mode: difference;
}

exclusion

最终颜色类似于 difference,但对比度更低一些。
difference 相同,黑色层不会造成变化,而而白色层会反转另一层的颜色。

<div id="div"></div>
#div {
  width: 300px;
  height: 300px;
  background: url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/br.png'),
              url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/tr.png');
  background-blend-mode: exclusion;
}

hue

最终颜色由顶部颜色的色调和底部颜色的饱和度亮度组成。

<div id="div"></div>
#div {
  width: 300px;
  height: 300px;
  background: url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/br.png'),
              url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/tr.png');
  background-blend-mode: hue;
}

saturation

最终颜色由顶部颜色的色调和底部颜色的饱和度发光度组成。
饱和度为零的纯灰色背景层不会造成变化。

<div id="div"></div>
#div {
  width: 300px;
  height: 300px;
  background: url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/br.png'),
              url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/tr.png');
  background-blend-mode: saturation;
}

color

最终颜色由顶部颜色的色调饱和度和底部颜色的亮度组成。
此效果保留了灰度级别,可用于为前景着色。(The effect preserves gray levels and can be used to colorize the foreground.)

<div id="div"></div>
#div {
  width: 300px;
  height: 300px;
  background: url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/br.png'),
              url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/tr.png');
  background-blend-mode: color;
}

luminosity

最终颜色由顶部颜色的亮度和底部颜色的色调和饱和度组成。
此混合模式相当于顶层与底层互换后的 color

<div id="div"></div>
#div {
  width: 300px;
  height: 300px;
  background: url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/br.png'),
              url('https://www.wenjiangs.com/wp-content/uploads/2020/mozilla/tr.png');
  background-blend-mode: luminosity;
}

混合模式的插值

混合模式之间的更改暂无插值。任何变化都会立即发生。

规范

规范状态备注
Compositing and Blending Level 1
<blend-mode>
Candidate RecommendationInitial definition.

浏览器兼容性

BCD tables only load in the browser

The compatibility table on this page is generated from structured data. If you'd like to contribute to the data, please check out https://github.com/mdn/browser-compat-data and send us a pull request.

另请参阅

其他网站上对各种混合模式的说明与介绍:

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

词条统计

浏览:150 次

字数:19335

最后编辑:7年前

编辑次数:0 次

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文