SVG动画图箭头

时间:2016-11-30 20:19:17

标签: svg svg-animate inline-svg

这是我第一次使用SVG,我想知道是否可以用箭头创建动画线图。我发现了没有箭头的动画线图,带箭头的非动画线图和带箭头的动画直线的多个例子,但不是我想要的。我附上了一些我在下面玩过的代码示例。有谁知道这是否可行/有解决方案?非常感谢!

  1. 动画线缺失箭头(需要箭头): http://codepen.io/alexandraleigh/pen/jVaObd

    # HTML
    <div class="graph__wrapper">
      <svg width="315px" height="107px" viewBox="0 0 315 107" version="1.1">
        <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" sketch:type="MSPage">
          <path d="M2.10546875,95.75 L40.5546875,68.3476562 L55.2109375,81.1796875 L65.2148437,76.3945312 L96.1835937,86.8320312 L131.023438,19.9414062 L142.15625,23.7226562 L183.605469,2.1953125 L211.007812,22.3320312 L234.320312,71.5664062 L234.667969,83.0039062 L244.019531,83.0039062 L247.105469,88.8320312 L312.695312,104.839844" id="Path-1" stroke="white" stroke-width="4" sketch:type="MSShapeGroup" class="path"></path>
        </g>
      </svg>
    </div> 
    
    
    # CSS(Less)
    
    @import "lesshat";
    
    @darkgrey:          #303030;
    
    *{
      box-sizing: border-box;
    }
    
    body{
      background: @darkgrey;
    }
    
    .graph__wrapper{
      width: 400px;
      margin: 30px auto;
      position: relative;
    
      svg{
        position: absolute;
        margin: 36px 0px 0px 15px;
      }
    }
    
    .path {
      stroke-dasharray: 1000;
      stroke-dashoffset: 1000;
      animation: dash 3s ease-in forwards;
      animation-iteration-count: 1;
      animation-delay: 1s;
    }
    
    @keyframes dash {
      to {
        stroke-dashoffset: 0;
      }
    }
    
    .description{
      font-family: "Roboto";
      color:lighten(@darkgrey, 50%);
      text-align: center;
      margin: 40px 0px;
    } 
    
  2. 带箭头的动画直线(需要在路径上的多个点停留): http://codepen.io/alexandraleigh/pen/yVPYrY

  3. 我尝试添加#1到#2的路径描述并且它具有所需的最终图形,只是没有动画: http://codepen.io/alexandraleigh/pen/pNdgWR

  4. 我还尝试将#2中的箭头标记添加到#1,但箭头没有动画: http://codepen.io/alexandraleigh/pen/aBVdVY

  5. 我也可以使用http://snapsvg.io/之类的插件,但是没有看到任何有助于我的情况的工作示例。

1 个答案:

答案 0 :(得分:2)

你可以用offset-motion(旧语法:motion-path)来做到这一点。 请注意,这是一个高度实验性的功能。它目前仅适用于Chrome。更重要的是,我在这里使用“旧”语法,因为这是目前在chrome中工作的,但它很快就会切换到新的systax ......

* {
  box-sizing: border-box;
}
body {
  background: #303030;
}
.graph__wrapper {
  width: 400px;
  margin: 30px auto;
  position: relative;
  svg {
    position: absolute;
    margin: 36px 0px 0px 15px;
  }
}
.path {
  stroke-dasharray: 428;
  stroke-dashoffset: 428;
  animation: dash 3s ease-in forwards;
  animation-iteration-count: 1;
  animation-delay: 1s;
}
@keyframes dash {
  to {
    stroke-dashoffset: 0;
  }
}
@keyframes pm {
  from {
    motion-offset: 0%;
  }
  to {
    motion-offset: 100%
  }
}
#arrow {
  animation: pm 3s ease-in forwards;
  animation-iteration-count: 1;
  animation-delay: 1s;
  motion-path: path('M2.10546875,95.75 L40.5546875,68.3476562 L55.2109375,81.1796875 L65.2148437,76.3945312 L96.1835937,86.8320312 L131.023438,19.9414062 L142.15625,23.7226562 L183.605469,2.1953125 L211.007812,22.3320312 L234.320312,71.5664062 L234.667969,83.0039062 L244.019531,83.0039062 L247.105469,88.8320312 L312.695312,104.839844');
  motion-rotation: auto;
  motion-anchor: center;
}
.description {
  font-family: "Roboto";
  color: lighten(@darkgrey, 50%);
  text-align: center;
  margin: 40px 0px;
}
<div class="graph__wrapper">
  <svg width="315px" height="107px" viewBox="0 0 315 107" version="1.1" style="overflow:visible">
    <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" sketch:type="MSPage">
      <path d="M2.10546875,95.75 L40.5546875,68.3476562 L55.2109375,81.1796875 L65.2148437,76.3945312 L96.1835937,86.8320312 L131.023438,19.9414062 L142.15625,23.7226562 L183.605469,2.1953125 L211.007812,22.3320312 L234.320312,71.5664062 L234.667969,83.0039062 L244.019531,83.0039062 L247.105469,88.8320312 L312.695312,104.839844"
      id="Path-1" stroke="white" stroke-width="4" sketch:type="MSShapeGroup" class="path"></path>



      <polyline id="arrow" points="0,-5 10,0 0,5 1,0" fill="white" />

    </g>
  </svg>
</div>

您也可以使用animateMotion执行此操作,但svg动画很快就会被删除。您迟早要以任何方式重写代码: - (

* {
  box-sizing: border-box;
}
body {
  background: #303030;
}
.graph__wrapper {
  width: 400px;
  margin: 30px auto;
  position: relative;
  svg {
    position: absolute;
    margin: 36px 0px 0px 15px;
  }
}
.path {
  stroke-dasharray: 428;
  stroke-dashoffset: 428;
  animation: dash 3s linear forwards;
  animation-iteration-count: 1;
  animation-delay: 1s;
}
@keyframes dash {
  to {
    stroke-dashoffset: 0;
  }
}
.description {
  font-family: "Roboto";
  color: lighten(@darkgrey, 50%);
  text-align: center;
  margin: 40px 0px;
}
<div class="graph__wrapper">
  <svg width="315px" height="107px" viewBox="0 0 315 107" version="1.1" style="overflow:visible">
    <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" sketch:type="MSPage">
      <path d="M2.10546875,95.75 L40.5546875,68.3476562 L55.2109375,81.1796875 L65.2148437,76.3945312 L96.1835937,86.8320312 L131.023438,19.9414062 L142.15625,23.7226562 L183.605469,2.1953125 L211.007812,22.3320312 L234.320312,71.5664062 L234.667969,83.0039062 L244.019531,83.0039062 L247.105469,88.8320312 L312.695312,104.839844"
      id="Path-1" stroke="white" stroke-width="4" sketch:type="MSShapeGroup" class="path"></path>



      <polyline id="arrow" points="0,-5 10,0 0,5 1,0" fill="white">
        <animateMotion rotate="auto" begin="1s" dur="3s" repeatCount="1" fill="freeze">
          <mpath xlink:href="#Path-1" />
        </animateMotion>
      </polyline>

    </g>
  </svg>
</div>