首页 > 其他分享 >前端学习教程-SVG绘制路径

前端学习教程-SVG绘制路径

时间:2022-12-07 17:02:40浏览次数:43  
标签:教程 定义 SVG 值为 标签 path 绘制 属性

前端学习教程-SVG绘制路径,在SVG中,使用 path 标签来定义一个路径。它是一个单标签,基本语法为:尖角号 path,斜线尖角号。应用路径,我们可以绘制任意形状的图形。

path标签的重要属性 d,用来定义绘制路径的命令,d 是 draw 的缩写,就是绘制的意思。

绘制路径的命令有很多,先看两个常用的命令:

M 命令,是 moveto 的缩写,定义绘制图形的起点坐标。例如 M 150 0 (大M,空格,150,空格,0),也可以写成 M150 0 (大M, 150,空格,0) ,表示路径从屏幕坐标的 x 150,y 0 (直接读) 这个点开始绘制。

L 命令,是 lineto 的缩写,用来绘制一条直线。例如 l 75 200 (读小l,空格,75,空格,200) ,也可以写成 l75 200 (读作小l,75,空格,200),表示从上一个结束点到 x 75,y 200 (直接读) 这个点绘制一条直线。

注意:命令的字母大小写,表示的意义是不同的。大写字母表示绝对定位,小写字母表示相对定位。绝对定位是相对于屏幕坐标原点的位置,相对定位是相对于上一个绘制点的位置。


前端学习教程-SVG绘制路径_ci

打开编辑器,新建一个 path.html 文件,补全基础代码,在 body 里添加一个 svg 标签,定义属性 width 等于 400,height 等于 210。

在 svg 里添加 path 标签,定义属性 d,它的值定义为 "M150 0 L75 200 L225 200"。保存文件。

在浏览器中预览,一个具有默认黑色的三角形就绘制好了。

这里你可能会问:用 polygon 绘制多边形不也可以吗,为什么用 path 呢?其实,path 的绘制能力非常强,比如绘制一条贝塞尔曲线。

“贝赛尔曲线”是由法国数学家皮埃尔·贝塞尔(Pierre Bézier)发明的,由此为计算机矢量图形学奠定了基础。

在 path 中,绘制“贝赛尔曲线” 使用 Q 命令。

Q 是 quadratic Bézier curve ([kɜːrv]) 的缩写,用来绘制二次贝塞尔曲线,需要定义控制点和终点的坐标。例如 q 150 -300 300 0,表示控制点坐标是 x 150,y -300,终点坐标是 x 300,y 0。这个比较难理解,大家来看一下二次贝塞尔曲线绘制示意图。

前端学习教程-SVG绘制路径_SVG_02

回到编辑器,为了强化练习,我们来绘制一张二次贝塞尔曲线模拟静态图。(此时会展示绘制完以后的效果图)

A为起点,B为控制点,C为终点。在AB,BC 两条红色的线段上,有一条绿色的切线,蓝色的为绘制的贝塞尔曲线。

我们先来绘制三个点。在上个 svg 结尾处添加一个 br 标签。回车换行。

添加一个新的 svg 标签,属性 width 等于 450,height 等于 400。

我首先绘制三个点。在 svg 标签里添加一个 circle 标签,定义属性 cx 等于 100,cy 等于 350,r 等于 3。

复制两个 circle,分别改写一下圆心的位置坐标。

这里我们能成组的给三个小圆定义颜色等属性吗?可以的。


在SVG中,我们可以使用 g 标签把多个绘图元素包裹起来,在 g 标签上定义公共的属性。

我们给三个小圆定义一个父标签 g,定义属性 fill,值为 black。保存。

回到浏览器,刷新,三个小圆点做好了。

接下来绘制三个点的名称。

回到编辑器,再创建一个 g 标签,在 g 标签里添加一个 text 标签,填入文本大写字幕 A。给 text 定义属性 x 等于 100,y 等于 350,dx 等于 -30。

复制两份 text 标签,修改文本内容分别为 B,和 C。再修改一下属性。

最后给 g 定义三个文本的公共属性,font-size 等于 30,fill 等于 black,text-anchor 等于 middle。保存。

回到浏览器,刷新,三个点的名称定义好了。

接下来绘制AB,BC两条线段。

回到编辑器,在 svg 里的首行创建一个 path 标签,定义 d 属性,值为 "M 100 350 l 150 -300" (直接读,注意那个小 l ) ,定义 stroke 属性,值为 red,定义 stroke-width 属性,值为 3,fill 属性,值为 none。

复制一个 path,修改一下 d 属性的值。保存。

回到浏览器,刷新,两条红色的线段绘制好了。

接下来绘制绿色的切线。

回到编辑器,创建第三个 path 标签,定义 d 属性,值为 "M 175 200 l 150 0" (直接读,注意那个小 l ) ,定义 stroke 属性,值为 green,定义 stroke-width 属性,值为 3,fill 属性,值为 none。保存。

回到浏览器,刷新,一条绿色的切线绘制好了。

最后绘制主角儿,贝塞尔曲线。

回到编辑器,创建第四个 path 标签,定义 d 属性,值为 "M 100 350 q 150 -300 300 0" (直接读,注意大M,小 q ) ,定义 stroke 属性,值为 blue,定义 stroke-width 属性,值为 5,fill 属性,值为 none。保存。

回到浏览器,刷新,完整的二次贝塞尔曲线模拟图就绘制好了。

返回编辑器,我们可以把辅助的点和线都去掉,保存。

回到浏览器,刷新,只显示了第四条 path 路径,贝塞尔曲线!

标签:教程,定义,SVG,值为,标签,path,绘制,属性
From: https://blog.51cto.com/u_14573321/5919724

相关文章

  • echart绘制中国地图及各省份地图
    示例:  地图文件下载地址:https://gitcode.net/mirrors/fuhang-lm/echarts?utm_source=csdn_github_accelerator&from_codechina=yes 这里以北京市地图为例,如果是其......
  • Javascript-极速入门指南-3-jQuery使用教程
    内容概要jQuery类库类库jQuery简介jQuery的宗旨:Writeless,domore写的更少做的更多jQuery的特点为: 1.加载速度快 2.选择器更多更好用 3.一行代码走天下......
  • Chatgpt注册全流程教程
    Chatgpt注册全流程教程​ Chatgpt最近非常火爆,Chatgpt的注册有一定的要求。下面我为大家带来完整的注册流程,以及一些常见问题的解决方案。一.梯子​ 梯子的注册可以看这......
  • Zabbix6.0使用教程 (三)—zabbix6.0的安装要求
    接上篇,我们继续为大家详细介绍zabbix6.0的使用教程之zabbix6.0的安装部署。接下来我们将从zabbix部署要求到四种不同的安装方式逐一详细的为大家介绍。本篇讲的是部署zabbi......
  • 现代javascript教程 数组
    array字面量或者构造函数声明数组newArray(100),长度100的空获取数组长度,是一个属性,arr.length获得元素,通过索引值,arr[0]修改数组,arr[0]=0用alert方法打印数组,会......
  • 绘制透明背景位图
    TransparentBltTheTransparentBltfunctionperformsabit-blocktransferofthecolordatacorrespondingtoarectangleofpixelsfromthespecifiedsourcedevic......
  • k8s集群搭建详细教程【1master2node】
    一、集群分类一主多从:一台master多个多个Node节点多主多从:多个master多个node节点二、安装方式minikube:快速安装搭建单节点k8s工具kubeadm:快速搭建k8s集群的工......
  • Threejs教程-07-光源2
    接上节,讲了Threejs06”。本节具体讲解一些Threejs的知识点。首先有条件的话搞个服务器,这里还是用的三丰云免费云服务器,免费虚拟主机在这里不适用就不介绍了,安装的Centos7......
  • Python——问题解决:matplotlib.pyplot绘制函数中文乱码
    代码frompylabimportmpl#中文库mpl.rcParams['font.sans-serif']=['SimHei']mpl.rcParams['axes.unicode_minus']=False例子plt.title("三次样条插值11点")plt.pl......
  • Linux 安装Mysql 详细教程(图文教程)
    首先通过 xshell 或者putty远程进入Linux命令行操作界面。Xshell 的安装1.去 XShell-Download 下载需要的版本。......