Firefox 中的 SVG 过滤器转换

Posted

技术标签:

【中文标题】Firefox 中的 SVG 过滤器转换【英文标题】:SVG Filter Transition in Firefox 【发布时间】:2012-11-25 07:07:30 【问题描述】:

我正在尝试将图像从 50% 灰度滤镜过渡到悬停时的无滤镜状态。

但是,过渡在 Firefox 中不起作用。是否可以仅使用 css 在 Firefox 中运行转换?

img 
    filter: url("data:image/svg+xml;utf8,<svg xmlns=\'http://www.w3.org/2000/svg\'><filter id=\'grayscale\'><feColorMatrix type=\'saturate\' values=\'0.5\'/></filter></svg>#grayscale"); /* Firefox 3.5+ */
    filter: gray alpha(opacity=50); /* IE6-9 */
    -webkit-filter: grayscale(50%); /* Chrome 19+ & Safari 6+ */
    -webkit-transition: all .6s ease; /* Fade to color for Chrome and Safari */
    -moz-transition: all .6s ease; 
    -ms-transition: all .6s ease; 
    transition: all .6s ease;
    -webkit-backface-visibility: hidden; /* Fix for transition flickering */

img:hover 
    filter: none;
    -webkit-filter: grayscale(0);

【问题讨论】:

也不适用于 Safari 5 或更低版本。如何添加 Safari 5 支持? 【参考方案1】:

因为标准过滤器语法是一个 url,所以它不适合转换。 Gecko 必须实现 shorthands 部分正在建设中的 Filter Effects 规范才能使其工作。

与此同时,您可以使用 SVG 动画而不是仅通过 CSS 来做到这一点。

【讨论】:

以上是关于Firefox 中的 SVG 过滤器转换的主要内容,如果未能解决你的问题,请参考以下文章

过滤器:mozilla firefox <svg> 的模糊不工作

如何将 SVG 中的 feGaussianBlur 转换为 JavaFX 中的 GaussianBlur 效果?

Safari 错误。当尝试使用模糊过滤器为 svg 转换设置动画时,safari 非常滞后

在某些情况下,SVG在Safari中过滤模糊

Firefox 浏览器中的 SVG 路径元素缩放转换错误

svg下图像标签中的过滤器会降低图像质量吗?