SVG 学习(一)
SVG 意为可缩放矢量图形(Scalable Vector Graphics)。
SVG 使用 XML 格式定义图像。
什么是SVG?
- SVG 指可伸缩矢量图形 (Scalable Vector Graphics)
- SVG 用来定义用于网络的基于矢量的图形
- SVG 使用 XML 格式定义图形
- SVG 图像在放大或改变尺寸的情况下其图形质量不会有所损失
- SVG 是万维网联盟的标准
- SVG 与诸如 DOM 和 XSL 之类的 W3C 标准是一个整体
SVG 的历史和优势
在 2003 年一月,SVG 1.1 被确立为 W3C 标准。
参与定义 SVG 的组织有:太阳微系统、Adobe、苹果公司、IBM 以及柯达。
与其他图像格式相比,使用 SVG 的优势在于:
- SVG 可被非常多的工具读取和修改(比如记事本)
- SVG 与 JPEG 和 GIF 图像比起来,尺寸更小,且可压缩性更强。
- SVG 是可伸缩的
- SVG 图像可在任何的分辨率下被高质量地打印
- SVG 可在图像质量不下降的情况下被放大
- SVG 图像中的文本是可选的,同时也是可搜索的(很适合制作地图)
- SVG 可以与 Java 技术一起运行
- SVG 是开放的标准
- SVG 文件是纯粹的 XML
SVG 的主要竞争者是 Flash。
与 Flash 相比,SVG 最大的优势是与其他标准(比如 XSL 和 DOM)相兼容。而 Flash 则是未开源的私有技术。
查看 SVG 文件
今天,所有浏览器均支持 SVG 文件,不过需要安装插件的 Internet Explorer 除外。插件是免费的,比如 Adobe SVG Viewer。
以上说明来源于w3c
接下来开始正式进入svg学习.........................
1、首先看一个例子svg圆和文字的创建
<!--svg圆和文字-->
<svg id="diag" width="400" height="400" style="border:1px solid #000;">
<circle cx="50" cy="50" r="50"/>
<text y="100" x="100" font-family="Arial" font-size="60px" fill="#f00" text-anchor="left">
SVG 文本
</text>
</svg>
2、SVG 绘制矩形
<svg width="200" height="200">
<rect x="10" y="10" width="100" height="100" stroke="red" fill="#ccc" />
</svg> stroke="red" 红色边框 fill="#ccc"灰色填充色
3、SVG 绘制圆形
<svg width="200" height="200">
<rect x="10" y="10" width="100" height="100" stroke="red" fill="#ccc" />
<circle cx="50" cy="50" r="40" stroke="#00f" fill="none" stroke-width="8"/>
</svg> cx="50" 圆心的x坐标值
cy="50" 圆心的y坐标值
r="40" 圆的半径
fill="none" 不添加填充
stroke-width="8" 边框宽度为8
stroke="#00f" 边框颜色
4、svg的变换
<svg width="200" height="200">
<g transform="translate(60,0) rotate(30) scale(0.75)" id="sh_group">
<rect x="10" y="10" width="100" height="100" stroke="#ccc" fill="#ccc"/>
<circle cx="100" cy="100" r="40" stroke="#f00" fill="none" stroke-width="5"/>
</g>
</svg> <g></g> 代表一个组,可以将多个元素结合起来
transform:变换
translate(60,0) 平移到60x 0y
rotate(30) 旋转30度
scale(0.75) 缩放到之前的0.75倍
5、svg复用内容
<svg width="200" height="200">
<defs>
<g id="sh_group">
<rect x="10" y="10" width="100" height="100" stroke="#ccc" fill="#ccc"/>
<circle cx="100" cy="100" r="40" stroke="#f00" fill="none" stroke-width="5"/>
</g>
</defs>
<use xlink:href="#sh_group" transform="translate(60,0) rotate(30) scale(0.75)"/>
<use xlink:href="#sh_group" transform="translate(120,80) rotate(30) scale(0.45)"/>
<use xlink:href="#sh_group" transform="translate(20,60) rotate(30) scale(0.25)"/>
</svg> defs 用于定义留待将来使用的内容。
use 用来链接到defs元素定义的内容。
6、为矩形和圆形添加纹理
<svg width="200" height="200">
<defs>
<pattern id="grap" patternUnits="userSpaceOnUse" x="0" y="0" width="100" height="67" viewBox="0 0 100 67">
<image x="0" y="0" width="100" height="67" xlink:href="https://www.baidu.com/img/bd_logo1.png"></image>
</pattern>
<linearGradient id="redBLackGradient">
<stop offset="0%" stop-color="#000"></stop>
<stop offset="100%" stop-color="#f00"></stop>
</linearGradient>
</defs>
<rect width="100" height="80" x="10" y="20" stroke="red" fill="url(#redBLackGradient)"/>
<circle cx="120" cy="80" r="40" stroke="#00f" stroke-width="8" fill="url(#grap)" />
</svg> pattern 定义一个待填充的图像
linearGradient:定义一个渐变
stop:设置渐变的开始值以及结束值
fill="url(#redBLackGradient)加载预设的纹理或者渐变
7、svg路径
<svg width="300" height="300">
<path d="M-25,-50L-10,-80L-20,-80L-5,-110L-15,-110L0,-140L15,-110L5,-110L20,-80L10,-80L25,-50Z" fill="#f00" transform="translate(100,200)" id="can">
</path>
</svg> path:自由形态的路径
d:代表数据
M:代表moveTo 移动到某一点
L:代表lineto 划线至
Q:代表二次曲线
Z:代表闭合路径
8、svg 二次曲线路径
<svg width="400" height="400">
<defs>
<pattern id="gd" patternUnits="userSpaceOnUse" x="0" y="0" width="100" height="67" viewBox="0 0 100 67">
<image x="0" y="0" width="100" height="67" xlink:href="https://www.baidu.com/img/bd_logo1.png"></image>
</pattern>
</defs>
<g transform="translate(-10,350)" stroke-width="20" stroke="url(#gd)" stroke-linejoin="round">
<path d="M0,0Q170,-50 260,-190Q310,-250 410,-250" fill="none">
</path>
</g>
</svg>
stroke-linejoin="round":这段代码作用是让二次曲线的接口处变圆滑
9、svg 文本
<svg width="600" height="200">
<text x="10" y="60" font-family="Arial" stroke="#0ff" font-size="40px" font-weight="bold">
dfksfgjfgdj
</text>
</svg>
定义的方法和css定义基本差不多
SVG 学习(一)的更多相关文章
- [翻译svg教程]svg学习系列 开篇
目录 [翻译svg教程]svg学习系列 开篇 [翻译svg教程 ]svg 的坐标系统 [翻译svg教程]svg 中的g元素 [翻译svg教程]svg中矩形元素 rect [翻译svg教程]svg中的c ...
- HTML5实战——svg学习
百度百科: SVG可缩放矢量图形(Scalable Vector Graphics)是基于可扩展标记语言(XML),用于描述二维矢量图形的一种图形格式.SVG是W3C制定的一种新的二维矢量图形格式,也 ...
- SVG 学习<八> SVG的路径——path(2)贝塞尔曲线命令、光滑贝塞尔曲线命令
目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...
- SVG 学习<七> SVG的路径——path(1)直线命令、弧线命令
目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...
- SVG 学习<六> SVG的transform
目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...
- SVG 学习<五> SVG动画
目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...
- SVG 学习<四> 基础API
目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...
- SVG 学习<三>渐变
目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...
- SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组
目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...
随机推荐
- DDD领域驱动设计仓储Repository
DDD领域驱动设计初探(二):仓储Repository(上) 前言:上篇介绍了DDD设计Demo里面的聚合划分以及实体和聚合根的设计,这章继续来说说DDD里面最具争议的话题之一的仓储Repositor ...
- vs2010公布时去除msvcp100.dll和msvcr100.dll图讲解明
近期开发个程序,Copy到虚拟机环境中測试时提示缺少msvcr100.dll,于是想到编译时设置选项去除依赖. 什么是 msvcr100.dll MS = Microsoft V = Visual C ...
- ImageView建立selector在录音中遇到的小问题及解决方案
随着两张照片做了一个selector,采用ImageView的src要么background采用selector当点击,总不会出现点击效果,这就是为什么?经过一番折腾,后来发现"揭秘&quo ...
- ScrollView 在嵌套 ViewPager 时出现的问题
1.在ViewPager 外面嵌套ScrollView 时导致ViewPager 中内容不显示,解决的办法是在ScrollView 标签下增加 android:fillViewport="t ...
- Rust这个新的语言
Rust这个新的语言 Rust初步(七):格式化 摘要: 在Rust中,如果要进行屏幕输出,或者写入到文件中,需要对数据进行格式化.这一篇总结一下它所支持的几种格式化方式. 这篇文章参考了以下官方文档 ...
- MEF实现设计上的“松耦合”
C#进阶系列——MEF实现设计上的“松耦合”(二) 前言:前篇 C#进阶系列——MEF实现设计上的“松耦合”(一) 介绍了下MEF的基础用法,让我们对MEF有了一个抽象的认识.当然MEF的用法可能 ...
- 3D数学学习笔记——笛卡尔坐标系
本系列文章由birdlove1987编写.转载请注明出处. 文章链接: http://blog.csdn.net/zhurui_idea/article/details/24601215 1.3D数学 ...
- 光流和KLT
一 光流 光流的概念是Gibson在1950年首先提出来的. 它是空间运动物体在观察成像平面上的像素运动的瞬时速度.是利用图像序列中像素在时间域上的变化以及相邻帧之间的相关性来找到上一帧跟当前帧之间存 ...
- POI使用汇总
POI它是apache下一步行为office有关格源工具.我们近期在使用这个框架实现Excel格式数据的导入和导出功能.这里进行一个使用总结.POI提供两种读写API模型:事件模型(eventmode ...
- 【日报C在23】堆和栈的深入了解
每日一C之堆与栈的深入理解 每天拾一个C语言贝壳,厚积薄发,积跬步以致千里. 今日贝壳:内存中堆与栈的深入理解.认识一个清晰地内存 假 ...