一篇文章带你了解SVG <Animation> 动画元素

开发 前端
SVG <Animation> 动画元素用于为SVG图形制作动画。动画元素最初是在同步多媒体集成语言(SMIL)中定义的。在动画中,必须指定属性,运动,颜色,动画的开始时间和动画的持续时间的开始和结束值。

[[355648]]

SVG <Animation> 动画元素用于为SVG图形制作动画。动画元素最初是在同步多媒体集成语言(SMIL)中定义的。在动画中,必须指定属性,运动,颜色,动画的开始时间和动画的持续时间的开始和结束值。

可以对SVG图像中的形状进行动画处理。有几种不同的动画SVG形状的方法。

一、SVG动画

这是一个简单的SVG动画。

  1. <svg xmlns="http://www.w3.org/2000/svg" 
  2.     xmlns:xlink="http://www.w3.org/1999/xlink"
  3.  
  4.     <rect x="10" y="10" height="110" width="110" 
  5.          style="stroke:#ff0000; fill: #0000ff"
  6.  
  7.         <animateTransform 
  8.             attributeName="transform" 
  9.             begin="0s" 
  10.             dur="20s" 
  11.             type="rotate" 
  12.             from="0 60 60" 
  13.             to="360 60 60" 
  14.             repeatCount="indefinite" 
  15.         /> 
  16.     </rect> 
  17.  
  18. </svg> 

运行效果:

注意<rect>元素如何在元素 <animateTransform>内部嵌套。正是这个元素使矩形动画化。

二、动画选项概述

这些SVG动画元素中的每一个都设置或设置SVG形状的不同方面的动画。这些动画元素将在本文的其余部分中进行说明。

1. set

该set元素是SVG动画元素中最简单的元素。在经过特定时间间隔后,它只是将属性设置为特定值。因此,形状不会连续进行动画处理,而只是更改属性值一次。

这是一个<set>元素示例:

  1. <svg width="500"  height="100"
  2.   <circle cx="30" cy="30" r="25" style="stroke: none; fill: #0000ff;"
  3.     <set attributeName="r" attributeType="XML" 
  4.          to="100" 
  5.          begin="5s"  /> 
  6.  
  7. </circle> 
  8. </svg> 

注:

<set>元素在特定时间设置属性的值。要设置的属性名称在attributeName属性中指定。将其设置为的值在to属性中指定。设置属性值的时间在begin属性中指定。

运行效果:(r在5秒钟后将属性设置为100):

2. attributeType

可以设置形状的CSS属性的动画。如果这样做,则需要将attributeType设置为CSS。如果不提供attributeType属性,则浏览器将尝试猜测要制作动画的属性是XML属性还是CSS属性。

3. animate

animate元素用于为SVG形状的属性设置动画。可以将animate元素嵌套在要应用的形状内。

示例

  1. <svg width="500"  height="100"
  2.   <circle cx="30" cy="30" r="25" style="stroke: none; fill: #0000ff;"
  3.     <animate attributeName="cx" attributeType="XML" 
  4.              from="30"  to="470" 
  5.              begin="0s" dur="5s" 
  6.              fill="remove" repeatCount="indefinite"/> 
  7.   </circle> 
  8. </svg> 

运行效果:

解析:

此示例将<circle>元素的cx属性从值30(“from”属性)设置为值479(“to”属性)的动画。动画从0秒开始(“begin”属性),持续时间为5秒(“dur”属性)。

动画完成后,动画属性将设置回其原始值(fill=“remove”属性设置)。如果希望动画属性保持动画的“到”值(to-value),请将“fill ”属性设定为“freeze”。动画无限期重复(“repeatCount”属性)。

4. animateTransform

<Animate>元素不能做到这一点,<AnimateTransform>元素可以为形状的Transform属性设置动画。

例:

  1. <svg width="500" height="100"
  2.             <rect x="20" y="20" width="100" height="40" style="stroke: #ff00ff; fill:none;"
  3.                 <animateTransform attributeName="transform" type="rotate" from="0 100 100" to="360 100 100" begin="0s" dur="10s" 
  4.                  repeatCount="indefinite" /> 
  5.             </rect> 
  6.         </svg> 

运行效果:

解析:

例中对嵌套transform其中的<rect>元素的属性进行动画处理。该type属性设置为rotate(旋转变换功能),表示动画变换将是旋转。在from和to属性设定的参数进行动画,并传递给rotate函数。本示例围绕点100,100从0度旋转到360度。

使正方形的比例动画化。

示例

  1. <svg width="500" height="200"
  2.             <rect x="20" y="20" width="40" height="40" style="stroke: #FF0000; fill: none;"
  3.                 <animateTransform attributeName="transform" type="scale" from="1 1" to="2 3" begin="0s" dur="10s" repeatCount="indefinite"
  4.         </animateTransform> 
  5.             </rect> 
  6. </svg> 

运行效果:

注:

from 和 to 属性包含通常作为参数传递给scale()转换函数的值。

三、总结

本文基于HTML基础,介绍了SVG中<Animation>元素。对每一种动画的效果进行详细讲解。每一种动画中都采用静态图解析的方式来呈现动态运用的效果。通过具体的案例分析,能够让读者更好的理解。

欢迎大家积极尝试,有时候看到别人实现起来很简单,但是到自己动手实现的时候,总会有各种各样的问题,切勿眼高手低,勤动手,才可以理解的更加深刻。

代码很简单,希望对你学习有帮助。

本文转载自微信公众号「前端进阶学习交流」,可以通过以下二维码关注。转载本文请联系前端进阶学习交流公众号。

 

责任编辑:武晓燕 来源: 前端进阶学习交流
相关推荐

2020-12-25 09:42:51

SVGtspanSVG基础

2021-01-01 09:18:48

SVG图像元素

2020-12-29 09:39:38

元素属性定位

2020-12-08 08:09:49

SVG图标Web

2021-02-26 20:01:57

SVG滤镜元素

2022-05-13 16:21:38

javascrip脚本SVG

2021-01-04 10:14:42

SVG标签元素

2021-03-26 09:57:51

SVGHtml基础SVG图像

2020-12-15 08:15:34

SVG元素路径

2021-02-05 18:36:15

SVG形状属性

2020-12-23 08:12:08

javascriptSVG脚本SVG元素

2021-02-23 06:51:16

SVGstrokeHtml基础

2020-12-11 08:39:14

SVG代码剪切

2021-05-07 14:17:01

JavaScript元素网页

2021-06-30 00:20:12

Hangfire.NET平台

2023-05-12 08:19:12

Netty程序框架

2021-06-04 09:56:01

JavaScript 前端switch

2021-02-02 18:39:05

JavaScript

2020-11-10 10:48:10

JavaScript属性对象

2021-01-29 18:41:16

JavaScript函数语法
点赞
收藏

51CTO技术栈公众号