javascript - 内联 SVG 动画 : Compatibility Oddities

标签 javascript xhtml animation html svg

我已经为此工作了一段时间,但似乎还没有找到合适的解决方案。

该页面是带有内联 SVG 的 XHTML,一旦 SVG 完成加载,它就会使用 ECMAscript 进行动画处理。有 0.5 秒的停顿,然后中间的一只眼睛睁开了。它适用于 MacOS X 上的 Safari、Firefox 和 Chrome。

问题是在 Windows 上的 Chrome 中动画不会启动,而在 Opera(在 OS X 上)中动画表现不稳定。

这是怎么回事?!

您可以在 this page 实时查看它.我很想听听您的想法。

以下是最相关的代码:

<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1"
   viewBox="0 0 1200 800"
   preserveAspectRatio="xMidYMid"
   style="width:100%; height:100%; position:absolute; top:0; left:0; z-index:2;"
   onload="startup(evt);"> 
  <script> 
    function startup(evt){
      setTimeout("doEyeOpen(1200,20);",500);
    }
    function doEyeOpen(dur,msrate) {
      eye=document.getElementById("eyehole");
      var totStep = dur/msrate, step=0;
      window.timer = window.setInterval(
        function() {
          var start=580, d1=start-175.087, d2=624.913-start;
          var prog = easeOut(step,totStep);
          var y2=start-(d1*prog);
          var y1=start+(d2*prog);
          var d="M 1200, 800 H 0 V 0 h 1200 V 800 z M 1183.589 400 C 1037.727 400 813.41 "+y1+" 600 "+y1+" C 386.591 "+y1+" 162.274 400 16.412 400 C 162.274  400 386.591 "+y2+" 600 "+y2+" C 813.41 "+y2+" 1037.727 400 1183.589 400 z";
          eye.setAttribute("d", d);
          step++;
          if (step > totStep) {window.clearInterval(window.timer); return}
        } 
      ,msrate)
    }
    function easeOut(step,totStep){
      return (1 - Math.pow(((step/totStep)-1),8));
    }
  </script> 
  <rect fill="#FFF" x="10" y="10" width="1180" height="780" id="white-bg"/> 
  <g id="Iris"> 
    <circle transform="translate(600, 400)" r="260" fill="#e50000" id="c-iris" onclick="changeColor(evt)" /> 
    <circle transform="translate(600, 400)" r="130" fill="#000" id="c-pupil"/> 
  </g> 
  <g id="Gray"> 
    <path fill="#999999" d="M138.363,397.25c0-90.911,26.295-175.674,71.671-247.127H78.419
          c-35.555,74.909-55.457,158.691-55.457,247.124c0,90.606,20.891,176.329,58.105,252.629h132.529
          C166.042,577.29,138.363,490.509,138.363,397.25z"/> 
    <path fill="#999999" d="M1121.58,150.124H989.963c45.377,71.453,71.671,156.216,71.671,247.127
          c0,93.258-27.68,180.039-75.233,252.626h132.53c37.215-76.3,58.107-162.023,58.107-252.629
          C1177.039,308.815,1157.137,225.033,1121.58,150.124z"/> 
  </g> 
  <clipPath id="CP"
            clip-rule="evenodd"> 
    <path id="eyehole"
          d="M 1200, 800 H 0 V 0 h 1200 V 800 z
          M 1183.589 400 C 1037.727 400 813.41 400.000 600 400.000 C 386.591 400.000 162.274 400 16.412 400
          C 162.274  400 386.591 400.000 600 400.000 C 813.41 400.000 1037.727 400 1183.589 400 z"/> 
  </clipPath> 
  <rect fill="#000" x="0" y="0" width="1200" height="800" id="black-cover" clip-path="url(#CP)"/> 
</svg>

最佳答案

启动方法似乎在 Opera 中被调用了两次,我已经就此提交了错误报告 (CORE-31399)。一种解决方法可能是仅使用一个内联 svg 片段,或者在启动函数中设置一个条件,这样您就不会启动两个计时器(我认为这是导致奇怪的渲染行为的原因)。

关于javascript - 内联 SVG 动画 : Compatibility Oddities,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3251048/

相关文章:

ios - AVPlayer replaceCurrentItemWithPlayerItem 打破 UIViewAnimation

JavaScript 创建元素然后添加一个事件

javascript - 如果在移动设备上滚动,则防止点击链接

xhtml - rel= 属性可以包含任何字符串字符并且仍然有效吗?

java - 删除 &lt;!-- 和//--> 之间的内容

javascript - 宽度动态 div 容器

Css3 背景图像动画动画太快

c - 如何仅使用 GTK3、C 和 Cairo 制作基本动画

javascript - 如何使用 javascript 打开文件/浏览对话框?

javascript - Qt QML 如何格式化(突出显示)文本