我正在尝试在较大的静态PNG背景上放置视频的一小部分,并且视频的边缘应该无缝地融合到背景中,即。你应该无法识别视频结束的位置和背景中的静态图像。
但是,我发现每个浏览器都会以不同的方式呈现视频颜色。在Chrome中,它取决于您是否添加任何CSS过滤器(-webkit-filter)属性,例如
filter: saturate(100%)
(根本不应该更改视频)。我创建了这个JSFiddle来演示问题https://jsfiddle.net/bj4hshwz/1/。没有它,它会使视频略微亮一些。使用filter属性,视频更暗/更饱和(在我的情况下匹配背景)。 Firefox正确呈现视频并且与背景匹配,在Safari中,无论您是否添加过滤器,它都会更亮。
有没有办法让Safari中的视频也正确?
答案 0 :(得分:0)
无操作过滤器更改渲染是一个错误。您应该将其报告给浏览器供应商。减少测试用例将有助于解决此问题。
除此之外,视频中的色彩配置文件处理存在问题,而且有点混乱。
网络上的图像和CSS颜色通常在sRGB色彩空间上定位,但视频内部使用了一些其他色彩空间,最常见的是Rec。 709(用于HD)和BT。 601(旧SD电视)。
问题是这些配置文件足够相似,很多软件都不关心它们之间的转换,或转换不正确(这很容易,因为有这么多微妙的不兼容的颜色空间被称为“YUV”)。只有当您尝试完全匹配颜色时(就像您一样),错误才会变得明显。
Rec 709具有gamma~2.4且sRGB具有gamma~2.2,因此不能在它们之间精确转换的软件将使亮度略微偏离。 709/601混淆会稍微改变色调。
要使视频颜色与CSS颜色完全匹配,所有星星必须对齐:
你可以指望Safari正确地完成所有这些,但在其他浏览器中,它通常是无可救药的错误。考虑更改您的设计以隐藏差异?