热门标签 | 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库,提供了详细的代码示例和优化建议。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 一个登陆界面
    预览截图html部分123456789101112用户登入1314邮箱名称邮箱为空15密码密码为空16登 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • This document outlines the recommended naming conventions for HTML attributes in Fast Components, focusing on readability and consistency with existing standards. ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • Microsoft即将发布WPF/E的CTP(Community Technology Preview)和SDK,标志着RIA(Rich Internet Application)技术的新里程碑。更多详情及下载链接请参见MSDN官方页面。 ... [详细]
  • 网页中正确显示英语音标的方法与实例
    在开发教育类网站时,经常遇到的一个问题是如何在网页上正确显示英语音标,以及为何某些情况下音标会显示为乱码。本文将探讨这些问题的成因及解决方案。 ... [详细]
  • 动画队列的设计目的是为了确保一系列任务能够按照预定顺序执行,每个任务只有在其前一个任务完成后才开始。这些任务既可以是同步的,也可以是异步的。本文将探讨jQuery动画系统中的队列机制,并介绍如何使用队列来优化动画效果。 ... [详细]
  • 本文详细介绍了如何在Apache Shiro框架中实现对并发登录人数的限制,包括配置和自定义过滤器的具体步骤。 ... [详细]
  • 本文基于作者使用Flask框架处理后端逻辑和原生JavaScript及jQuery进行前端开发的经验,详细介绍了如何在前后端之间高效地传输JSON数据。文章不仅涵盖了技术实现细节,还提供了实用的代码示例。 ... [详细]
  • 探索PWA H5 Web App优化之路(Service Worker与Lighthouse的应用)
    本文探讨了如何通过Service Worker和Lighthouse工具来优化PWA H5 Web App,旨在提升用户体验,包括提高加载速度、增强离线访问能力等方面。 ... [详细]
  • SonarQube配置与使用指南
    本文档详细介绍了SonarQube的配置方法及使用流程,包括环境准备、样本分析、数据库配置、项目属性文件解析以及插件安装等内容,适用于具有Linux基础操作能力的用户。 ... [详细]
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社区 版权所有