SVG 学学就会了。
SVG 随便学学就会了
这两天闲来没事把 Echart 换成 Rechart 感觉世界都清爽了。因为 rechart 使用 svg 来渲染,所以顺带学了下 SVG 感觉很轻松哦。
概念
SVG 是 w3c 的退出的规范。(就是 w3c 指定语法。各大厂商自己去实现)。SVG 渲染的是矢量图(它之规定了图像怎么画,而不是规定那个像素画什么颜色)。
优点
因为以上两点(w3c, 矢量图)所以他有兼容性好,不失真的优点。除此之外还有:
使用xml的格式规范(HTML 也是)。在浏览器上基本上可以看做是DOM节点来操作。(事件,渲染样式)
svg 不同于位图指定每一个像素的渲染,内部其实是用简介的语法指定图应该从哪画到那怎么画。本质上就是文本,所以很小。
这些优点决定了他很适合在前端画一些简单的图。(画复杂的就算了交给设计师吧)
Getting Started
在现在的浏览器使用 SVG 太简单不过了。只需要在HTML中直接写
<!-- version prop in svg will be Deprecated -->
<!-- xmlns is unnecessary for inner svg elements or inside HTML documents. -->
<svg width="100" height="100">
<line x1="0" y1="0" x2="100" y2="100" stroke="red"></line>
</svg>
- 可以清楚的看到 svg 的语法。svg 是 xml 的语法格式。svg 是定义一个容器。其定义一个图的大小。图的内容由其子元素来确定。
<svg> props
- width | height 定义元素的大小
与 canvas 不同,width 和 height 是定义一个类似于窗口的显示大小,可以在窗口外画东西,只是你一般看不到。可以是svg显示这个宽口外的图,后面讲。
svg 子元素
画图总离不开一些简单的图形,svg 对这些进行了封装,成为以下的标签。
<line x1="2" y1="4" x2="4" y5="7"></line>
: 两点确定一条线段,x1,y1,x2,y2 就是指定这两个点的。
<rect x="2" y="4" width="100" rx="4" ry="4" height="100"></rect>
: 画长方形的,需要注意的是rx ry 是用来画带圆角的长方形的。就像css的border-radius;
<circle cx="13" cy="13" r="40"></circle>
:cx, cy 确定圆心,r为半径画一个圆。
<ellipse cx="0" cy="0" rx="132" ry="test"></eliipse>
: 这个是画椭圆,rx, ry 是定义椭圆的x半径, y轴半径的。
<polygon points="0,0 3,3 4,4"></polygon>
: 等价于你拿着笔按顺序画过经过的 points 中的各个点,最后回到第一个点。围起来的图形。
--- 以上就是一些常用的简单图了 ---
曲线(最复杂)
这个是普通 HTML CSS 没办法做到的。所以这个是学 SVG 中最高性价比的东西。
直接上例子
<!-- 画一条从(0,0)到(50,50)的线 -->
<svg width="100" height="100">
<path d="M0 0 L50 50"></path>
</svg>
可以看到标签是path,d为属性。属性d的值使用 Commandx y 这样的语法格式。(注意Command后直接跟参数没有空格)
指令 | 参数 | 说明 |
---|---|---|
M | x y | 将点移动到 (x,y) 经过不划线 |
L | x y | 将点移动到 (x,y) 并划线 |
H | y | 将点的y坐标做变化x不变,并划线 |
V | x | 将点的x坐标做变化y不变,并划线 |
说明 | x,y | 上面的参数都是绝对值,线面都是相对值 |
m | 参数都一样 | 将点的个个坐标都添加上x,y的值,作用跟M一样 |
l | 参数都一样 | 将点的个个坐标都添加上x,y的值,作用跟L一样 |
h | 参数都一样 | 将点的个个坐标都添加上x的值,作用跟H一样 |
v | 参数都一样 | 将点的个个坐标都添加上y的值,作用跟V一样 |
z | 没有参数 | 将点移动到起点,并划线 |
(妈妈(M)拉(L)我看湖(H)南卫(V)视。真是智(Z)障。
下面真的搞曲线了
接触过曲线的都知道贝塞尔曲线,SVG 画曲线也玩不出花来肯定是用贝塞尔曲线的。
<svg width="100" height="100">
<path d="M0 0 Q0 100, 100 100"></path>
<svg>
画贝塞尔曲线一般需要3个参数,但是画图的语言,一般会记录上一个点,所以SVG的命令就是 Qx y,targetX targetY
。
指令 | 参数 | 说明 |
---|---|---|
Q | x y,targetX targetY | 以(x, y)为切点,上一个点位起点,(targetX, targetY)为终点画一条贝塞尔曲线 |
T | targetX targetY | 以上条贝塞尔曲线的弧度画一条到(targetX, targetY)的贝塞尔曲线,如果上一条划线不是贝塞尔那就是画一条直线 |
腾讯QT语音的两个字的灵感不会是从这里来的吧。
当然还有三次贝塞尔曲线的。语法类似。
指令 | 参数 | 说明 |
---|---|---|
C | x y, x2 y2,targetX targetY | 以(x, y),(x2,y2)为3次贝塞尔的曲线参数,上一个点位起点,(targetX, targetY)为终点画一条贝塞尔曲线 |
S | targetX targetY | 类比上一个 |
用QT语音打CS????
样式的定义
SVG画的线部分已经结束了,接下来我们上色,跟描边。
上面的全部标签都可以分为两部分,一部分是线,已经线包围起来的内容。
线的样式可以在标签上用stroke来定义, 包围起来的内容用fill。
- stroke 有 stroke stroke-width stroke-linecap stroke-opacity等
- fill 有 fill fill-opacity fill-rule 等
<svg width="100" height="100">
<circle
width="100" height="100" x="0" y="0"
stroke="red" stroke-width="2" stroke-linecap="round" stroke-opacity="0.8" stroke-linejoin="round"
fill="green" fill-opacity="0.8"
></circle>
</svg>
图形的复用
就这么老老实实的搬一般就够用了,但是这程序最重要的就是少搬砖,多偷懒。
有时候我们可能一个图中有了很多个相同的图,这时候就copy就惨了。偷懒第一招。
<svg width="100" height="100">
<defs>
<g id="ahole">
<rect x="0" y="0" width="50" height="50" id="rect1"></rect>
<circle
width="100" height="100" x="0" y="0"
stroke="red" stroke-width="2" stroke-linecap="round" stroke-opacity="0.8" stroke-linejoin="round"
fill="green" fill-opacity="0.8"
id="circle1"
></circle>
</g>
</defs>
<use href="#ahole"/>
<use href="#rect1" x="123123"/>
<!-- you can add any props you want to replace the svg element you used -->
<use href="#circle1" y="123123"/>
</svg>
解析:defs 就是定义声明不会在svg中划出。g是将其子元素统统打包,方便use的时候使用。use 就是调用啦,通过href:#id的方式来指定使用哪一个小图形,你可以在use的标签中使用任何属性来替掉你use的标签原来的属性。这里要说明,use 不一定只能应用 defs 中定义的,只要在上下文前,有用id命名的都可以。
偷懒第二招
上面这招只能在同一个svg中使用,但是我们想在每一个svg中使用呢。比如UI库中的icon可能有大量的svg,这是用引用一个就画一个svg显然有点浪费。
<svg style="display: none;">
<symbol id="beaker">
<!-- <path>s and whatever other shapes in here -->
<rect width="40" height="100" x="0" y="0" fill="red"></rect>
</symbol>
</svg>
<svg width="100" height="100" style="border:solid 1px green">
<use href="#beaker"></use>
</svg>
解析:把包含symbol的svg隐藏,并注入大量要使用的svg图,后面的svg就可以简单的通过use来应用了。(这里的svg版本都是最新的,以前版本的语法可能需要xmlns:href等复杂的写法,我选择拥抱最新)
与CSS的结合
我们可以通过给svg元素添加class,并在 css 中设置样式。
在上一篇文章中,我们初步实现了一些利用基本图形就能完成的线条动画: [Web动画]SVG 线条动画入门 当然,事物都是朝着熵增焓减的方向发展的,复杂线条也肯定比有序线条要多. 很多时候,我们无法人工去 ... 通常我们说的 Web 动画,包含了三大类. CSS3 动画 javascript 动画(canvas) html 动画(SVG) 个人认为 3 种动画各有优劣,实际应用中根据掌握情况作出取舍,本文讨论 ... SVG的文本可以沿着一条自定义的Path来排布,比如曲线.圆形等等,使用方式如下所示(来源MDN): <svg viewBox="0 0 1000 300" xmlns=&q ... SVG开发里有个较为少见的问题. 对x1=x2或者y1=y2的直线(line以及path),比如: <path d="M200,10 200,100" stroke=&quo ... 1.SVG绘图总结: ①方法一:已有svg文件,<img src="x.svg"> 方法二:<body><svg></svg>&l ... 1.关于Canvas绘制图像: 问题:需要绘制多张图片时,必须等待所有图片加载完成才能开始绘制:而每张图片都是异步请求,彼此没有先后顺序,哪一张先加载完成完全无法预测: 方案: var progres ... 在SVG中,通过svg标记的 width和height可以规定这段SVG代码所表达的数据在绘制时所占用的空间大小 如下代码svg设置了宽度与高度,rect同样,所以结果自然是全屏 <svg wi ... 1.$和jquery在全局命名空间中定义的唯一两个变量. 2.jquery是工厂函数,不是构造函数.他返回一个新创建的对象. 3.jquery的四种调用方式: <1>传递C ... stroke-dasharray:定义描边的虚线长度,如果提供奇数个,则会自动复制该值成偶数 stroke-dashoffset:定义虚线描边的偏移量(在路径开始的前面,看不到) 实现如下所示 svg ... JSP 教程 这是第一篇JSP JSP与PHP.ASP.ASP.NET等语言类似,运行在服务端的语言. JSP(全称Java Server Pages)是由Sun Microsystems公司倡导和许 ... SQL 语句的语法顺序是: SELECT[DISTINCT] FROM WHERE GROUP BY HAVING UNION ORDER BY 一.查询SELECT 1.查询全部列:SELEC ... 用COUNT函数: mysql> SELECT count(one) FROM tb_test;+------------+| count(http://www.amjmh.com/v/BIBR ... 刚自学Vue不久,所以还不太熟,所以直接上代码. 一.先在data里增加一个变量,用来储存当前点击的元素 data() { return { activeClass: -1, // 0为默认选择第一个 ... <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ... 一.简介 Android系统提供了两种HTTP通信类:HttpURLConnection和HttpClient,前者对比后者十分难用. 网络请求进化:HttpURLConnection --- Apa ... EnumMap EnumMap 能解决什么问题?什么时候使用 EnumMap? 1)EnumMap[枚举映射]中的键值必须来自单个枚举. 2)EnumMap 根据枚举键的自然顺序来维护,迭代遍历是有序 ... C:\Program Files (x86)\Microsoft Visual Studio 14.0\Common7\IDE\ItemTemplates\CSharp\Code\2052\Class ... 改善系统的信号完整性和电磁兼容性需要注意如下: (1)系统电源尽量使用稳压输出. (2)高速期间器件与低俗器件隔离,避免低速器件影响高速器件. (3)模拟模块部分与数字模块部分分离. (4)为器件就近 ... YOLOv3没有太多的创新,主要是借鉴一些好的方案融合到YOLO里面.不过效果还是不错的,在保持速度优势的前提下,提升了预测精度,尤其是加强了对小物体的识别能力. 本文主要讲v3的改进,由于是以v1和 ...SVG 学学就会了。的更多相关文章
随机推荐