使用Snap.svg的箭头标记的动画的路径

时间:2016-04-12 11:33:38

标签: javascript svg snap.svg svg-animate

我弄清楚如何在末尾用箭头标记设置路径动画。我试图对角线进行动画处理。

您可以在此处查看正在运行的示例:http://codepen.io/danieltnaves/pen/ZWryxm

var animationsPaths = new Array();
animationsPaths.push("M 100 10 L 200 110");
animationsPaths.push("M 100 10 L 230 110");
animationsPaths.push("M 250 110 L 300 10");
animationsPaths.push("M 400 110 L 600 210");
animationsPaths.push("M 700 210 L 800 10");
animationsPaths.push("M 700 210 L 850 110");

var paper = Snap("#paper");

function animatePaths() {
   if (animationsPaths.length == 0) return;
   var line2 = paper.path(animationsPaths[0]);
   var lengthLine2 = line2.getTotalLength();
   console.log(animationsPaths);
   animationsPaths.shift();

   var Triangle = paper.polyline("0,10 5,0 10,10");
   Triangle.attr({
     fill: "#000"
   });  

   var triangleGroup = paper.g( Triangle ); // Group polyline

   Snap.animate(0, lengthLine2 - 1, function( value ) {
      movePoint = line2.getPointAtLength( value );
      triangleGroup.transform( 't' + parseInt(movePoint.x - 15) + ',' +     parseInt(movePoint.y - 15) + 'r' + (movePoint.alpha - 90));
   }, 500,mina.easeinout);


line2.attr({
   stroke: '#000',
   strokeWidth: 2,
   fill: 'none', 
   // Draw Path
   "stroke-dasharray": lengthLine2 + " " + lengthLine2,
   "stroke-dashoffset": lengthLine2
    }).animate({"stroke-dashoffset": 20}, 500, mina.easeinout, animatePaths.bind( this ));
   }

   animatePaths();

谢谢!

1 个答案:

答案 0 :(得分:1)

我首先将三角形居中,然后事情变得更容易......

var Triangle = paper.polyline("-5,5 0,-5 5,5");

http://codepen.io/anon/pen/PNQXbQ