Chrome 未始终如一地渲染 CSS 蒙版图像

Chrome not rendering CSS mask-image consistently

我 运行 遇到了一个奇怪的问题,即 chrome 没有始终如一地应用一些带有蒙版的图像。 (一张图片按预期工作,而另一张图片没有并呈现整个 div)。两个图像在 Firefox 中都按预期工作(当删除 webkit 前缀时)。

在下面的代码笔中,它以 base 64 编码的图像(一只猫)开始,它正确地掩盖了 div,3 秒后设置的超时将掩码更改为心脏图像。此掩码未按预期应用。为了证明它是一个有效的图像,我在 3 秒后(成功)将图像应用为背景图像。

let heartUri = 'url()'

  setTimeout(() => {
      document.getElementById('luminance-target').style['-webkit-mask-image'] = heartUri
  }, 3000)
  setTimeout(() => {
       document.getElementById('luminance-target').style['background-image'] = heartUri
  }, 6000)
 
#luminance-target {
  display: block;
  background-color: yellow;
  -webkit-mask-image: url('');
  -webkit-mask-mode: luminance;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: 100%;
  width: 300px;
  height: 300px;
}
  <div id="luminance-target">
    <h2>Luminance Mask</h2>
  </div>

https://codepen.io/anon/pen/PXYgNg

这是预期的行为吗?

Chrome 对 CSS 掩码的实现是 still incomplete。现阶段不支持luminance模式:

默认模式为alpha。由于您的猫图像具有透明背景,因此效果很好。另一方面,您的心脏图像不会。

下面的演示从您的猫图像开始,然后过渡到您原来的心脏,然后在同一个心脏上完成,但应用了透明度。

为了避免痛苦的数据 URL,我为图像添加了 imgur 链接。

猫:https://i.stack.imgur.com/rnXYp.png
老心:https://i.stack.imgur.com/nbLhD.png
新心:https://i.stack.imgur.com/JnFrp.png

let heartUri = 'url(\'https://i.stack.imgur.com/nbLhD.png\')';
let newHeartUri = 'url(\'https://i.stack.imgur.com/JnFrp.png\')'

 setTimeout(() => {
     document.getElementById('luminance-target').style['-webkit-mask-image'] = heartUri;
 }, 3000);

 setTimeout(() => {
     document.getElementById('luminance-target').style['-webkit-mask-image'] = newHeartUri;
 }, 6000);
 
#luminance-target {
  display: block;
  background-color: yellow;
  -webkit-mask-image: url('https://i.stack.imgur.com/rnXYp.png');
  -webkit-mask-mode: alpha;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: 100%;
  width: 300px;
  height: 300px;
}
<div id="luminance-target">
    <h2>Luminance Mask</h2>
</div>