Firefox中的SVG过滤器过渡

时间:2012-12-07 05:27:46

标签: css firefox svg css-transitions svg-filters

我试图在悬停时尝试将图像从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);
}

1 个答案:

答案 0 :(得分:3)

因为标准过滤器语法是一个URL,所以它不适合转换。 Gecko必须实现构造shorthands规范的Filter Effects部分才能实现。

与此同时,您可以使用SVG动画,但不能仅通过CSS。