热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

前端提高篇(七十):SVG基本使用、基本样式、路径path

SVG是使用XML来描述二维图形和绘图程序的语言。SVG遵循的是xml的规范,与html5的使用有所区别SVG绘制出来的是矢量图,放大之后不会失真官方文

SVG 是使用 XML 来描述二维图形和绘图程序的语言。
SVG遵循的是xml的规范,与html5的使用有所区别
SVG绘制出来的是矢量图,放大之后不会失真
官方文档链接

应用场景:
1.图形(脑图)
2.图标、logo(矢量图)
3.动效

发展简史及支持情况
1.在2003年,SVG1.1被确立为W3C标准
2.firefox、IE9+、chrome、safari均支持

使用:
html:

<svg width&#61;&#39;500px&#39; height&#61;&#39;500px&#39; xmlns&#61;"http://www.w3.org/2000/svg" version&#61;"1.1">svg>

js&#xff1a;

var char &#61; "http://www.w3.org/2000/svg";
var svg &#61; document.createElementNS(char, &#39;svg&#39;);

SVG元素对象一般通过调用setAttribute()方法来设定属性值

基础元素&#xff1a;


<line x1&#61;&#39;100&#39; y1&#61;&#39;100&#39; x2&#61;&#39;200&#39; y2&#61;&#39;100&#39; stroke&#61;&#39;red&#39;>line>

<rect x&#61;&#39;100&#39; y&#61;&#39;100&#39; width&#61;&#39;100&#39; height&#61;&#39;100&#39; rx&#61;&#39;20&#39; ry&#61;&#39;20&#39;>rect>

<circle cx&#61;&#39;100&#39; cy&#61;&#39;100&#39; r&#61;&#39;50&#39; fill&#61;&#39;green&#39;>circle>

<ellipse rx&#61;&#39;100&#39; ry&#61;&#39;50&#39; cx&#61;&#39;250&#39; cy&#61;&#39;100&#39;>ellipse>

<polygon points&#61;&#39;100 100,70 150,130 150&#39;>polygon>

<polyline points&#61;&#39;0 100,100 35,200 150,300 75,400 150,500 20&#39;>polyline>

<text x&#61;&#39;300&#39; y&#61;&#39;300&#39;>学习text>

元素的属性名是固定的&#xff0c;不可随意改动&#xff1b;但可以直接写在dom上&#xff0c;不用另外写在css文件里&#xff0c;或内部样式表&#xff0c;如fill&#xff0c;stroke&#xff0c;width&#xff0c;height等等
fill-opacity&#xff1a;填充透明度
stroke-opacity&#xff1a;描边透明度

1.默认画的元素都会填充成黑色&#xff0c;想改颜色用fill&#xff0c;但画直线时&#xff0c;没有可以填充的地方&#xff0c;显示不出来&#xff0c;所以需要单独设置stroke颜色才能看见

svg {border: 1px solid #000;
}
line {stroke: red;
}

<svg width&#61;&#39;500&#39; height&#61;&#39;500&#39; xmlns&#61;"http://www.w3.org/2000/svg" version&#61;"1.1"><line x1&#61;&#39;100&#39; y1&#61;&#39;100&#39; x2&#61;&#39;200&#39; y2&#61;&#39;100&#39;>line>
svg>

效果就是一条红色的线

2.线宽stroke-width是有写px的&#xff0c;不是相对大小
一个椭圆&#xff0c;以透明填充&#xff0c;描边用橘色&#xff0c;线宽20px&#xff1a;

ellipse {stroke: orange;fill: transparent;stroke-width: 20px;
}

3.画折线时&#xff0c;由于默认会填充&#xff0c;所以会把第一个点和最后一个点连起来&#xff0c;然后填充成黑色&#xff0c;就像多边形一样

<polyline points&#61;&#39;0 100,100 35,200 150,300 75,400 150,500 20&#39;>polyline>

在这里插入图片描述
把填充色改成透明色看看原来折线的样子

polyline {stroke: red;fill: transparent;
}

在这里插入图片描述

4.文字也能添加样式

text {stroke: red;font-size:20px;stroke-width:3px;
}

<text x&#61;&#39;300&#39; y&#61;&#39;300&#39;>学习text>

在这里插入图片描述

基础样式
1.fill: transparent;
2.stroke: red;
3.stroke-width: 10px;
4.stroke-opacity/fill-opacity: 0.5;
5.stroke-linecap: butt/round/square;
6.stroke-linejoin: bevel/round/miter;

与canvas的类似

路径

path 元素用于定义一个路径。
d: 定义路径指令
下面的命令可用于路径数据&#xff1a;M &#61; moveto移动到
L &#61; lineto画线到
H &#61; horizontal lineto水平线到&#xff08;后面加水平走多少&#xff0c;不是加坐标&#xff09;
V &#61; vertical lineto垂直线到&#xff08;后面加垂直走多少&#xff0c;不是加坐标&#xff09;
C &#61; curveto三次贝塞尔曲线到
S &#61; smooth curveto光滑三次贝塞尔曲线到
Q &#61; quadratic Bézier curve二次贝塞尔曲线到
T &#61; smooth quadratic Bézier curveto光滑二次贝塞尔曲线到
A &#61; elliptical Arc椭圆弧 A 70 120 0 1 1 150 200
Z &#61; closepath关闭路径(连接起点和终点&#xff0c;不分大小写)
注意&#xff1a;以上所有命令均允许小写字母。大写表示绝对定位&#xff08;对于svg&#xff09;&#xff0c;小写表示相对定位&#xff08;相对前面那个路径&#xff09;。

在这里插入图片描述

VvHh的使用

<path d&#61;&#39;M 100 100 v 100 h 100&#39;>path>

从svg的(100,100)处垂直走100&#xff0c;再水平走100&#xff0c;水平走的方向根据写的数值和大小写Hh来控制
在这里插入图片描述
如果写成&#xff1a;

<path d&#61;&#39;M 100 100 V 100 H 100&#39;>path>

就相当于还是一个点&#xff0c;画笔移动到svg(100,100)处&#xff0c;V代表svg垂直方向100处&#xff0c;还是这个点&#xff0c;H代表水平方向100处&#xff0c;也还是这个点&#xff0c;所以不会有画线&#xff0c;需要用小写的v和h

L使用&#xff1a;画多段直线&#xff1a;

<path d&#61;&#39;M 100 100 L 200 100, 200 200,100 200,100 150&#39;>path>

在这里插入图片描述
可以一直lineTo下去

有svg的在线编辑器&#xff0c;可以方便地画图形&#xff0c;然后保存成svg文件&#xff0c;在ide中打开&#xff0c;就能看到对应的path
在线编辑器
随便画了个图
在这里插入图片描述
保存文件&#xff0c;在浏览器打开&#xff0c;就是图示的这样&#xff0c;在vscode打开&#xff0c;是这样的&#xff1a;
在这里插入图片描述
已经写好了对应的svg元素及属性

二次贝塞尔曲线&#xff1a;
M到起始点&#xff0c;Q后面跟控制点&#xff0c;最后写终止点

<path d&#61;&#39;M 100 100 Q 200 0 300 100&#39;>path>

在这里插入图片描述
关于A指令的使用&#xff1a;
这里有一篇很赞的文章&#xff0c;给出了详细的解释
在这里插入图片描述
A指令是不指定椭圆圆心的&#xff0c;指定起点和终点&#xff0c;经过这两个点的椭圆有2个&#xff0c;弧有4段&#xff0c;
如果A指令的第4个参数为1&#xff0c;代表选择大弧&#xff0c;即图中的1或者4&#xff1b;
如果第4个参数为0&#xff0c;代表选择小弧&#xff0c;即图中的2或者3&#xff1b;
如果第5个参数为1&#xff0c;代表选择从起点到终点顺时针的弧1&#xff1b;
如果第5个参数为0&#xff0c;代表选择从起点到终点逆时针的弧4

A 70 120 0 1 1 150 200的图&#xff1a;
在这里插入图片描述
如果指定的起点和终点刚好在轴上&#xff0c;画出的圆只有1个&#xff0c;可选择的弧只有2段

如果设定了旋转角度&#xff0c;是旋转完椭圆&#xff0c;与起点终点匹对位置&#xff0c;然后旋转弧段&#xff0c;不是在未旋转时选好弧段再旋转
在这里插入图片描述

<path d&#61;&#39;M 100 100 A 70 120 90 1 1 150 200&#39;>path>

在这里插入图片描述
关于path&#xff0c;这里还有一篇很赞的文章&#xff0c;可以参考


推荐阅读
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • Docker的安全基准
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 本文介绍如何在 Android 中通过代码模拟用户的点击和滑动操作,包括参数说明、事件生成及处理逻辑。详细解析了视图(View)对象、坐标偏移量以及不同类型的滑动方式。 ... [详细]
  • 2023 ARM嵌入式系统全国技术巡讲旨在分享ARM公司在半导体知识产权(IP)领域的最新进展。作为全球领先的IP提供商,ARM在嵌入式处理器市场占据主导地位,其产品广泛应用于90%以上的嵌入式设备中。此次巡讲将邀请来自ARM、飞思卡尔以及华清远见教育集团的行业专家,共同探讨当前嵌入式系统的前沿技术和应用。 ... [详细]
  • 程序员妻子吐槽:丈夫北漂8年终薪3万,存款情况令人意外
    一位程序员的妻子在网上分享了她丈夫在北京工作八年的经历,月薪仅3万元,存款情况却出乎意料。本文探讨了高学历人才在大城市的职场现状及生活压力。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • 本文详细介绍了如何解决Uploadify插件在Internet Explorer(IE)9和10版本中遇到的点击失效及JQuery运行时错误问题。通过修改相关JavaScript代码,确保上传功能在不同浏览器环境中的一致性和稳定性。 ... [详细]
  • 本文基于刘洪波老师的《英文词根词缀精讲》,深入探讨了多个重要词根词缀的起源及其相关词汇,帮助读者更好地理解和记忆英语单词。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 数据管理权威指南:《DAMA-DMBOK2 数据管理知识体系》
    本书提供了全面的数据管理职能、术语和最佳实践方法的标准行业解释,构建了数据管理的总体框架,为数据管理的发展奠定了坚实的理论基础。适合各类数据管理专业人士和相关领域的从业人员。 ... [详细]
author-avatar
张茂彪6
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有