设计软件
GIMP手册
Svg动画和Canvas动画
SVG <animateMotion>用法及代码示例
thingsboard
SVG常用元素标签列表
SVG中的常用标签
svg
demo
svg path 详解
JessyInk制作SVG格式网页版动画
svg desc
UBML
浪潮erp软件
AI工具
本文档使用 MrDoc 发布
-
+
首页
svg path 详解
# path元素的能力 path元素是SVG基本形状中最强大的一个,它不仅能创建其他基本形状,还能创建更多其他形状。 比如矩形(直角矩形或者圆角矩形)、圆形、椭圆、折线形、多边形等。 更重要的是能够绘制一些曲线,如贝塞尔曲线、二次曲线等。 path元素的形状是通过属性d来定义的,d属性通过“命令和坐标”的序列来控制整个path绘制的路径 # 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 然后一个个来介绍主要分为直线命令和曲线命令 # 直线命令 直线命令主要有以下几种: M(moveto):需要两个参数(x轴和y轴坐标,移动到的点的x轴和y轴的坐标 L(lineto):需要两个参数(x轴和y轴坐标),它会在当前位置和最新的位置(L前面画笔所在的点)之间画一条线段。 H(horizontal lineto):一个参数,标明在x轴移动到的位置,绘制水平线 V(vertical lineto):一个参数,标明在y轴移动到的位置,绘制垂直线 Z( closepath):从当前点画一条直线到路径的起点 示例: 画一个正方形 <svg width="100px" height="100px" version="1.1" xmlns="http://www.w3.org/2000/svg"> <path d="M10 10 H 90 V 90 H 10 L 10 10"/> </svg> 代码解析: 首先定义了一个100x100的画布(坐标系),用M命令在(10,10)创建起点,通过H命令在水平方向移动到x轴为90的位置,y轴不变,也就是移动到(90, 10),再通过V命令移动到y轴为90的位置,x轴不变,也就是坐标为(90,90)的位置,再通过H命令在水平方向移动到x轴为10的位置,y轴不变,此刻的位置为(10,90),最后使用L命令在起点(10,10)的位置与上次的点(10,90)画一条直线,那么四条边就画完了。 思考? 通过上面的参数和示例可以想到,其实最后的一步有几种办法可以实现 <svg width="100px" height="100px" version="1.1" xmlns="http://www.w3.org/2000/svg"> <!-- 利用Z命令 --> <path d="M10 10 H 90 V 90 H 10 Z"/> <!-- 利用V命令 --> <path d="M10 10 H 90 V 90 H 10 V 10"/> </svg> 实现的效果都是一样的,Z命令是直接从当前点画一条直线到起点,V利用本次示例中最后一步向垂直方向移动,所以它也能够做到。 以上所说的是绝对距离,当然还可以使用==相对距离==来画,使用==小写字母==。 <svg width="100px" height="100px" version="1.1" xmlns="http://www.w3.org/2000/svg"> <path d="M10 10 h 80 v 80 h -80 Z" /> </svg> 曲线命令 # C(curveto)三次贝塞尔曲线 三次贝塞尔曲线需要定义一个点和两个控制点,用C命令来创建。 (x,y)表示的是曲线的终点,(x1,y1)是起点的控制点,(x2,y2)是终点的控制点。控制点描述的是曲线起始点的斜率,曲线上各个点的斜率,是从起点斜率到终点斜率的渐变过程。 命令参数: C x1 y1, x2 y2, x y c dx1 dy1, dx2 dy2, dx dy 示例: <svg width="200px" height="100px" version="1.1" xmlns="http://www.w3.org/2000/svg"> <path d="M10 10 C 20 20, 40 20, 50 10" stroke="black" fill="transparent"/> </svg> 代码解释: 用M创建一个起点(10,10),C创建一个以(50,10)为终点,(20,20)为起点的控制点,(40,10)为终点的控制点。 给它加上辅助的点,看效果和代码 <svg width="200px" height="200px" version="1.1" xmlns="http://www.w3.org/2000/svg"> <path d="M130 110 C 120 140, 180 140, 170 110" stroke="black" fill="transparent"/> <circle cx="130" cy="110" r="2" fill="red"/> <circle cx="120" cy="140" r="2" fill="red"/> <line x1="130" y1="110" x2="120" y2="140" style="stroke:rgb(255,0,0);stroke-width:2"/> <circle cx="180" cy="140" r="2" fill="red"/> <circle cx="170" cy="110" r="2" fill="red"/> <line x1="180" y1="140" x2="170" y2="110" style="stroke:rgb(255,0,0);stroke-width:2"/> </svg> 原理分析: 结合下面的图看一下,曲线沿着起点到第一控制点的方向伸出,逐渐弯曲,然后沿着第二控制点到终点的方向结束。 # S(smooth curveto)简写的三次贝塞尔曲线 S其实是创建一个特殊的三次贝塞尔曲线。它特殊的地方就是当一个点某一侧的控制点是它另一侧的控制点的对称也就是保持斜率不变。 (x,y)表示的是曲线的终点,(x2,y2)是既是终点的控制点也是起点的控制点。 命令参数: S x2 y2, x y s dx2 dy2, dx dy 示例: 先画一个三次贝塞尔曲线 <svg width="400px" height="200px" version="1.1" xmlns="http://www.w3.org/2000/svg"> <path d="M 10 50 C 40 20, 120 20, 150 50" stroke="black" fill="transparent"/> </svg> 在三次贝塞尔曲线后面使用简写的三次贝塞尔曲线,使用S命令画一个简写的三次贝塞尔曲线。 <svg width="400px" height="200px" version="1.1" xmlns="http://www.w3.org/2000/svg"> <path d="M 10 50 C 40 20, 120 20, 150 50 S 260 80, 290 50" stroke="black" fill="transparent"/> </svg> 效果: 相当于起始点使用上一个三次贝塞尔曲线终点的斜率,依照这个斜率画出了一个镜像的三次贝塞尔曲线。 将辅助点标示出来 <svg width="400px" height="200px" version="1.1" xmlns="http://www.w3.org/2000/svg"> <path d="M 10 50 C 40 20, 120 20, 150 50 S 260 80, 290 50" stroke="black" fill="transparent"/> <circle cx="10" cy="50" r="2" fill="red"/> <circle cx="40" cy="20" r="2" fill="red"/> <line x1="10" y1="50" x2="40" y2="20" style="stroke:rgb(255,0,0);stroke-width:1"/> <circle cx="120" cy="20" r="2" fill="red"/> <circle cx="150" cy="50" r="2" fill="red"/> <line x1="120" y1="20" x2="150" y2="50" style="stroke:rgb(255,0,0);stroke-width:1"/> <circle cx="180" cy="80" r="2" fill="blue"/> <circle cx="180" cy="80" r="2" fill="red"/> <circle cx="260" cy="80" r="2" fill="red"/> <line x1="150" y1="50" x2="180" y2="80" style="stroke:blue;stroke-width:1"/> <line x1="290" y1="50" x2="260" y2="80" style="stroke:rgb(255,0,0);stroke-width:1"/> </svg> 蓝色的线连接的那个点,其实就是向上一个“借”来的。 注意:如果S命令跟在一个C命令或者另一个S命令的后面,它的第一个控制点,就会被假设成前一个控制点的对称点。如果S命令单独使用,前面没有C命令或者另一个S命令,那么它的两个控制点就会被假设为同一个点。 # Q(quadratic Bézier curve)二次贝塞尔曲线 二次贝塞尔曲线Q,只需要一个控制点,用来确定起点和终点的曲线斜率。因此它需要两组参数,控制点和终点坐标。 Q x1 y1, x y q dx1 dy1, dx dy 示例: <svg width="200px" height="200px" version="1.1" xmlns="http://www.w3.org/2000/svg"> <path d="M 10 80 Q 95 20 180 80" stroke="black" fill="transparent"/> </svg> 它相比三次贝塞尔曲线,只有一个控制点,也就是一个点同时控制起点和终点,将辅助点标出来 <svg width="200px" height="200px" version="1.1" xmlns="http://www.w3.org/2000/svg"> <path d="M 10 80 Q 95 20 180 80" stroke="black" fill="transparent"/> <circle cx="10" cy="80" r="2" fill="red"/> <circle cx="95" cy="20" r="2" fill="red"/> <circle cx="180" cy="80" r="2" fill="red"/> <line x1="10" y1="80" x2="95" y2="20" style="stroke:rgb(255,0,0);stroke-width:1"/> <line x1="95" y1="20" x2="180" y2="80" style="stroke:rgb(255,0,0);stroke-width:1"/> </svg> # T(smooth quadratic Bézier curveto)简写的二次贝塞尔曲线 简写的二次贝塞尔曲线T,只需要一个终点。 T x y t dx dy 示例: <svg width="400px" height="200px" version="1.1" xmlns="http://www.w3.org/2000/svg"> <path d="M10 80 Q 50 10, 90 80 T 170 80" stroke="black" fill="transparent"/> </svg> 加上辅助线和点 <svg width="400px" height="200px" version="1.1" xmlns="http://www.w3.org/2000/svg"> <path d="M10 80 Q 50 10, 90 80 T 170 80" stroke="black" fill="transparent"/> <circle cx="10" cy="80" r="2" fill="red"/> <circle cx="50" cy="10" r="2" fill="red"/> <line x1="10" y1="80" x2="50" y2="10" style="stroke:rgb(255,0,0);stroke-width:1"/> <circle cx="90" cy="80" r="2" fill="red"/> <line x1="90" y1="80" x2="50" y2="10" style="stroke:rgb(255,0,0);stroke-width:1"/> <circle cx="170" cy="80" r="2" fill="blue"/> <circle cx="130" cy="150" r="2" fill="blue"/> <line x1="90" y1="80" x2="130" y2="150" style="stroke:rgb(0,0,255);stroke-width:1"/> <line x1="130" y1="150" x2="170" y2="80" style="stroke:rgb(0,0,255);stroke-width:1"/> </svg> 注意:T命令前面必须是一个Q命令,或者是另一个T命令,才能达到这种效果。如果T单独使用,那么控制点就会被认为和终点是同一个点,所以画出来的将是一条直线。 # A(elliptical Arc)弧形 A命令用于画弧形。 A rx ry x-axis-rotation large-arc-flag sweep-flag x y a rx ry x-axis-rotation large-arc-flag sweep-flag dx dy 参数说明 弧形命令A前两个参数rx和ry分别是x轴半径和y轴半径。 弧形命令A的第三个参数表示弧形的旋转情况。 large-arc-flag决定弧线是大于还是小于180度,0表示小角度弧,1表示大角度弧。 sweep-flag表示弧线的方向,0表示从起点到终点沿逆时针画弧,1表示从起点到终点沿顺时针画弧。 x:结束点x坐标。 y:结束点y坐标。 示例: <svg width="400px" height="320px" version="1.1" xmlns="http://www.w3.org/2000/svg"> <path d="M10 315 L 110 215 A 30 50 0 0 1 162.55 162.45 L 172.55 152.45 A 30 50 -45 0 1 215.1 109.9 L 315 10" stroke="black" fill="red" stroke-width="2" fill-opacity="0.5"/> </svg> 代码解析: 画布上有一条对角线,中间有两个椭圆弧被对角线切开(x radius = 30, y radius = 50)。 第一个椭圆弧的x-axis-rotation(x轴旋转角度)是0,所以弧形所在的椭圆是正置的(没有倾斜)。 在第二个椭圆弧中,x-axis-rotation设置为-45,所以这是一个旋转了45度的椭圆,并以短轴为分割线,形成了两个对称的弧形。 # 总结 学习了直线命令,特别是比较难理解的曲线命令。 绘制平滑曲线的命令有三个,其中两个用来绘制贝塞尔曲线,另外一个用来绘制弧形或者说是圆的一部分。 在path元素里,只存在两种贝塞尔曲线:三次贝塞尔曲线C,和二次贝塞尔曲线Q。 在这里还要注意简写的贝塞尔曲线使用的前提。最难的当然是弧形了。 原文地址:【SVG】SVG的夺命利器——path - 知乎 https://zhuanlan.zhihu.com/p/432284368
智能制造CEO
2024年3月2日 22:58
分享文档
收藏文档
上一篇
下一篇
微信扫一扫
复制链接
手机扫一扫进行分享
复制链接
关于 MrDoc
觅思文档MrDoc
是
州的先生
开发并开源的在线文档系统,其适合作为个人和小型团队的云笔记、文档和知识库管理工具。
如果觅思文档给你或你的团队带来了帮助,欢迎对作者进行一些打赏捐助,这将有力支持作者持续投入精力更新和维护觅思文档,感谢你的捐助!
>>>捐助鸣谢列表
微信
支付宝
QQ
PayPal
Markdown文件
分享
链接
类型
密码
更新密码