首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用Anime.JS,如何将动画应用于svg的特定元素/路径?

使用Anime.JS,如何将动画应用于svg的特定元素/路径?
EN

Stack Overflow用户
提问于 2022-02-09 16:21:06
回答 1查看 193关注 0票数 0

我已经编写了一些代码来旋转整个svg,但是我不知道如何旋转各个主体。

代码语言:javascript
运行
复制
<!DOCTYPE html>
<html lang="en">

<head>
  <div class="content">

    <object id="demo-svg" data="./assets/test-graphic.svg" type="image/svg+xml" width="100%" height="100%"></object>

    <script src="https://cdn.jsdelivr.net/npm/animejs@3.0.1/lib/anime.min.js"></script>

    <script type="text/css">

      body, html{ margin:0 } svg, g { transform-origin: unset unset; } path { transform-origin: 50% 50%; transform-box: fill-box; }

    </script>
  </div>

</head>

<div>

  <script>
    anime({
      targets: 'path',
      scale: [0.1, 1],
      opacity: [0.1, 1],
      rotate: "1turn",
      duration: 7000
    });
  </script>


</div>

</html>

整个svg代码太大了,无法粘贴,下面是一个片段

代码语言:javascript
运行
复制
<linearGradient id="linear-gradient" x1="69" y1="559.5" x2="1875" y2="559.5" gradientUnits="userSpaceOnUse"><stop offset="0" stop-color="#22b226"/><stop offset="1" stop-color="#2112b5"/>

对于上下文,此梯度对指向下面的路径。

代码语言:javascript
运行
复制
<path d="M657,540a3,3,0,0,0-3,3v33a3,3,0,0,0,6,0V543A3,3,0,0,0,657,540Z" transform="translate(-69 -56)" fill="url(#linear-gradient)"/>
EN

回答 1

Stack Overflow用户

发布于 2022-04-08 07:28:29

如果你想把目标对准一个单独的部分,那就瞄准一个单独的部分。给他们一个身份证或其他一些方法来指代他们,然后发狂。

代码语言:javascript
运行
复制
var tl = anime.timeline({
    duration: 700,
    easing: "easeOutElastic(1, 1)",
    endDelay: 400,
    loop: true
  })
  .add({
    targets: "svg",
    scale: [0, 1]
  })
  .add({
    targets: ".eye",
    scaleY: [1, 0, 1, 0, 1],
    easing: "easeInOutSine"
  });

for (i = 0; i < 10; i++)
  tl.add({
    targets: ".pupil",
    translateX: anime.random(-12, 12),
    translateY: anime.random(-12, 12)
  });

tl.add({
  targets: "svg",
  scale: 0,
  easing: "easeInElastic(1, 1)",
  endDelay: 1000
});
代码语言:javascript
运行
复制
<script src="https://cdnjs.cloudflare.com/ajax/libs/animejs/3.2.1/anime.min.js"></script>
<svg width="100vmin" height="100vmin" viewBox="0 0 120 120">
  <circle cx="60" cy="60" r="40" stroke-width="6" stroke="#1F1F1F" fill="#AF87CC" transform-origin="60 60" />
  <g class="eye" transform-origin="60 60">
    <circle class="pupil" cx="60" cy="60" r="24" />
    <circle cx="77" cy="43" r="10" fill="#FFFFFF" />
  </g>
</svg>

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71053136

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档