跳转至

SVG画图:画一个腾讯云logo

什么是SVG

首先来了解一下什么是 SVG,SVG(Scalable Vector Graphics)是一种基于 XML 的图像格式,用于描述二维矢量图形。这种格式具有高度的可伸缩性和分辨率独立性,意味着 SVG 图像可以在不失真的情况下放大或缩小,非常适合用于网页设计、移动应用、数据可视化等领域。

首先要有一个大的框架,SVG 标签中放的是我们要画的图形和元素,其中 width 和 heigth 是整个 SVG 图形的大小

<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg">
   <!-- 在这里添加你的SVG图形和元素 -->
</svg>

接下来我们将使用这个网站 https://www.bejson.com/ui/svg_editor/

来画几个简单的图形

画个圆

接下来画个简单的圆形,其中 circle 表示这是圆,cx 和 cy 属性分别定义圆心的 x 和 y 坐标,r 表示半径,fill 表示填充的颜色,这里为绿色

<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg">
  <circle cx="50" cy="50" r="40" fill="green" />
</svg>

1712197554817-49f3e944-0264-4463-a821-62324acc78df.png

画个矩形

矩形的标签是 rect,x 和 y 定义的是矩形的左上角的坐标,width 和 height 定义矩形的宽度和高度,fill 仍然表示颜色

<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg">
  <rect x="10" y="10" width="80" height="50" fill="blue" />
</svg>

1712197622415-ab89dca9-3ac5-4bc3-8358-b6a8f30731c7.png

画一条线

线条的标签是 line,x1 和 y1 定义线的起点坐标,x2 和 y2 定义线的终点坐标,stroke 定义线的颜色,stroke-width 定义线的宽度

<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg">
  <line x1="10" y1="10" x2="90" y2="90" stroke="red" stroke-width="2" />
</svg>

1712201386958-f5c8f8f3-a845-4cdd-9bfc-c0f54993287d.png

但是到这里大家应该注意到了,我们画的形状都是有标签来决定的,比如圆的标签是 circle,需要指定这个标签才能画一个圆,但是我们的目标是腾讯云的 logo,这显然有些 ... 复杂了

1712205466119-27aefb39-d915-4f05-a3d4-1e4cb43680ba.png

别担心,如果我们想要自己创建形状可以直接使用 path 标签,path 标签使用 "d" 属性来描述图形的路径。路径描述包括移动(M/m)、线(L/l)、曲线(C/c、Q/q、S/s、A/a)和关闭路径(Z/z)等命令

这里是 path 标签的一些基本命令:

M (moveto): 移动到一个新位置,不画线。例如,M 10 10 会将画笔移动到坐标 (10,10)。
L (lineto): 从当前位置画一条直线到新位置。例如,L 20 20 会从当前位置画一条直线到 (20,20)。
H (horizontal lineto): 从当前位置画一条水平线到指定的 X 坐标。例如,H 30 会画一条线到 X 坐标 30,当前 Y 坐标不变。
V (vertical lineto): 从当前位置画一条垂直线到指定的 Y 坐标。例如,V 40 会画一条线到 Y 坐标 40,当前 X 坐标不变。
C (cubic Bézier curve): 画一个立方体贝塞尔曲线。它需要三组坐标,分别代表两个控制点和终点。例如,C 10 10, 20 20, 30 30。
S (smooth cubic Bézier curve): 画一个平滑的立方体贝塞尔曲线。它假设第一个控制点是前一个 C 或 S 命令的第二个控制点的反射。它需要两组坐标:一个控制点和一个终点。
Q (quadratic Bézier curve): 画一个二次贝塞尔曲线。它需要两组坐标:一个控制点和一个终点。
T (smooth quadratic Bézier curve): 画一个平滑的二次贝塞尔曲线。它类似于 S,但用于 Q 命令。
A (elliptical arc): 画一个椭圆弧。这个命令需要一些复杂的参数,包括椭圆的半径、旋转角度、大弧标志、顺时针或逆时针标志以及终点坐标。
Z (closepath): 关闭当前的路径。它将当前位置连接回初始的 M 命令的位置。

每个命令都有一个相应的小写字母形式,例如 m、l、h、v 等。小写字母表示相对坐标,而大写字母表示绝对坐标。使用相对坐标可以简化路径的定义,因为它们是相对于前一个点的位置。

例如我们来画一个心型

<svg width="100" height="100" viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg">
  <path d="M 10,30
           A 20,20 0,0,1 50,30
           A 20,20 0,0,1 90,30
           Q 90,60 50,90
           Q 10,60 10,30 z" fill="red"/>
</svg>

1712240112772-59f84f7a-7bef-4a1f-bb2c-09794997bb30.png

接下来解析一下这个心形是怎么画出来的

M 10,30 移动到起始点 (10, 30)。

A 20,20 0,0,1 50,30 画出第一个半圆弧形。这里 A 命令指定了一个椭圆弧。它的半径在 x 和 y 方向都是 20,不旋转,大弧标志为 0,顺时针标志为 1,终点是 (50, 30)。这画出了心形顶部的左半边。

A 20,20 0,0,1 90,30 画出第二个半圆弧形,与第一个半圆弧形相接,绘出心形的顶部右半边,结束于 (90, 30)。

Q 90,60 50,90 使用一个二次贝塞尔曲线,从 (90, 30) 开始,通过控制点 (90, 60) 到终点 (50, 90),形成心形的右下边缘。

Q 10,60 10,30 再画一个二次贝塞尔曲线,从 (50, 90) 开始,通过控制点 (10, 60) 回到 (10, 30),形成心形的左下边缘。

最后,z 命令关闭路径,确保所有线条连接起来,形成闭合的图形。

fill="red" 属性确保这个心形被填充红色。整个描述合在一起,就形成了一个红色的心形图形。

那么我们来观察一下 腾讯云的这个 logo,基本可以根据颜色分为三部分,上面是一个圆环的一部分,

1712242000926-3cbe7a05-117f-4cc0-bd37-a3d1dcc10e68.png

先来画一个圆环

<svg width="200" height="200">
  <path d="M 50,100
    A 50,50 0 0 1 150,100
    L 130,100
    A 30,30 0 0 0 70,100
    Z"
    fill="#006EFF"  />
</svg>

M 50,100 移动到起点。

A 50,50 0 0 1 150,100 画一个半径为50的外圈弧线到点(150,100)。

L 130,100 从外圈弧线的终点画一条直线到内圈弧线的起点。

A 30,30 0 0 0 70,100 画一个半径为30的内圈弧线回到点(70,100)。

Z 闭合路径,自动画一条直线从内圈弧线的终点回到起点。

1712279644397-33da12cd-1669-4a8c-a0da-46df7d17b4c3.png

但是看起来 logo 并不是单纯的半圆环,我们来稍微调整一下,让它有些倾斜

<svg width="200" height="200">
  <path d="M 50,100
           A 50,50 0 0 1 140,90
           L 120,93
           A 30,30 0 0 0 70,100
           Z"
        fill="#006EFF"  />
</svg>

1712279623829-650e88ac-1631-4518-8df8-1216deb2ea85.png

然后来画左下角的图形,这里基本上要参照原来的图形的坐标,先画直线,在画圆弧最终闭合起来

<svg width="200" height="200">
  <path d="M 50,100
           A 50,50 0 0 1 140,90
           L 120,93
           A 30,30 0 0 0 70,100
           Z"
        fill="#006EFF"  />
  <path d="M 90,130
           L 100,120
           L 70, 100
            L 50, 100
           A 20,20 0 0 0 70,180
           L 80 170
           L 60 170
           A 20,24 0 0 1 57,111
           L 64 112
           Z"
        fill="#00C8DC"  />
</svg>

M 90,130 移动到点 90,130 这个起点是右边最下方的点

L 100,120 走直线到 100,120

L 70, 100 再走直线到 70,100

L 50, 100 走直线到 50,100 到这里就和上面的图形看上去连接起来了,我们开始画圆弧

A 20,20 0 0 0 70,180 逆时针画一个圆弧

L 80 170

L 60 170 这些是画下面的直线

A 20,24 0 0 1 55,113 顺时针画圆弧

L 64 112 走到合适的位置方便闭合

Z" 闭合1712281367418-8c014a6f-044d-448c-a922-c263190d000b.png

接下来画最后一部分,这是一个类似水滴的形状,先从第二个图形的最下端开始画,画一个直线后直接画圆弧得到这样一个全部填充的形状

  <path d="M 70,180
        L 130,105
        A  20,20 0 0 1 160,180
        Z"
        fill="#00A3FF"  />

1712282084947-e5d6c7c3-0297-420d-b17c-90d644b448f9.png

我们可以继续从里面走线直到把线条闭合留出里面的空白,也可以复制一份画一个小的白色的水滴型,把里面填充为白色

  <path d="M 95,168
        L 135,118
        A  10,10 0 0 1 155,168
        Z"
        fill="#ffffff"  />

到此,一个仿制的腾讯云 logo 就完成了

1712282435200-43447252-c971-49b4-b6e1-f58aea69c303.png

emmm,再调整一下宽度等细节,只能说,凑合能认识吧

1712282594293-f3824960-3835-490c-9f9b-dd36f06b9592.png

完成代码:

<svg width="200" height="200">
  <path d="M 50,100
           A 50,50 0 0 1 140,90
           L 120,93
           A 30,30 0 0 0 70,100
           Z"
        fill="#006EFF"  />
  <path d="M 90,130
           L 100,120
           L 70, 100
            L 50, 100
           A 20,20 0 0 0 70,180
           L 80 170
           L 60 170
           A 20,24 0 0 1 57,111
           L 64 112
           Z"
        fill="#00C8DC"  />
  <path d="M 70,180
        L 130,105
        A  20,20 0 0 1 160,180
        Z"
        fill="#00A3FF"  />
  <path d="M 95,168
        L 135,118
        A  10,10 0 0 1 155,168
        Z"
        fill="#ffffff"  />
</svg>

再来看一下原版的代码有多复杂,甚至连字都是这么画出来的!?瑞思拜:

1712282796182-5eaa87a9-941d-4b02-8b1e-ce1f108092a1.png

原文: https://www.yuque.com/hxfqg9/misc/bpmtirab3f8p3ean