热门标签 | 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;可以参考


推荐阅读
  • 本文探讨了如何在Classic ASP中实现与PHP的hash_hmac('SHA256', $message, pack('H*', $secret))函数等效的哈希生成方法。通过分析不同实现方式及其产生的差异,提供了一种使用Microsoft .NET Framework的解决方案。 ... [详细]
  • Python自动化测试入门:Selenium环境搭建
    本文详细介绍如何在Python环境中安装和配置Selenium,包括开发工具PyCharm的安装、Python环境的设置以及Selenium包的安装方法。此外,还提供了编写和运行第一个自动化测试脚本的步骤。 ... [详细]
  • 本文介绍如何使用 Angular 6 的 HttpClient 模块来获取 HTTP 响应头,包括代码示例和常见问题的解决方案。 ... [详细]
  • 实用正则表达式有哪些
    小编给大家分享一下实用正则表达式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下 ... [详细]
  • 本文探讨了为何相同的HTTP请求在两台不同操作系统(Windows与Ubuntu)的机器上会分别返回200 OK和429 Too Many Requests的状态码。我们将分析代码、环境差异及可能的影响因素。 ... [详细]
  • 本文将探讨2015年RCTF竞赛中的一道PWN题目——shaxian,重点分析其利用Fastbin和堆溢出的技巧。通过详细解析代码流程和漏洞利用过程,帮助读者理解此类题目的破解方法。 ... [详细]
  • 深入解析Spring启动过程
    本文详细介绍了Spring框架的启动流程,帮助开发者理解其内部机制。通过具体示例和代码片段,解释了Bean定义、工厂类、读取器以及条件评估等关键概念,使读者能够更全面地掌握Spring的初始化过程。 ... [详细]
  • 本文详细比较了CSS选择器和XPath在Selenium中通过页面结构定位元素的优劣,并提供了具体的代码示例,帮助读者理解两者在不同场景下的适用性。 ... [详细]
  • Spring Boot 中静态资源映射详解
    本文深入探讨了 Spring Boot 如何简化 Web 应用中的静态资源管理,包括默认的静态资源映射规则、WebJars 的使用以及静态首页的处理方法。通过本文,您将了解如何高效地管理和引用静态资源。 ... [详细]
  • 本文探讨了如何利用HTML5和JavaScript在浏览器中进行本地文件的读取和写入操作,并介绍了获取本地文件路径的方法。HTML5提供了一系列API,使得这些操作变得更加简便和安全。 ... [详细]
  • ListView简单使用
    先上效果:主要实现了Listview的绑定和点击事件。项目资源结构如下:先创建一个动物类,用来装载数据:Animal类如下:packagecom.example.simplelis ... [详细]
  • ArcXML:互联网空间数据交换的专用语言
    ArcXML是一种专为ArcIMS平台设计的数据交换协议,基于XML标准,用于在不同组件之间传输和描述地理空间数据。本文将详细介绍ArcXML的背景、用途及其与XML的关系。 ... [详细]
  • 本文详细介绍如何使用 Python 集成微信支付的三种主要方式:Native 支付、APP 支付和 JSAPI 支付。每种方式适用于不同的应用场景,如 PC 网站、移动端应用和公众号内支付等。 ... [详细]
  • 本文详细介绍了 Android 开发中 layout_gravity 属性的使用方法及其在不同布局下的效果,旨在帮助开发者更好地理解和利用这一属性来精确控制视图的布局。 ... [详细]
  • 利用Selenium与ChromeDriver实现豆瓣网页全屏截图
    本文介绍了一种使用Selenium和ChromeDriver结合Python代码,轻松实现对豆瓣网站进行完整页面截图的方法。该方法不仅简单易行,而且解决了新版Selenium不再支持PhantomJS的问题。 ... [详细]
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社区 版权所有