SVG用法:如何在Firefox中使用不同图形之间的关系

5
我们有一个简单的代码,可以跨浏览器运行:
<html>
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg xmlns="http://www.w3.org/2000/svg"
xmlns:xlink="http://www.w3.org/1999/xlink"
width="200" height="100">

    <circle id="circ" cx="120" cy="40" 
    r="30" fill="green"/>

    <rect id="rect" x="10" y="10"
    width="60" height="60" fill="blue">
        <set attributeName="fill-opacity" to="0.5"
        begin="circ.mouseover" end="circ.mouseout"/>
    </rect>
</svg>

在Firefox浏览器中,当我尝试使用defs块中的元素时,两个矩形之间的关系会丢失。

<html>
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg xmlns="http://www.w3.org/2000/svg"
xmlns:xlink="http://www.w3.org/1999/xlink"
width="200" height="100">
    <defs>
        <circle id="circ" cx="120" cy="40" 
        r="30" fill="green"/>

        <rect id="rect" x="10" y="10"
        width="60" height="60" fill="blue">
            <set attributeName="fill-opacity" to="0.5"
            begin="circ.mouseover" end="circ.mouseout"/>
        </rect>
    </defs>

    <use id="use_circ.rectangles" xlink:href="#circ" />
    <use id="use_rect.rectangles" xlink:href="#rect" />
</svg>

我在这里阅读了一些关于关系的内容http://www.petercollingridge.co.uk/data-visualisation/mouseover-effects-svgs - 实际上是这些话:

请注意,此效果不适用于Firefox Firefox 6及更早版本(我想),这可能是此方法最大的缺点。

我需要按下按钮才能移动(更改)另一个元素。我还尝试创建类似于此的东西,以设置关系效果:

<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>Button</title>

    <script type="text/javascript" language="javascript">
        function turn_right(button, miliSec)
        {
            document.getElementById("circ_left_position").setAttribute('visibility','hidden');

            setTimeout(function() {
                button.parentNode.setAttribute('xlink:href','#rect.right_position');
            }, miliSec);

            document.getElementById("circ_right_position").setAttribute('visibility','visible ');
        }
        function turn_left(button, miliSec)
        {
            document.getElementById("circ_right_position").setAttribute('visibility','hidden ');

            setTimeout(function() {
                button.parentNode.setAttribute('xlink:href','#rect.left_position');
            }, miliSec);

            document.getElementById("circ_left_position").setAttribute('visibility','visible ');
        }
    </script>
</head>

<body style="margin:0; border:0">
    <?xml version="1.0" encoding="UTF-8" standalone="no"?>
    <svg xmlns="http://www.w3.org/2000/svg"
    xmlns:xlink="http://www.w3.org/1999/xlink"
    width="200" height="100">

        <defs>
            <g id="rect.left_position" onclick="turn_right(this,500)">
                <rect x="10" y="10" width="60" height="60" fill="blue"/>

                <circle id="circ_left_position" cx="120" cy="40" r="30" fill="green"/>

                <animateTransform id="trigger1" begin="click"
                attributeName="transform" type="rotate" additive="replace"
                from="0 70 70" to="10 70 70" dur="0.5s" fill="freeze" />
            </g>

            <g id="rect.right_position" onclick="turn_left(this,500)">
                <rect x="10" y="10" width="60" height="60" fill="blue" transform="rotate(10 70 70)"/>
                <circle id="circ_right_position" cx="120" cy="40" r="30" fill="green"/>

                <animateTransform id="trigger1" begin="click"
                attributeName="transform" type="rotate" additive="replace"
                from="0 70 70" to="-10 70 70" dur="0.5s" fill="freeze" />
            </g>
        </defs>

        <use id="positions.rectangles" xlink:href="#rect.left_position" />

    </svg>
</body>

在Chrome和FF中,我们得到不同的结果。此外,我不理解浏览器之间的差异。我相信,存在一个简单的解决方案。


2
很抱歉,SMIL在Firefox中与<use>元素的兼容性不是很好。 - Robert Longson
您IP地址为143.198.54.68,由于运营成本限制,当前对于免费用户的使用频率限制为每个IP每72小时10次对话,如需解除限制,请点击左下角设置图标按钮(手机用户先点击左上角菜单按钮)。 - arrow
1个回答

0

用户不会复制动画,这在 SVG 1.1 中是不被期望的行为(这不是 Firefox 的问题)

SVG 2 中的 Smil 将解决这个问题。

您可以使用脚本克隆每个动画并将它们附加到 use 标签。也许在 onload 事件上。但是我认为这对于您的特定代码集来说可能不起作用,因为指定了一个 id。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接