首页 > 其他分享 >前端绘图方式Canvas和SVG的区别

前端绘图方式Canvas和SVG的区别

时间:2022-10-26 16:34:23浏览次数:87  
标签:Canvas SVG 绘图 标签 图形 绘制

前端绘图方式Canvas和SVG的区别
Canvas和SVG是html5中支持2种可视化技术,都是可以在画布上绘制图形和放入图片。下面来介绍和分析一下他们。

一.Canvas 和 SVG 简介

1.什么是Canvas?

Canvas 是H5新出来的标签

Canvas画布,利用JavaScript在网页绘制图像

在标签中给上宽高: 不用加单位

如果在css中给宽高 会对图像造成拉伸 (默认宽高300px*150px)

通过过去绘制工具 .getContext(“2d”) 来在画布中绘制图形

2.什么是SVG?

SVG 可缩放矢量图形(Scalable Vector Graphics),基于可扩展标记语言XML 出来的时间比较老

SVG 用来定义用于网格的基于矢量的图形

二.Canvas 和 SVG 区别

1.绘制的图片格式不同

Canvas 的工具getContext 绘制出来的图形或传入的图片都依赖分辨率,能够以 .png 和 .jpg格式保存存储图像,可以说是位图

SVG 可以在H5中直接绘制,但绘制的是矢量图

由于位图依赖分辨率,矢量图不依赖分辨率,所以Canvas和SVG的图片格式的不同实际上是他们绘制出来的图片的格式不同造成的。

2.Canvas不支持事件处理器,SVG支持事件处理器

Canvas 绘制的图像 都在Canvas这个画布里面,是Canvas的一部分,不能用js获取已经绘制好的图形元素。

如下:

 


在控制台中可以看到canvas标签里面是没有单独的长方形存在的。

Canvas就像动画,每次显示全部的一帧的内容,想改变里面某个元素的位置或者变化需要在下一帧中全部重新显示。

而SVG绘图时,每个图形都是以DOM节点的形式插入到页面中,可以用js或其他方法直接操作

如下:

效果:


可以看出svg 标签下面多了两个矩形的标签

下面我们来操作新出来的矩形标签:

给上rect标签id r1 和 r2

获取元素

var rect1 = document.getElementById(“r1”);

var rect2 = document.getElementById(“r2”);

改变元素的填充颜色:

rect1.style.fill = “yellow”;

rect2.style.fill = “pink”;

效果:

 

SVG 中 每个被绘制的图形都被视为对象,如果SVG对象的属性发生变化,那么浏览器能够自动重现图形。

3.适用范围不同

由于Canvas 和 SVG 的工作机制不同,

Canvas是逐像素进行渲染的,一旦图形绘制完成,就不会继续被浏览器关注。而SVG是通过DOM操作来显示的。

所以Canvas的文本渲染能力弱,而SVG最适合带有大型渲染区域的应用程序,比如地图。

而Canvas 最适合有许多对象要被频繁重绘的图形密集型游戏。

而SVG由于DOM操作 在复杂度高的游戏应用中 会减慢渲染速度。所以不适合在游戏应用。
————————————————
参考:前端绘图方式Canvas和SVG的区别

标签:Canvas,SVG,绘图,标签,图形,绘制
From: https://www.cnblogs.com/aspirant/p/16828903.html

相关文章

  • vue使用canvas合成海报
    接着上面随笔,继续探索~~~上篇合成海报的过程有点负责冗余。完全可以不借助插件,用canvas合成~~需求背景:多张模版可供选择,用户输入姓名,上传头像,最终合成海报保存分享。1.头像有......
  • html2Canvas 前端保存页面为图片
    html2canvas 能够实现在用户浏览器端直接对整个或部分页面进行截屏。这个html2canvas脚本将当页面渲染成一个canvas图片,通过读取DOM并将不同的样式应用到这些元素上实现。......
  • 小程序使用svga
     svga是一种动画格式。不仅可以在ios,android,flutter,web上使用,小程序也支持。设计师使用aftereffects或是animate进行动画设计。设计师导出工具给我们svga动......
  • [FAQ] 如何从 svg 字符串创建 SVGElement
     HTML部分:<divstyle="display:none"id="svgCon"></div>JS部分:constsvgCon=document.getElementById('svgCon')svgCon.innerHTML='<svg>xxxxx';consts......
  • Canvas和svg的一些区别
    区别:1.Canvas使用笔刷来绘制2D图形,而svg主要是用标签来绘制不规则矢量图的2.Canvas画的是位图(放大会模糊),svg话的是矢量图(放大不会失真)3.Canvas性能好一些,但写起来更为复......
  • Matlab绘图高级部分
    图形是呈现数据的一种直观方式,在用Matlab进行数据处理和计算后,我们一般都会以图形的形式将结果呈现出来。尤其在论文的撰写中,优雅的图形无疑会为文章加分。本篇文章非完全......
  • HTML 画布 <canvas>
    HTML5<canvas>标签用于绘制图像(通过脚本,通常是JavaScript),getContext("2d")对象的属性和方法,可用于在画布上绘制文本、线条、矩形、圆形等等。颜色、样式和阴影属性......
  • matplotlib绘图之中文标题、坐标轴标签乱码问题
    importmatplotlib.pyplotaspltimportmatplotlibasmpl#解决中文乱码问题#sans-serif就是无衬线字体,是一种通用字体族。#常见的无衬线字体有TrebuchetMS,Taho......
  • vue 用 input 和 canvas 标签实现前端背景图片的移动 重绘 上传
    前言:    闲得无聊写的,嫌麻烦的直接出门左转搜索vuecropper.js模块直接用就行正文:  首先我们要知道input是自带file方法的,直接可以选这文件上传就行,但为了......
  • vue2.0中svg图片的引用
    1、基础工作都是引用了svg-sprite-loader这个插件  npmisvg-sprite-loader--save2、写一个Svglcon的组件(components/Svglcon),在components目录下新建一个SvgIcon文......