好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

HTML5 内联 SVG

在 html5 中,我们可以直接将 SVG 元素嵌入 html 页面 中

什么是SVG ?

SVG 指可伸缩矢量图形 ( scalable Vector Graphics)

SVG 用于定义用于网络的基于矢量的图形

SVG 使用 XML 格式定义图形

SVG 图像在放大或改变尺寸的情况下其图形质量不会有损失

SVG 优势

与其它图像格式相比(比如 JPEG 和 GIF),使用 SVG 有如下好处

SVG 图像可通过文本编辑器来创建和 修改
SVG 图像可被 搜索 、索引、脚本化或压缩
SVG 是可伸缩的
SVG 图像可在任何的分辨率下被高质量地打印
SVG 可在图像质量不下降的情况下被放大

浏览器 支持

Internet Explorer 9+,Firefox,Opera,Chrome,和 Safari 支持 内联 SVG

把 SVG 直接嵌入 HTML 页面

在 HTML5 中,我们可以直接将 SVG 元素嵌入 HTML 页面 中

<!DOCTYPE?html>
<svg?xmlns="http://www.w3.org/2000/svg"?version="1.1"?height="190">
??< poly gon?points="100,10?40,180?190,60?10,60?160,180"?style="fill:lime; stroke :purple; stroke -width:5;fill-rule:evenodd;">
</svg>

运行结果如下


SVG 与 canvas 之 间的 区别

SVG 是一种使用 XML 描述 2D 图形的语言,Canvas 通过 JavaScript 来绘制 2D 图形

SVG 基于 XML,这意味着 SVG DOM 中的每个元素都是可用的,我们可以为某个元素附加 JavaScript 事件处理器

在 SVG 中,每个被绘制的图形均被视为对象,如果 SVG 对象的 属性 发生变化,那么浏览器能够 自动 重现图形

Canvas 是逐像素进行渲染的,在 canvas 中,一旦图形被绘制完成,它就不会继续得到浏览器的关注,如果其位置发生变化,那么整个场景也需要重新绘制, 包括 任何或许已被图形覆盖的对象

SVG
SVG 是一种使用 XML 描述 2D 图形的语言。
SVG 基于 XML,这意味着 SVG DOM 中的每个元素都是可用的。您可以为某个元素附加 JavaScript 事件处理器。
在 SVG 中,每个被绘制的图形均被视为对象。如果 SVG 对象的 属性 发生变化,那么浏览器能够 自动 重现图形。
特点:

不依赖分辨率
支持 事件处理器
最适合带有大型渲染区域的应用程序(比如谷歌地图)
复杂度高会减慢渲染速度(任何过度使用 DOM 的应用都不快)
不适合游戏应用

Canvas
Canvas 通过 JavaScript 来绘制 2D 图形。
Canvas 是逐像素进行渲染的。
在 canvas 中,一旦图形被绘制完成,它就不会继续得到浏览器的关注。如果其位置发生变化,那么整个场景也需要重新绘制, 包括 任何或许已被图形覆盖的对象。
特点:

依赖分辨率
不支持 事件处理器
弱的文本渲染能力
能够以 .png 或 .jpg 格式保存结果图像
最适合图像密集型的游戏,其中的许多对象会被频繁重绘? ?

canvas 与 SVG 的比较

下表列出了 canvas 与 SVG 之 间的 一些不同之处

canvas sVG 依赖分辨率 不依赖分辨率 不支持 事件处理器 支持 事件处理器 弱的文本渲染能力 最适合带有大型渲染区域的应用程序(比如谷歌地图) 能够以 png 或 jpg 格式保存结果图像 复杂度高会减慢渲染速度(任何过度使用 DOM 的应用都不快) 最适合图像密集型的游戏,其中的许多对象会被频繁重绘 不适合游戏应用

HTML5 Geolocation 地理定位 ? ?HTML5 Canvas画布

查看更多关于HTML5 内联 SVG的详细内容...

  阅读:45次

上一篇

下一篇

第1节:HTML5 教程    第2节:HTML5 浏览器支持    第3节:HTML5 新元素    第4节:HTML5 Video 视频    第5节:HTML 5 Video + DOM    第6节:HTML5 内联 SVG    第7节:HTML5 新的 Input 类型    第8节:HTML5 MathML 数学公式    第9节:HTML5 Geolocation 地理定位    第10节:HTML5 Canvas画布    第11节:HTML5 拖放 ( drag 和 drop )    第12节:HTML5 Audio 音频    第13节:HTML5 Web Workers    第14节:HTML5 表单元素    第15节:HTML5 表单属性    第16节:HTML5 语义元素    第17节:HTML5 Web 存储    第18节:HTML5 Web SQL 数据库    第19节:HTML5 应用程序缓存    第20节:HTML 5 服务器发送事件    第21节:HTML5 WebSocket    第22节:HTML5 历史记录API    第23节:HTML 5 代码规范    第24节:HTML5 Canvas 描边和填充    第25节:HTML5 Canvas 绘制矩形    第26节:HTML5 Canvas 清除画布    第27节:HTML5 Canvas 渐变    第28节:HTML5 Canvas 合成    第29节:HTML5 Canvas 绘制图像    第30节:HTML5 Canvas 绘制文本    第31节:HTML5 Canvas 阴影    第32节:HTML5 Canvas 路径    第33节:HTML5 Canvas 转换    第34节:HTML5 Canvas 状态    第35节:HTML5 Canvas toDataURL()    第36节:HTML5 Canvas 像素处理    第37节:HTML5 Canvas 制作动画