前端可视化——SVG矢量图技术
SVG
1、SVG 是一种绘图技术,SVG 的全名叫可缩放矢量图形(Scalable Vector Graphics)。
2、SVG 使用 XML 格式定义图像。
3、可伸缩,不失真。
简单示例:
<svg xmlns="http://www.w3.org/2000/svg" version="1.1"><circle cx="100" cy="50" r="40" stroke="black"stroke-width="2" fill="red" />
</svg>
1、SVG的结构
他是标准的 XML 文档结构。
<?xml version="1.0" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN""http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg xmlns="http://www.w3.org/2000/svg" version="1.1"><circle cx="100" cy="50" r="40" stroke="blue"stroke-width="2" fill="red" />
</svg>
包括:
1、xml申明。
2、DOCTYPE申明。dtd是一种约束 xml 文件的标准格式。
3、以及一个svg标签包裹的图形描述。
2、嵌入html
第一种:<embed />标签
<embed src="circle1.svg" type="image/svg+xml" />
第二种:<object />标签
<object data="circle1.svg" type="image/svg+xml"></object>
第三种:<iframe />标签
<iframe src="circle1.svg"></iframe>
最后,也可以使用a标签,链接到svg文件。
<a href="circle1.svg">View SVG file</a>
tips:浏览器是能够直接展示svg的图形的。
区别和优势:
从兼容性考虑,使用object的方式展示svg更好。object不支持js脚本。
从脚本使用的角度考虑,使用 embed 和 iframe 更好一些。
3、svg矩形——rect
<svg xmlns="http://www.w3.org/2000/svg" version="1.1"><rect width="300" height="100"style="fill:rgb(0,0,255);stroke-width:1;stroke:rgb(0,0,0)"/>
</svg>
矩形,它的标签是rect。
相关属性:width、height、style、class、x、y、rx、ry。
x、y,分别是svg的矩形,相对svg的偏移距离。
rx、ry 表示给矩形添加圆角。
style 和 class 都是给当前 svg 写样式的。
常见样式属性如下:
.svg {width: 100px;height: 100px;fill: rgb(0,0,255);stroke-width: 1;stroke: black;fill-opacity: 1;stroke-opacity: 1;
}
fill 表示填充颜色。
stroke-width 表示图形边框宽度。
stroke 表示边框颜色。
opacity 表示整个图形的不透明度
fill-opacity 填充颜色的不透明度
stroke-opacity 边框的不透明度
4、svg圆形——circle
他有这么几个属性:
cx、cy 表示圆形的坐标点。
r 表示圆形的半径距离
5、svg椭圆——ellipse
<ellipse cx="240" cy="100" rx="220" ry="30"style="fill:purple" />
cx、cy 表示坐标中心,
rx、ry 表示横坐标轴 和 纵坐标轴。
6、svg直线——line
<line x1="0" y1="0" x2="200" y2="200"style="stroke:rgb(255,0,0);stroke-width:2"/>
x1、y1 表示起点。
x2、y2 表示终点。
7、svg多边形——ploygon
<polygon points="200,10 250,190 160,210"style="fill:lime;stroke:purple;stroke-width:1"/>
fill-rule: nonzero
fill-rule: evenodd
表示对于重合部分的渲染规则!
8、svg曲线——ployline
元素是用于创建任何只有直线的形状
<polyline points="20,20 40,25 60,40 80,120 120,140 200,180"style="fill:none;stroke:black;stroke-width:3" />
9、svg路径——path
路径规则
M = moveto
L = lineto
H = horizontal lineto
V = vertical lineto
C = curveto
S = smooth curveto
Q = quadratic Bézier curve
T = smooth quadratic Bézier curveto
A = elliptical Arc
Z = closepath
<svg xmlns="http://www.w3.org/2000/svg" version="1.1"><path d="M150 0 L75 200 L225 200 Z" />
</svg>
10、svg文本——text
基本使用:
<svg xmlns="http://www.w3.org/2000/svg" version="1.1"><text x="0" y="15" fill="red">I love SVG</text>
</svg>
旋转的文本:transform=“rotate(30 20,40)”
<text x="0" y="15" fill="red" transform="rotate(30 20,40)">I love SVG</text>
11、svg的stroke属性
stroke,定义颜色。
stroke-width,定义宽度。
stroke-linecap,有 butt、round、square 三种值。
stroke-dasharray,定义虚线。使用特殊的规则。
12、svg滤镜
1、SVG滤镜用来增加对SVG图形的特殊效果。
2、两个标签:<defs> 和 <filter>
3、滤镜,表示一个规则,让你的图形按照你想要的规则展示出来!
4、filter 标签,用来定义一个svg滤镜!
5、所有的svg滤镜,都应该放到defs标签中!
基本示例:
<svg xmlns="http://www.w3.org/2000/svg" version="1.1"><defs><filter id="f1" x="0" y="0"><feGaussianBlur in="SourceGraphic" stdDeviation="5" /></filter></defs><rect filter="url(#f1)" class="svg"/>
</svg>
说明:
feGaussianBlur,表示定义图形的模糊效果。
in=“SourceGraphic”,表示这个部分由整个图像创建效果。
stdDeviation,定义了模糊量,表示在原本图形上的伸缩效果。
fitler属性,把当前图形,链接到定义的规则上面。
filter标签的 x 属性:表示横向的压缩。y 属性:表示纵向的压缩。
13、svg阴影——feOffset
feOffset标签,表示形成一个偏移的图形。
feBlend标签,表示与图像相结合的滤镜。或者可以理解为,生成一个原本的图像。
feColorMatrix标签,给元素渲染颜色。
<svg xmlns="http://www.w3.org/2000/svg" version="1.1"><defs><filter id="f1" x="0" y="0"><feOffset result="offOut" in="SourceGraphic" dx="20" dy="20" /><feGaussianBlur result="blurOut" in="offOut" stdDeviation="10" /><feColorMatrix result="matrixOut" in="blurOut" type="matrix"values="0.2 0 0 0 0 0 0.2 0 0 0 0 0 0.2 0 0 0 0 0 1 0" /><feBlend in="SourceGraphic" in2="matrixOut" mode="normal" /></filter></defs><rect filter="url(#f1)" class="svg"/>
</svg>
14、svg线性渐变——linearGradient
linearGradient,表示线性渐变。需要设置四个值:x1、y1、x2、y2。
x表示横向渐变的过程,y表示纵向渐变的过程。
内部,需要两个stop标签,需要设置颜色(style)和位置(offset)。
<defs><linearGradient id="grad1" x1="0%" y1="0%" x2="100%" y2="0%"><stop offset="0%"style="stop-color:rgb(255,255,0);stop-opacity:1" /><stop offset="100%"style="stop-color:rgb(255,0,0);stop-opacity:1" /></linearGradient>
</defs><rect fill="url(#grad1)" class="svg"/>
15、svg放射性渐变——radialGradient
radialGradient,定义的是由中心到四周的渐变。
CX,CY和r属性定义的最外层圆和Fx和Fy定义的最内层圆。
<defs>
<radialGradient id="grad1" cx="50%" cy="50%" r="50%" fx="50%" fy="50%"><stop offset="0%"style="stop-color:rgb(255,255,255);
stop-opacity:0" /><stop offset="100%"style="stop-color:rgb(0,0,255);stop-opacity:1" />
</radialGradient>
</defs>
<ellipse cx="200" cy="70" rx="85" ry="55" fill="url(#grad1)" />
16、svg参考手册
https://www.runoob.com/svg/svg-reference.html
17、思考和总结(现实应用场景)
SVG绘图,能够绘制一些简单的、有一定规则的图形、并且给这些图形、文本一些滤镜特效。
关于SVG 和 Canvas 的区别。
1、SVG 不能绘制图片,而 canvas 可以。SVG是通过 XML 绘制,而Canvas通过 js 绘制
2、Canvas绘制的方式,是通过 js 逐像素渲染的。也就是说,它绘制一个复杂的图形和一个简单的图形的性能是差不多的。
SVG 是通过 XML 的方式渲染。它的本质是DOM,而复杂的图形,就会降低其渲染性能。
3、Canvas 是依赖分辨率,是一种标量图。所以在放缩的时候,存在失真的问题。
SVG 绘制的时候,不依赖分辨率,是一种矢量图。所以当SVG放缩的时候,不会使得图像失真。
4、SVG 适合带有大型渲染区域的应用程序:比如谷歌地图、百度地图。
Canvas 适合对象密集型的游戏应用场景。
前端可视化——SVG矢量图技术相关推荐
- 【转】SVG矢量图技术
一.SVG概述: SVG (Scalable Vector Graphics, 可伸缩矢量图形) 是W3C推出的一种开放标准的文本式矢量图形描述语言,他是基于XML 的.专门为网络而设计的图像格式.S ...
- Android使用SVG矢量图打造酷炫动效!
一个真正酷炫的动效往往让人虎躯一震,话不多说,咱们先瞅瞅效果: 如果你想看 GAStudio Github主页,请戳这里: 如果你想看 GAStudio更多技术文章,请戳这里: QQ技术交流群:277 ...
- Android矢量图动画特效,Android使用SVG矢量图打造酷炫动画效果
一个真正Android使用SVG矢量图打造酷炫动效往往让人虎躯一震,话不多说,咱们先看看效果: 这个效果我们需要考虑以下几个问题: 1. 这是图片还是文字: 2. 如果是图片该如何拿到图形的边沿线坐标 ...
- svg矢量图字体图标iconfont的制作
前端拿到设计稿 若是存在SVG矢量图需要处理成字体图标,图片放大也不会模糊 ,svg也可以在项目中直接使用,但是兼容性不太好.以iconfont字体图标库为例,在字体图标库里创建一个项目. 步骤如下: ...
- %config InlineBackend.figure_format=svg#矢量图设置
在默认设置的matplotlib中图片分辨率不是很高,可以通过设置矢量图的方式来提高图片显示质量 %config InlineBackend.figure_format='svg'#矢量图设置
- 【Android 安装包优化】Android 中使用 SVG 图片 ( SVG 矢量图简介 | Android 中生成 Vector 矢量图资源 )
文章目录 一.SVG 矢量图简介 二.Android 中生成 Vector 矢量图资源 三.参考资料 一.SVG 矢量图简介 Android SVG 参考文档 : https://developer. ...
- SVG矢量图中矢量路径的获取
矢量图中矢量路径的获取 首先下载一张svg图片,例如,在阿里矢量图标库中下载 用代码编辑器打开下载的图片 将标签中的d属性复制出来,写成下面的格式 这样就可以拿到矢量图中的路径了! SVG矢量图是无损 ...
- 自制批量SVG矢量图转普通图片格式小工具
最近在学unity自制一点小游戏,当然我们这种主攻开发的,在学习阶段肯定只能借(tou)美工素材来学习了. 本来拿到了一系列的动画,但是是SVG的矢量图格式的,原生unity对SVG矢量图支持不太好, ...
- SVG矢量图怎么做?
SVG 矢量图是一种可缩放的图像格式,基于 XML 的标记语言.它可以用于描述二维矢量图形,并且具有数百种功能,能够帮助你创建出色的网站.SVG矢量图怎么做?在本教程中,我们将学习如何使用SVG矢量图 ...
最新文章
- selenium工具的安装
- Spring Boot 2.2.1 正式发布,需特别注意这个注解的使用!
- 19. 邮件提醒(发送邮件)
- mysql设计积分兑换表_积分系统数据库表设计.docx
- js保持div悬浮,不随页面向下滚动而被覆盖
- php微信分享接口调用,TP5的微信分享接口和JSSDK使用
- 数据持化技术的发展演变(SQL、JDBC、mybatis)
- JAVA 从菜鸟成长为大牛的必经之路
- pbs分解_产品分解结构
- C++ 动态联编实现原理分析
- Ubuntu下挂载U盘
- hadoop学习一-hadoop简介
- ArcGIS和Fragstats的脚本化调用 ------以ArcPy和命令行的方式
- 计算机知识怎么记忆,计算器记忆加怎么用
- 特征值篇2——特征子空间
- 一文了解复旦大学NLP实验室的14篇EMNLP 2022长文内容
- C++生成条型码和二维码源码及调用示例 还是C#方便
- sip转webrct
- “ 装逼不成,被雷劈了。。。。 ”答案
- 如何打开打开xml文件的方法和软件。
热门文章
- Flutter上传文件到服务器
- 常见的apk专项测试,主要有几类
- 读论文-----基于单通道表面肌电信号的手势识别 Hand Gestures Recognition Based on One-Channel Surface EMG Signal
- Reids延时队列使用的思考
- JavaWeb过滤器(Filter)详解,是时候该把过滤器彻底搞懂了(万字说明)
- HTML5微信播放全屏问题的解决方法
- python爬取煎蛋网妹子图,已解密图片~~~~~
- 计算机网络的体系结构--学习计算机网络的重中之重
- 2021年百度Java面试真题,文末有彩蛋
- 【Unity3D实战】方块跑酷初级开发实战(一)