一.什么是SVG
- SVG 指可缩放矢量图形(Scalable Vector Graphics)。
- 用来定义用于网络的基于矢量的图形。使用XML格式定义图形。
- 图像在放大或改变尺寸的情况下其图形质量不会有所损失。
- 是万维网联盟的标准。
- 与诸如DOM和XSL之类的W3C标准是一个整体
二.与其他图像格式相比,使用SVG的优势在于
- SVG可被非常多的工具读取和修改(比如记事本)。
- 与JPEG和GIF图像比起来,尺寸更小,且可压缩性更强。是可伸缩的。
- 图像可在任何的分辨率下被高质量地打印。可在图像质量不下降的情况下被放大。
- 图像中的文字是可选的,同时也是可搜索的(很适合制作地图)。
- 可以与Java技术一起运行。是开放的标准。文件是纯粹的XML。
- 与Flash相比,SVG最大的优势是与其他标准(eg:XSL和DOM)相兼容。而Flash则是未开源的私有技术。
三.查看SVG文件
所有浏览器均支持SVG文件,不过Internet Explorer需要安装插件。插件是免费的(eg:Adobe SVG Viewer)
四.SVG文件可通过<embed>、<object>、<iframe>标签嵌入HTML文档
<embed>标签被所有主流的浏览器支持,并允许使用脚本。
注:当在HTML页面中嵌入SVG时使用<embed>标签是Adobe SVG Viewer推荐的方法!然而,如果需要创建合法的 XHTML,就不能使用 <embed>。任何 HTML 规范中都没有 <embed> 标签。
语法:
<embed src="rect.svg" width="300" height="100"
type="image/svg+xml"
pluginspage="http://www.adobe.com/svg/viewer/install/" />
注:pluginspage 属性指向下载插件的 URL
<object> 标签是 HTML 4 的标准标签,被所有较新的浏览器支持。它的缺点是不允许使用脚本。
注:假如您安装了最新版本的 Adobe SVG Viewer,那么当使用 <object> 标签时 SVG 文件无法工作(至少不能在 IE 中工作)!
语法:
<object data="rect.svg" width="300" height="100"
type="image/svg+xml"
codebase="http://www.adobe.com/svg/viewer/install/" />
注:codebase 属性指向下载插件的 URL。
<iframe> 标签可工作在大部分的浏览器中。
语法:
<iframe src="rect.svg" width="300" height="100">
</iframe>
SVG 形状
SVG 有一些预定义的形状元素,可被开发者使用和操作:
- 矩形 <rect>
- 圆形 <circle>
- 椭圆 <ellipse>
- 线 <line>
- 折线 <polyline>
- 多边形 <polygon>
- 路径 <path>