`
hjk685
  • 浏览: 102568 次
  • 来自: ...
社区版块
存档分类
最新评论

转载:了解svg

 
阅读更多
 

了解SVG

分类: 前端 7424人阅读 评论(1) 收藏 举报


教程细节

·      语言: JavaScript,HTML, SVG

·      难度: 中等

·      预计阅读时间: 30 分钟

 

        SVG-可缩放矢量图形 ,是一个XML风格标记驱动的矢量图形的浏览器渲染引擎。除了IE 9.0Android V3之前版本外的所有浏览器都支持SVGCanvas也有同样的支持情况,所以问题往往表现为:我们应该使用哪种方案?

        今天,我们将全面介绍SVG,并且解释为什么我应该使用哪一个这个问题通常的答案是 “我要用它们来做什么要得到SVG的完整信息,请查看Mozilla关于此主题的文档。你还可以看看SVG DOM API


概述

        我们将首先概述SVG的一些独特的优势。 然后,用不着通读SVG所有长达80页的节点类型,我们将说明如何通过Illustrator快速的把SVG文档加入到网页中。我们还会讲讲D3.js,一个强大的、SVG控制的JavaScript库。

SVG并不只用于像素处理。


SVG的主要优点

        除了用于某些应用上跨图像或者基于Canvas的渲染之外,SVG还有相当多的优点。 SVG并不只用于进行像素处理,但是它能够很好地处理矢量图形和可编程性的矢量。

分辨率无关

        你可能不知道,分辨率无关和浏览器不可知论是近来前端开发中热议的话题(想想响应式设计)。大多数用来解决分辨率问题(例如视网膜屏幕上)的方案既导致了大量不必要的数据下载(高清图像替换)又为一个或者其他浏览器进行了妥协。这使得无线网络中更高分辨率图像的传输往往受限于数据下载速度的瓶颈。这并不理想。

        SVG提供了一种方法来提供全分辨率的图形元素:不管什么大小的屏幕,缩放比例或着分辨率。 直到SVG出现之前,我们只能通过CSS和文本渲染看到清晰的元素样式。在SVG里不需要使用div:after元素来创建简单的形状和其他效果。相反你可以创建各种矢量形状。

SVG提供了一种方法来提供全分辨率的图形元素:不管什么大小的屏幕,缩放比例或着分辨率

基于DOM节点的API

        你写HTML吗? JavaScriptCSS呢? 是的。 现在你已经知道了很多关于编写SVG的信息。 SVG实际上使用和XML兼容的格式来定义其呈现的形状。除此之外,你可以用CSS为形状添加样式,使它们与JavaScript进行交互。多个像D3.jsRaphaelJS库可以协助你。下面是一组SVG元素的例子(Envato叶子)。你也可以在JSFiddle上看到这个示例 

 

<svg>
<g>
   <g>
      <path fill="#8BAC54" d="M28.028,104.509c-35.271,44.527-36.619,105.084-7.616,150.407
         c26.073-66.957,58.919-142.287,99.378-209.543C81.802,61.428,46.351,81.377,28.028,104.509z M278.797,11.28
         c-0.408-3.492-2.227-6.447-4.845-8.41c-2.5-2.097-5.802-3.197-9.304-2.784c0,0-10.403,2.227-26.959,6.483
         C158.62,82.498,93.735,184.229,43.453,281.932c1.875,1.628,3.778,3.255,5.749,4.794c56.202,44.471,137.782,34.972,182.238-21.163
         C282.657,200.806,278.797,11.28,278.797,11.28z"/>
   </g>
   <g>
      <path fill="#B1C982" d="M58.392,293.368c59.428-95.491,133.438-188.549,220.117-247.851c0.558-20.869,0.289-34.238,0.289-34.238
         c-0.408-3.492-2.227-6.447-4.845-8.41c-2.5-2.097-5.802-3.197-9.304-2.784c0,0-10.403,2.227-26.959,6.483
         C158.62,82.498,93.735,184.229,43.453,281.932c1.875,1.628,3.778,3.255,5.749,4.794C52.185,289.102,55.271,291.308,58.392,293.368
         z"/>
   </g>
</g>
</svg>

        SVG基于DOM节点的API比起客户端侧的CanvasAPI来说,无疑具有更高的可访问性。你可以由此做到:

 

 

  • 在服务器端创建基于SVG文档的图像
  • 像其他HTML元素一样检查SVG元素
  • 通过你熟悉的技术(JSCSS)编程来处理形状、样式和位置
  • SVG节点绑定事件函数

 

        DOM API为使用SVG提供了更多一系列明显的优势。

无须不必要的HTTP请求

        当你在HTML中使用<img>标签来引入图像时,就是定义了一个用户浏览器需要请求的文件。这个请求会占用带宽,需要更多宝贵的时间来下载。如果你的图像用一组DOM节点来代替,可以减少额外的HTTP请求,使你的网站速度更快,对用户更加友好。

简单交互脚本

        尽管现在浏览器大战,跨浏览器的DOMAPI在脚本的交互性方面提供了广泛的灵活性,可以延伸到SVG元素上。可以通过CSSSVG添加样式;SVG元素支持浏览器事件API使得的通过脚本进行交互不在话下;还可以轻松的将一个事件函数绑定到SVG元素的节点上。

        这不是真正在画布上绘制的元素。由于画布是一个简单的像素渲染引擎,绘制的元素不能在内存中保存为对象。脚本将保持这些元素的收集工作,并监管所有相关的位置和大小信息来在事件循环中寻找和触发事件。除此之外,Z-index也由脚本处理。

        让我们来看看一个例子。请注意:为了保持简洁,我们将使用jQuery

 

var circleCenter = [200, 300], radius = 50;
$(window).on("mousemove", function(e){
   var mx = e.pageX, my = e.pageY;
   if (mx > circleCenter[0] - radius && mx < circleCenter[0] + radius && my > circleCenter[1] - radius && my < circleCenter[1] + radius){
      // now we are hovering
   }
 
});

 

        相比之下,我们可以看到使用SVG可以更简单的完成相同任务。

 

$("svg path#circle").on("hover", function(event){
   // That's all.
});

 

        显然开发者编写简单交互的脚本来说效率更高。

实际应用

        有大量的Canvas相关的JS库(例如KineticJS可以让你实现一些酷炫的功能)。但如果你像我一样,就不会在你的Web应用里使用完全的物理引擎。作为替代,我最经常需要可扩展的图标、交互图以及详细的、美观的方式来把信息呈现给用户。大多数我需要的图形就是简单易用的公式。这些图形元素很容易的使用SVG来创建,许多简单的物理方程可以处理你的这些需求。所以让我们来看看SVG的一些实际应用。

图形
        因为SVG最大的优势是基本的矢量形状,自然非常适用于图形和信息图表。它不仅非常适合用来从给定的数值创建静态的图表,还适用于“实时的”图形:通过AJAX请求、用户输入或者随机生成的数据生成。

路线图
        路线图由坚硬的线条和精确的形状组成。这些形状可以用向量图形很好的展示。

复杂的UI元素

        例如现在你需要一个UI元素,看上去像圆圈金字塔。你如何用HTMLCSS来实现?好吧,你要先为每一个洞创建一堆的div,为它们每个赋予确定的圆角边框和边框样式。然后你要使用一个div容器来定位它们。现在你如果想要一个整体的渐变该如何实现?你可能必须要使用Mask,或者一些其他技术。我们宁可不使用图像,因为它们不可扩展,而且不能用可编程的方式来重新渲染或者改变。相反,为什么不在Illustrator中绘制元素,并且将它保存为一个SVG文件?这将会让你有一个单独的、可扩展的元素,并且不用担心多个div的管理。

Logos
        多数标志都是基于矢量的。你可以为你的Logo定义一个SVG文档,并且把它放到任何地方,随时缩放为任何尺寸,而完全不需要牺牲质量或者占用过多的带宽。

简单游戏
        Canvas
适合游戏渲染,这并不是秘密。另外的原因是游戏往往不依赖于矢量图形,相反它们使用基于像素的艺术字和动画。然而,SVG对于需要更少字符动画和更多信息展示的游戏来说是一个很棒的选择(例如数独游戏)。


为什么你可能不使用SVG

        现在我们已经看过了许多SVG的优点,让我们来看看许多开发者为什么仍然选择不使用SVG。最主要有两个原因:

        1、他们从来没有听说过SVG或者从没想过需要它,所以都忽略了(这不再是借口!)

        2、 SVG XML文档看起来相对古老和复杂,好像使用图像更加简单。

        当然没有任何人想手动编辑SVG XML里的一个个点。幸运的是,没有人需要这么做。这是人们常常没有意识到的部分,这里有许多工具来编辑SVG,所以你永远不需要手动来做这件事。


SVG工具

Illustrator,Inkscape

        这个矢量编辑器最有可能把你的文件保存为SVG。立即来试试吧!打开Illustrator,画一两个圆,并且把文件保存为SVG。然后在Sublime或者其他文本编辑器中打开,你能够立即看到,除了一些额外的元数据,SVGXML可以马上应用到HTML中。你最有可能看到<g>标签(group),<path>标签(path)以及<svg>元素。

D3.js

        虽然你完全可以把SVG XML直接拖放到一个HTML文件中,但是当你想要动态创建SVG时怎么办?D3.js是一个基于数据操作文档的JS库。换句话说,它的伟大之处在于可以基于一系列的数据生成例如条形图和线状图的SVG元素。我们选择展示D3是因为它符合浏览器里SVG实际实现的词汇,请注意另外还有一些很棒的非标准SVG库(值得注意的是Raphael.js)。

        D3.jsSVG处理外还提供其他更多功能。(请确保你查看了D3.js官网上的示例和这个讨论

示例一:脉冲圈

        在第一个例子里,我们使用Math.sinsetInterval构造的迭代器简单的创建一个脉冲圈。

 

示例二:更新线状图

        在这个例子里,我们将用一些随机值更新绘制的线状图。

 


什么时候不用SVG

        SVG可以处理很多浏览器里的图像渲染需求。虽然我们有很多使用SVG的理由,但是就像任何伟大的事物一样,也有一些地方它表现不是很好。

 

  • 如果你需要渲染上千个节点,更高性能的办法是在Canvas上进行。
  • 如果你的应用需要IE8的支持,记得你需要提供另外一个备用的向量(例如更复杂的 VML),或者依靠响应式的图像来完全替代向量。

 


有用链接

        这里有一些有用的连接,可以帮助你更好的了解SVG

 

 

        你还发现了SVG的其他用途吗?请在评论中告诉我们,还要感谢你的阅读。

        译自:http://net.tutsplus.com/tutorials/why-arent-you-using-svg/

        转载请注明:来自蒋宇捷的博客

分享到:
评论

相关推荐

    SVG和Canvas绘图:使用SVG创建基本形状.docx

    SVG和Canvas绘图:使用SVG创建基本形状.docx

    glide加载和下载svg矢量图片

    implementation 'com.caverock:androidsvg:1.3.1' ``` 3. 创建SVG模型类: - 为了在Glide中使用SVG,我们需要创建一个自定义的`GlideModule`,并实现`Encoder`接口,以便将SVG对象编码为字节数组。 - 示例代码...

    svg 学习 资料 合集

    1. 矢量图与位图:了解SVG作为矢量图与传统的位图(如JPEG、PNG)之间的区别,理解矢量图不受分辨率限制的优势。 2. SVG结构:学习SVG的基本结构,包括SVG根元素、视口、坐标系统以及如何创建形状。 3. 基本形状:...

    Android-使用Glide在Android中加载SVG

    implementation 'com.caverock:androidsvg:1.3.3' } ``` 然后,我们需要创建一个自定义的Glide模块,以便于处理SVG的解析和转换。创建一个新的Java类,例如`SvgModule`,并实现`GlideModule`接口: ```java ...

    jaxb-svg11-1.0.2-API文档-中文版.zip

    赠送jar包:jaxb-svg11-1.0.2.jar; 赠送原API文档:jaxb-svg11-1.0.2-javadoc.jar; 赠送源代码:jaxb-svg11-1.0.2-sources.jar; 赠送Maven依赖信息文件:jaxb-svg11-1.0.2.pom; 包含翻译后的API文档:jaxb-svg11...

    SVG和Canvas绘图:SVG和Canvas的性能优化技巧.docx

    SVG和Canvas绘图:SVG和Canvas的性能优化技巧.docx

    SVG:ms svg库的分支(http:svg.codeplex.com)

    SVG.NET C#SVG渲染库在Codeplex上的公共派生: ://svg.codeplex.com/ 最初,这是一个较小的修改,可以写入正确的SVG字符串。 但是现在,经过将近两年的修复和改进,我们决定与公众共享当前的代码库,以进一步改进...

    SVG6000用户手册V3.2

    SVG6000 用户手册 V3.2 本手册是星网数码 SVG6000 用户手册 V3.2 的知识点总结,涵盖了 SVG6000 的系统概述、硬件配置、软件配置、短信管理、业务特性说明等方面的知识点。 系统概述 * 系统简介:SVG6000 是一款...

    Android-ChinaMap利用xml解析SVG文件绘制中国省份地图

    implementation 'com.caverock:androidsvg:1.5' } ``` 然后同步项目,使库生效。 2. **SVG文件准备** 在这个案例中,我们有一个名为"ChinaMap"的SVG文件,其中包含了中国所有省份的矢量数据。SVG文件由XML结构...

    Python实现程序:SVG图片转为ico图标

    使用场景:很多时候下载的图片都是SVG矢量文件,不适用于需要 ico图片 的场景。 举例说明:比如,iconfont网站上下载的图标资源。 功能描述:此程序使用Python编写 1. 可以将 单个SVG图片文件 转换为 【128/64/48/32...

    SVG精髓图书英文版

    1. **SVG基础知识**:介绍SVG的基本概念,包括SVG文件结构、元素类型以及属性设置,帮助读者了解如何创建和编辑SVG图形。 2. **SVG元素**:讲解各种SVG图形元素,如矩形、圆形、线条、曲线、路径等,以及如何使用...

    C#代码 SVG 编辑

    首先,了解SVG的基本结构至关重要。SVG文件由一系列的路径数据、形状、文本、渐变、蒙版、滤镜等元素组成。在C#中,我们可以利用.NET Framework或.NET Core中的库来解析和操作这些元素。 一个常用的C# SVG处理库是...

    胜利者:Ruby SVG Image Builder

    Victor-Ruby SVG图像生成器 Victor是直接的Ruby到SVG的构建者。 所有方法调用都直接转换为SVG元素。 目录 安装 $ gem install victor 或使用捆绑器: gem 'victor' 例子 require 'victor' svg = Victor :: SVG . ...

    毕设项目:基于SVG的自动站雨量分析系统(asp.net+源代码+论文)

    2 SVG技术 1 2.1 XML介绍 1 2.2 SVG介绍 2 2.3 SVG的特点 2 2.4 SVG规范 2 3 雨量分析系统的需求分析 4 3.1 系统需求 4 3.2 功能分析 4 3.3 用例分析 5 4 雨量分析系统的设计 6 4.1 系统模块结构 6 4.2 数据库的设计...

    这是一个svg文件包svg.rar

    SVG,全称Scalable Vector Graphics,是一种基于XML(可扩展标记语言)的矢量图形格式。这种格式允许用户创建可缩放的图形,而不会损失图像质量,因此在网页设计、应用程序图标、UI设计等领域广泛应用。SVG文件不...

    vscode-svg-previewer:Vscode SVG预览器

    重新打开编辑器”(通过命令面板) 选择“图像查看器”并将其设置为默认值命令: 命令描述SVG:打开预览将预览打开到活动视图列SVG:打开侧面预览打开预览到侧视图列SVG:显示源活动预览的开源文件设定: 财产描述...

    remove-svg-properties:从 SVG 中删除属性和样式

    删除-svg-属性 从 SVG 中删除属性和样式 安装 使用安装 npm install remove-svg-properties --save 用法 var rsp = require ( ‘remove - svg - properties’ ) ; rsp . remove ( options ) ; 选项 以下值是...

    wmf2svg-0.9.8-API文档-中文版.zip

    Maven坐标:net.arnx:wmf2svg:0.9.8; 标签:arnx、wmf2svg、中文文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持...

    Animated-SVG:动画SVG文件

    动画SVG(Scalable Vector Graphics)是一种用于创建交互式和动态图形的技术,广泛应用于网页设计、应用程序...在"Animated-SVG-master"这个压缩包中,很可能包含了示例代码和教程,帮助学习者深入了解和实践这些技术。

    svg:提供SVG解析和渲染

    您可以使用 haxelib 轻松安装 SVG: haxelib install svg 要将其添加到 Lime 或 OpenFL 项目,请将其添加到您的项目文件中: 用法 package ; import format . SVG ; import openfl . display . Sprite ; import...

Global site tag (gtag.js) - Google Analytics