SVG 新手入门
svg 入门新认知
一、第一步创建设置svg
<svg width="100%" height="500">
</svg>
设置粗细 5px 的红色线条绘制,图标是无填充的
svg {
stroke: #ff0000;
stroke-width: 5;
fill: none;
}
二、<line> 创建一条直线。
使用<line> 元素创建图标
- x1:起点的水平轴坐标
- y1:起点的竖直轴坐标
- x2:终点的水平轴坐标
- y2:终点的竖直轴坐标
通过坐标(x1,y1)来确定线的起点开始,通过(x2,y2)来确定直线的终点
让我们来创建第一条线,长为50px;起点为x1 = 10,y1 =10,则x2 = 60 ,y2 = 10
就可以看到一根直线平行于x轴
<line x1="10" y1="10" x2="60" y2="10"></line>
查看浏览器你会看到一条50px的红色线条
当然可以创建多条不一样的线条
<line x1="10" y1="10" x2="60" y2="10"></line>
<line x1="10" y1="20" x2="60" y2="20"></line>
<line x1="10" y1="30" x2="60" y2="30"></line>
效果如下
三、<polyline> 创建折线
<polyline> 元素只有一个属性:points;
我们来开始制作一个类似返回按钮的箭头,通过勾股定理来说比较明白些,我们要创建一个长度为50px的,那我们开始插入图标就是(40,0),第二个就是(0,30)转节点
<polyline points="
40 0
0 30
"></polyline>
接下来就是(40,30+30)那就是(40,60)为结点
<polyline points="
40 0
0 30
40 60
"></polyline>
同理得:结合上面的勾股定理可以得出下面效果
如果你不想这样写也可以这样2种写法写
<polyline points="40 0,0 30,40 60"></polyline>
<polyline points="40 0 0 30 40 60"></polyline>
四、<rect> 创建矩形
使用<rect> 有4个需要提供值的属性
- x:左上角的 x 轴坐标值
- y:左上角的 y 轴坐标值
- width:矩形的宽度
- height:矩形的高度
注意:你也可以使用属性 rx 和 ry 来指定矩形的圆角半径。
我们来创建一个正方形,左上角有一个偏移量3px,所以已x=“3”,y=“3”的属性值,设置他的边长为100px,则width=“100”,height=“100”
<rect x="3" y="3" width="100" height="100"></rect>
效果如下
我们进一步学习,结合上面的知识点创建一个田字,也可以自己深入研究其他图标
<rect x="3" y="3" width="100" height="100"></rect>
<line x1="3" y1="50" x2="100" y2="50"></line>
<line x1="53" y1="0" x2="53" y2="100"></line>
五、<ellipse>创建圆
这个属性类似上面一个,<ellipse>也需要4个属性,这个和上面的不一样的是,它是通过中心点来定位,而不像上面的通过左边角来定位
- cx:中心位置在 x 轴上的坐标
- cy:中心位置在 y 轴上的坐标
- rx:沿 x 轴向的半径,也就是它会把图形分割成上下两部分
- ry:沿 y 轴向的半径,也就是它会把图形分割成左右两部分
现在设计一个100px和100px的圆,所以半径为40px,则rx = “50” ry=“50”;同时又想和x,y相切,加上上面有3px偏移量,所以中心点为 53px,则cx =“53” cy=“53”来设置
<ellipse cx="53" cy="53" rx="50" ry="50"></ellipse>
这样可以得到一个圆啦!!
进一步学习
弄一个奥迪汽车标志
<ellipse cx="53" cy="53" rx="50" ry="50"></ellipse>
<ellipse cx="132" cy="53" rx="50" ry="50"></ellipse>
<ellipse cx="212" cy="53" rx="50" ry="50"></ellipse>
<ellipse cx="290" cy="53" rx="50" ry="50"></ellipse>
六、<polygon> 创建多边形
<polygon> 元素和 <polyline> 元素几乎一样。都是采用点的值来设置组成一个图案;它们不同之处是 折线 <polyline> 不是闭合的而多边形 <polygon> 是自动闭合的
弄一个五变形的图案
<polygon points="100 0,195 69, 159 181, 41 181 ,5 69" />
七、<path> 通过指定点以及点和点之间的线来创建任意形状
最灵活的生成 SVG 图形的方法,但是也是最复杂的,即 <path> 元素
属性d,d代表data,在这里,你将定义路径的所有点和线。在这个属性里,设置路径点和在点之间创建连线的命令是由诸如 M 或 L 这样的单个字母来提供的,然后是一组 x 和/或 y 坐标
<path>的命令比较多,通常比较常用的是M、L、Z
-   M 表示移动到(moveto),它用x,y值来确定起点
-   L 表示划线到(lineto)
-   Z 表示闭合路径。
创建开始建议添加一个空路径的元素
<path d="
"></path>
创建一个俄罗斯方块
一次添加一个命令,保存查看走向,这样会可以方便创建出来;
- 第一,我们移动到(20,3)开始,这个是图标的开始点。需要在属性d里面添加一个命令 M 20 3
- 接着使用L命令在起点平行于x轴画出一条60px的线段,所以命令为L 80 3;然后保存看看自己浏览器,你会看到一条直线;
- 然后用L 80 23 向下画出一条20px直线垂直于x轴的线;
- 接着用L 60 23 向左画出一条直线线,接着跟着 L 60 46
- 。。。。
- 最后一步直接用Z,它会自动闭合就出现上面的图(俄罗斯方块)
<path d="
M 20 3
L 80 3
L 80 23
L 60 23
L 60 46
L 40 46
L 40 23
L 20 23
Z
"></path>
八、<defs> 元素
目的定义可复用的图形,初始情况下 <defs> 里面的内容是不可见的;
<defs>
<!-- 图标存放这里,图标都被隐藏起来 -->
</defs>
九、<g> 创建组合对象
要把一个图标转为一个组合,用标签 <g></g> 来包裹它,然后给它一个id
例如:
<g id="lign">
<!-- 第一个实列 -->
<line x1="10" y1="10" x2="60" y2="10"></line>
<line x1="10" y1="20" x2="60" y2="20"></line>
<line x1="10" y1="30" x2="60" y2="30"></line>
</g>
<g id="back">
<!-- 返回键 -->
<polyline points="40 0 0 30 40 60"></polyline>
</g>
<g id="word">
<!-- 田字 -->
<rect x="3" y="3" width="100" height="100"></rect>
<line x1="3" y1="50" x2="100" y2="50"></line>
<line x1="53" y1="0" x2="53" y2="100"></line>
</g>
十、<use> 放置组合
获取在<defs> 中定义的复用对象并在 SVG 中显示出来。
<defs>
<g id="lign">
<!-- 第一个实列 -->
<line x1="10" y1="10" x2="60" y2="10"></line>
<line x1="10" y1="20" x2="60" y2="20"></line>
<line x1="10" y1="30" x2="60" y2="30"></line>
</g>
<g id="back">
<!-- 返回键 -->
<polyline points="40 0 0 30 40 60"></polyline>
</g>
<g id="word">
<!-- 田字 -->
<rect x="3" y="3" width="100" height="100"></rect>
<line x1="3" y1="50" x2="100" y2="50"></line>
<line x1="53" y1="0" x2="53" y2="100"></line>
</g>
</defs>
<use href="#lign" x = "5" y = "5"></use>
<use href="#back" x = "50" y = "50"></use>
<use href="#word" x = "150" y = "150"></use>
注意 <use> 标签里面的x,y 是定义到特定的位置,通过href 获取上面的图标来使用
效果如下
十一、<symbols> 创建模板对象
除开上面的组合方法,还有一个模板定义图标;模板和组合几乎一模一样,但是你要额外设置控制制视口(viewbox)和长宽比。
如果你想要把我们目前创建的图标设置为居中,图标转换成模板,然后使它们垂直填充100像素高的空间,并在这个空间中水平居中里面;
我们要将图标代码存放<symbol></symbol> 模板中,然后给他们添加一个ID;同时添加一个属性viewBox,属性让我们可以定义每个模板的可见部分应该是什么,前两个定义图标的左上角,第三和第四分别定义它的宽度和高度。
通过use调用
<!-- 第一个实列 宽:50 高:30 -->
<symbol id="lign-symbol" viewBox="0 0 50 30">
<!-- 第一个实列 -->
<line x1="10" y1="10" x2="60" y2="10"></line>
<line x1="10" y1="20" x2="60" y2="20"></line>
<line x1="10" y1="30" x2="60" y2="30"></line>
</symbol>
<!-- 返回键 宽:40 高:60 -->
<symbol id="back-symbol" viewBox="0 0 40 60">
<!-- 返回键 -->
<polyline points="40 0 0 30 40 60"></polyline>
</symbol>
<!-- 田字 宽:106 高:106 -->
<symbol id="word-symbol" viewBox="0 0 106 106">
<!-- 田字 -->
<rect x="3" y="3" width="100" height="100"></rect>
<line x1="3" y1="50" x2="100" y2="50"></line>
<line x1="53" y1="0" x2="53" y2="100"></line>
</symbol>
<use href="#lign-symbol" x="0" y="0" width="100" height="100"></use>
<use href="#back-symbol" x="0" y="100" width="100" height="100"></use>
<use href="#word-symbol" x="0" y="210" width="100" height="100"></use>
这个use 提供设置好宽度和高度为100px 的图标
效果如下
总结:
- 通过设置<svg>元素包裹整个图标
- <line>和<polyline>创建线
- <rect>创建矩形,实现田字,<ellipse>创建圆,实现一个奥迪标志,<polygon> 创建多边形实现五边形,它门实现闭合的图形
- <path> 任意创建形状,实现俄罗斯方块
- <g>组合形状,通过id标识形状
- 使用 <defs> 元素定义组合和模板
- 使用 <use> 元素来放置你定义的组合和模板。
SVG 新手入门的更多相关文章
- SVG新手入门
特点 矢量图 属性:形状的参数(都没有单位) 添加事件跟html一样 修改样式跟html一样 属性操作: setAttribute/getAttribute 图形 <svg width=&quo ...
- 原创:从零开始,微信小程序新手入门宝典《一》
为了方便大家了解并入门微信小程序,我将一些可能会需要的知识,列在这里,让大家方便的从零开始学习:一:微信小程序的特点张小龙:张小龙全面阐述小程序,推荐通读此文: 小程序是一种不需要下载.安装即可使用的 ...
- gulp的使用以及Gulp新手入门教程
Gulp新手入门教程 原文 http://w3ctrain.com/2015/12/22/gulp-for-beginners/ Gulp 是一个自动化工具,前端开发者可以使用它来处理常见任务: 搭 ...
- Gulp新手入门教程
Gulp 是一个自动化工具,前端开发者可以使用它来处理常见任务: 搭建web服务器 文件保存时自动重载浏览器 使用预处理器如Sass.LESS 优化资源,比如压缩CSS.JavaScript.压缩图片 ...
- 从零开始:微信小程序新手入门宝典《一》
为了方便大家了解并入门微信小程序,我将一些可能会需要的知识,列在这里,让大家方便的从零开始学习: 一:微信小程序的特点 张小龙:张小龙全面阐述小程序,推荐通读此文: 小程序是一种不需要下载.安装即可使 ...
- 新手入门指导:Vue 2.0 的建议学习顺序
起步 1. 扎实的 JavaScript / HTML / CSS 基本功.这是前置条件. 2. 通读官方教程 (guide) 的基础篇.不要用任何构建工具,就只用最简单的 <script> ...
- Flume NG Getting Started(Flume NG 新手入门指南)
Flume NG Getting Started(Flume NG 新手入门指南)翻译 新手入门 Flume NG是什么? 有什么改变? 获得Flume NG 从源码构建 配置 flume-ng全局选 ...
- 【原创】新手入门一篇就够:从零开发移动端IM
一.前言 IM发展至今,已是非常重要的互联网应用形态之一,尤其移动互联网时代,它正以无与论比的优势降低了沟通成本和沟通代价,对各种应用形态产生了深远影响. 做为IM开发者或即将成为IM开发者的技术人员 ...
- 课程上线 -“新手入门 : Windows Phone 8.1 开发”
经过近1个月的准备和录制,“新手入门 : Windows Phone 8.1 开发”系列课程已经在Microsoft 虚拟学院上线,链接地址为:http://www.microsoftvirtuala ...
随机推荐
- Python - 使用 xlwt 写入表格
# -*- coding: utf-8 -*- import xlwt def write_excel(): f = xlwt.Workbook() fenlei = ['一类','二类','三类', ...
- Office Shared-Addin : Favorite的下载、安装和使用(2020.2.22)
Favorite是一个可以用于Office常用组件.VBA的共用加载项,32位和64位都兼容. 如果是Office 2007及其以上版本,界面显示为Custom UI+任务窗格. 如果是Office ...
- iOS仿QQ侧滑菜单、登录按钮动画、仿斗鱼直播APP、城市选择器、自动布局等源码
iOS精选源码 QQ侧滑菜单,右滑菜单,QQ展开菜单,QQ好友分组 登录按钮 3分钟快捷创建高性能轮播图 ScrollView嵌套ScrolloView(UITableView .UICollecti ...
- asp.net 获取日期
//获取日期+时间 DateTime.Now.ToString(); // 2008-9-4 20:02:10 DateTime.Now.ToLocalTime().ToString(); // 20 ...
- The Pomodoro Technique
目录 简介 What to solve How to use Some applications 自我总结 结束语 简介 番茄工作法是简单易行的时间管理方法,是由弗朗西斯科·西里洛于1992年创立的一 ...
- JVM如何判断对象能否被回收
•写在前面说起Java和C++,很容易想到让人疯狂的指针,Java使用了内存动态分配和垃圾回收技术,让我们从C++的各种指针问题中摆脱出来,更加专心于业务逻辑,不过如果我们需要深入了解java的JVM ...
- 前端-js-长期维护
############### JS简介和JS引入 ################ <!DOCTYPE html> <html lang="en" ...
- [LC] 268. Missing Number
Given an array containing n distinct numbers taken from 0, 1, 2, ..., n, find the one that is missin ...
- spring xml 注入 map 时 map 标签报错
如图所示: 在XML配置文件中并没有问题,问题出在实体类,在类中属性 maps 用 Map定义即可,用HashMap定义就会出现如上错误 K-I-N-G-D-O-M
- spring配置ConcurrentMap实现缓存
spring本身内置了对Cache的支持,本次记录的是基于Java API的ConcurrentMap的CacheManager配置. 1.xml文件中增加命名空间 <beans xmlns=& ...