广告
返回顶部
首页 > 资讯 > 前端开发 > html >如何实现svg动画
  • 996
分享到

如何实现svg动画

2024-04-02 19:04:59 996人浏览 薄情痞子
摘要

这篇文章主要为大家展示了“如何实现svg动画”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何实现svg动画”这篇文章吧。   一、SVG 的 animati

这篇文章主要为大家展示了“如何实现svg动画”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何实现svg动画”这篇文章吧。

  一、SVG 的 animation

  SVG animation 有五大元素,他们控制着各种不同类型的动画,分别为:

  set

  animate

  animateColor

  animateTransfORM

  animateMotion

  set 为动画元素设置延迟,此元素是SVG中最简单的动画元素,但是他并没有动画效果。

  使用语法:

  attributeName :是要改变的元素属性名称。

  attributeType :是表明attributeName属性值的列表,支持三个固定参数 CSS/XML/auto,如x,y以及transform属于XML,opacity属于CSS。auto是浏览器自动判别的意思,也是默认值,如果你不知道该选哪个就填auto,浏览器自己判别。

  to :动画结束的属性值。

  begin :动画延迟时间。

  eg:绘制一个半径为200的圆,4秒之后,半径变为50。

  <svg width="320" height="320">

  <circle cx="0" cy="0" r="200" style="stroke: none; fill: #0000ff;">

  <set attributeName="r" attributeType="XML" to="50" begin="4s" />

  </circle>

  </svg>

  ?

  是基础的动画元素,实现单属性的过渡效果。

  使用语法:

  from :过渡效果的属性开始值。

  to:过渡效果的属性结束值。

  begin:动画开始时间。

  dur:动画过渡时间,控制动画速度。

  repeatCount:动画重复次数。

  eg:绘制一个半径为200的圆,4秒之后半径在2秒内从200逐渐变为50。

  <circle cx="0" cy="0" r="200" style="stroke: none; fill: #0000ff;">

  <animate attributeName="r" from="200" to="50"

  begin="4s" dur="2s" repeatCount="2"></animate>

  </circle>

  ?

  控制颜色动画,animate也可以实现这个效果,所以该属性目前已被废弃。

  实现transform变换动画效果,与css3的transform变换类似。实现平移、旋转、缩放等效果。

  使用语法:

  repeatCount:重复次数,设置为 indefinite 表示无限循环,一直执行。

  type:添加 transform 变换类型。

  eg:绘制一个半径为200的圆,4秒之后开始缩放,在2秒内从1.5缩小到0倍。

  <svg width="320" height="320">

  <circle cx="0" cy="0" r="200" style="stroke: none; fill: #0000ff;">

  <animateTransform attributeName="transform" begin="4s"

  dur="2s" type="scale" from="1.5" to="0"

  repeatCount="indefinite"></animateTransform>

  </circle>

  </svg>

  可以定义动画路径,让SVG各个图形,沿着指定路径运动。

  使用语法:

  path:定义路径,使用语法与《HTML5(八)&mdash;&mdash;SVG 之 path 详解》path的d属性一致。

  begin:延迟时间。

  dur:动画执行时间。

  eg:绘制一个半径为10的圆,延迟4秒从左上角运动的右下角。

  <svg width="320" height="320">

  <circle cx="0" cy="0" r="10" style="stroke: none; fill: #0000ff;">

  <animateMotion

  path="M 0 0 L 320 320"

  begin="4s" dur="2s"

  ></animateMotion>

  </circle>

  </svg>

  ?

  实际制作动画的时候,动画太单一不酷,需要同时改变多个属性时,上边的四种元素可以互相组合,同类型的动画也能组合。以上这些元素虽然能够实现动画,但是无法动态地添加事件,所以接下来我们就看看 js 如何制作动画。

  二、javascript 控制

  上篇文章我们介绍js可以操作path,同样也可以操作SVG的内置形状元素,还可以给任意元素添加事件。

  给SVG元素添加事件方法与普通元素一样,可以只用on+事件名 或者addEventListener添加。

  eg:使用SVG绘制地一条线,点击线条地时候改变 x1 ,实现旋转效果。

  <svg width="800" height="800" id="svg">

  <line id="line" x1="100" y1="100"

  x2="400" y2="300"

  stroke="black" stroke-width="5"></line>

  </svg>

  <script>

  window.onload=function(){

  var line=document.getElementById("line")

  line.onclick=function(){

  let start=parseInt(line.getAttribute("x1")),

  end=400,dis=start-end

  requestAnimationFrame(next)

  let count=0;

  function next(){

  count++

  let a=count/200,cur=Math.abs(start+ dis*a)

  line.setAttribute('x1',cur)

  if(count<200)requestAnimationFrame(next)

  }

  }

  }

  </script>

  ?

  js制作的SVG动画,主要利用 requestAnimationFrame 来实现一帧一帧的改变。

  我们上述制作的 SVG 图形、动画等,运行在低版本IE中,发现SVG只有IE9以上才支持,低版本的并不能支持,为了兼容低版本浏览器,可以使用 VML ,VML需要添加额外东西,每个元素需要添加 v:元素,样式中还需要添加 behavier ,经常用于绘制地图。由于使用太麻烦,所以我们借助 Raphael.js 库。

  三、Rapha?l.js (拉斐尔)

  Raphael.js是通过SVG/VML+js实现跨浏览器的矢量图形,在IE浏览器中使用VML,非IE浏览器使用SVG,类似于Jquery,本质还是一个javascript库,使用简单,容易上手。

  使用之前需要先引入Raphael.js库文件。cdn的地址为:

  Rapheal有两种创建画布的方式:

  第一种:浏览器窗口上创建画布

  创建语法:

  var paper=Raphael(x,y,width,height)

  x,y是画布左上角的坐标,此时画布的位置是绝对定位,有可能会与其他html元素重叠。width、height是画布的宽高。

  第二种:在一个元素中创建画布

  创建语法:

  var paper=Raphael(element, width, height);

  element是元素节点本身或ID width、height是画布的宽度和高度。

  画布创建好之后,该对象自带SVG内置图形有矩形、圆形、椭圆形。他们的方法分别为:

  paper.circle(cx, cy, r); // (cx , cy)圆心坐标 r 半径

  paper.rect(x, y, width, height, r); // (x,y)左上角坐标 width宽度 height高度 r圆角半径(可选)

  paper. ellipse(cx, cy, rx, ry); // (cx , cy)圆心坐标 rx水平半径 ry垂直半径

  eg:在div中绘制一个圆形,一个椭圆、一个矩形。

  <div id="box"></div>

  <script>

  var paper=Raphael("box",300,300)

  paper.circle(150,150,150)

  paper.rect(0,0,300,300)

  paper.ellipse(150,150,100,150)

  </script>

  ?

  运行结果如下:

  ?

  除了简单图形之外,还可以绘制复杂图形,如三角形、心型,这时就使用path方法。

  使用语法:paper.path(pathString)

  pathString是由一个或多个命令组成,每个命令以字母开始,多个参数是由逗号分隔。

  eg:绘制一个三角形。

  还可以绘制文字,如果需要换行,使用 \n 。

  文字语法:paper.text(x,y,text)

  (x,y)是文字坐标,text是要绘制的文字。

  图形绘制之后,我们通常会添加stroke、fill、stroke-width等让图形更美观,Raphael使用attr给图形设置属性。

  使用语法:circle.attr()

  如果只有属性名没有属性值,则是获取属性,如果有属性值,则是设置属性。

  注意:如果只设置一个属性时,可以省略&lsquo;{}&rsquo;。如:rect.attr('fill','pink')

  eg:给上边的矩形添加边框和背景色。

  <div id="box"></div>

  <script>

  var paper=Raphael("box",300,300)

  let rect=paper.rect(100,100,150,200)

  rect.attr({'fill':'red','stroke':'blue','stroke-width':'10'})

  </script>

  ?

  RaphaelJS一般具有以下事件:

  click、dblclick、drag、hide、hover、mousedown、mouseout、mouseup、mouseover等以及对应的解除事件,只要在前面加上“un”就可以了(unclick、undblclick)。

  使用语法:

  animate为指定图形添加动画并执行。

  使用语法:

  属性名和属性值就根据你想要的动画类型加就ok。

  time:动画所需时间。

  type:指动画缓动类型。常用值有:

  linear - 线性渐变

  ease-in | easeIn | < - 由慢到快

  ease-out | easeOut | > - 由快到慢

  ease-in-out | easeInOut | <> - 由慢到快再到慢

  back-in | backIn - 开始时回弹

  back-out | backOut - 结束时回弹

  elastic - 橡皮筋

  bounce - 弹跳

  eg:点击矩形,矩形缓缓变大。

  <div id="box"></div>

  <script>

  var paper=Raphael("box",800,500)

  let rect=paper.rect(100,100,150,100)

  rect.attr({'fill':'red','stroke':'blue','stroke-width':'10'})

  rect.attr('fill','pink')

  rect.click(function(){

  rect.animate({

  "width":300,

  "height":300

  },1000,"bounce")

  })

  </script>

  ?

  复制上边的代码,分别在各个浏览器和低版本IE浏览器运行,发现都可以正常运行。SVG的动画库挺多了,我们介绍了拉斐尔,有兴趣的小伙伴可以自行找找其他库。

以上是“如何实现svg动画”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网html频道!

--结束END--

本文标题: 如何实现svg动画

本文链接: https://www.lsjlt.com/news/91947.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何实现svg动画
    这篇文章主要为大家展示了“如何实现svg动画”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何实现svg动画”这篇文章吧。   一、SVG 的 animati...
    99+
    2022-10-19
  • SVG如何实现描边动画
    这篇文章给大家分享的是有关SVG如何实现描边动画的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。效果如下:代码如下:<!DOCTYPE html> <h...
    99+
    2022-10-19
  • 如何实现基于CSS动画的SVG按钮
    这篇文章给大家分享的是有关如何实现基于CSS动画的SVG按钮的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。具体代码如下所示:<a href="#&quo...
    99+
    2022-10-19
  • SVG怎么实现复杂线条动画
    本篇内容介绍了“SVG怎么实现复杂线条动画”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!事物都是朝着熵增焓...
    99+
    2022-10-19
  • 如何利用SVG和CSS3实现边框动画效果
    本篇内容主要讲解“如何利用SVG和CSS3实现边框动画效果”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何利用SVG和CSS3实现边框动画效果”吧!今天我们来...
    99+
    2022-10-19
  • 如何使用CSS3实现SVG路径描边动画效果
    这篇文章将为大家详细讲解有关如何使用CSS3实现SVG路径描边动画效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。不依赖javascript,直接使用纯css实现 svg 的描边绘制动画效果,效果演示动...
    99+
    2023-06-08
  • SVG如何制作地图旋转动画
    这篇文章主要介绍SVG如何制作地图旋转动画,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!<!DOCTYPE html> <html > &...
    99+
    2022-10-19
  • html中如何使用SVG实现画走势图
    这篇文章主要介绍html中如何使用SVG实现画走势图,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!先说说viewBox是干嘛的,就是按比例缩放视图的。用图形来表示<svg&nb...
    99+
    2022-10-19
  • 如何使用SVG 画线
    本篇内容主要讲解“如何使用SVG 画线”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用SVG 画线”吧!SVG <line>元素是一个SVG基...
    99+
    2022-10-19
  • 如何使用SVG画圆形
    小编给大家分享一下如何使用SVG画圆形,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!SVG  <circle&g...
    99+
    2022-10-19
  • CSS3动画如何实现
    本篇内容主要讲解“CSS3动画如何实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“CSS3动画如何实现”吧!我们先来看看示例 注意: 这里呢,我们用 my...
    99+
    2022-10-19
  • 如何实现Flutter动画
    这篇文章主要为大家展示了“如何实现Flutter动画”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何实现Flutter动画”这篇文章吧。动画中的三大核心为了能够实现动画效果,必须提供下面的三个...
    99+
    2023-06-04
  • Angular如何实现动画
    这篇文章给大家分享的是有关Angular如何实现动画的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。在实现的过程上,我采用了两种不同的 Angular 动画的方式:使用 TypeS...
    99+
    2022-10-19
  • css3如何实现动画
    css3实现动画的方法:1、在通过transition设置过渡,添加transform设置形状,从而可以实现动画效果;2、添加animation属性,设置动画效果即可。具体使用示例:通过transition设置过渡,添加transform设...
    99+
    2022-10-10
  • 如何使用SVG 画多边形
    这篇文章主要讲解了“如何使用SVG 画多边形”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用SVG 画多边形”吧!一、 Polygon 画多边形简单的...
    99+
    2022-10-19
  • javascript如何实现帧动画
    小编给大家分享一下javascript如何实现帧动画,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!概述【分类】常见的帧动画的方式...
    99+
    2022-10-19
  • uniapp 如何实现canvas动画
    随着移动端应用的不断发展,动画已经成为了现代应用的必备元素。而canvas作为HTML5中提供的一种绘图技术,被广泛应用于实现各种复杂的动画效果。而今,随着uniapp的流行,我们也可以借助uniapp的强大能力,轻松实现canvas动画效...
    99+
    2023-05-22
  • JavaScript如何实现window动画
    这篇文章主要介绍了JavaScript如何实现window动画,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。requestAnimationFrame:window动画win...
    99+
    2023-06-03
  • Android如何实现背景动画
    这篇文章主要介绍了Android如何实现背景动画,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体如下:先创建动画层,有三张图片<xml version=&q...
    99+
    2023-05-30
    android
  • 如何实现动画CSS边框
    这篇文章给大家分享的是有关如何实现动画CSS边框的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。动画CSS边框当我们想使我们的项目更可见时,该怎么办来给它做个动画!我们可以对我们的边框进行动画化处理,甚至在不改变元...
    99+
    2023-06-27
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作