python如何画svg路径_svg之<path>详解

path元素的形状是通过属性d定义的,属性d的值是一个“命令+参数”的序列。

每一个命令都用一个关键字母来表示,每一个命令都有两种表示方式。

一种是用**大写字母**,表示采用**绝对定位**。

另一种是用**小写字母**,表示采用**相对定位**

(例如:从上一个点开始,向上移动10px,向左移动7px)

因为属性d采用的是用户坐标系统,所以不需标明单位。

接下来,来看一下各个命令

直线命令

M

【Move to】需要两个参数,分别是需要移动到的点的x轴和y轴的坐标。类似于移动画笔的位置。

M x y //绝对位置

m dx dy //相对位置。后续提到其他命令雷同,故省略不再赘述。

L

【Line to】需要两个参数,分别是一个点的x轴和y轴坐标,L命令将会在当前位置和新位置(L前面画笔所在的点)之间画一条线段。

H 【绘制平行线】

V 【绘制垂直线】

这两个命令都只带一个参数,标明在x轴或y轴移动到的位置,因为它们都只在坐标轴的一个方向上移动

Z 【闭合路径】

Z命令会从当前点画一条直线到路径的起点。不区分大小写

看一下MDN中给的例子:画的是一个矩形。

效果图如下:

曲线命令

C

三次贝塞尔曲线。(x,y)表示的是曲线的终点,(x1,y1)是起点的控制点,(x2,y2)是终点的控制点。

控制点描述的是曲线起始点的斜率,曲线上各个点的斜率,是从起点斜率到终点斜率的渐变过程。

C x1 y1, x2 y2, x y

有点抽象,可以看一下例子。(建议自己拍一下代码看看效果)

S

当一个点某一侧的控制点是它另一侧的控制点的对称(以保持斜率不变),可以使用S命令。简写的贝塞尔曲线命令。

如果S命令跟在一个C命令或者另一个S命令的后面,它的第一个控制点,就会被假设成前一个控制点的对称点。如果S命令单独使用,前面没有C命令或者另一个S命令,那么它的两个控制点就会被假设为同一个点。

S x2 y2, x y

继续扔一个栗子来看看。【注意】蓝色部分是对称的控制点

Q

二次贝塞尔曲线Q,只需要一个控制点,用来确定起点和终点的曲线斜率。因此它需要两组参数,控制点和终点坐标。

Q x1 y1, x y

看一下例子,(代码中表示点的位置没写。)

效果图,path是黑色曲线

T

与S命令相似,是Q命令的简写命令。

与S命令相似,T也会通过前一个控制点,推断出一个新的控制点。这意味着,在你的第一个控制点后面,可以只定义终点,就创建出一个相当复杂的曲线。

【需要注意】,T命令前面必须是一个Q命令,或者是另一个T命令,才能达到这种效果。如果T单独使用,那么控制点就会被认为和终点是同一个点,所以画出来的将是一条直线。

T x y

还是看例子比较清楚。

效果图如下:【注意蓝色部分是自动补全对称的】

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值