可缩放向量图形
Template:Expand language Template:BrowserUpdate Template:NoteTA 脚本错误:没有“Infobox”这个模块。Template:Template other脚本错误:没有“Check for unknown parameters”这个模块。
可缩放矢量图形(Template:Langx,缩写:脚本错误:没有“Lang”这个模块。)是一种基于可扩展标记语言(XML),用于描述二维矢量图形的图形格式。SVG由W3C制定,是一个开放标准。
SVG概述[编辑]
SVG由1998年成立的W3C SVG工作组启动开发,随着当年提交给W3C的六份标准提案而开展。
SVG允许3种图形物件类型:矢量图形、栅格图像以及文本。图形物件——包括PNG、JPEG这些栅格图像——能够被编组、设计、转换及整合进先前的渲染物件中。文本可以在任何适用于应用程序的XML命名空间之内,从而提高SVG图形的搜索能力和无障碍性。SVG提供的功能集涵盖了嵌套转换、脚本错误:没有“ilh”这个模块。、Alpha通道、滤镜效果、模板对象以及可扩展性。
SVG严格遵从XML语法,并用文本格式的描述性语言来描述图像内容,因此是一种和图像分辨率无关的矢量图形格式。
优点[编辑]
- 图像文件可读,易于修改和编辑(理论上如此,但实际上却是因为各种不同的SVG档编辑器而可能储存成不易解读的SVG档案)。
- 与现有技术可以互动融合。例如,SVG技术本身的动态部分(包括时序控制和动画)就是基于SMIL标准。另外,SVG文件还可嵌入JavaScript(严格地说,应该是ECMAScript)脚本来控制SVG对象。
- SVG图形格式可以方便的建立文字索引,从而实现基于内容的图像搜索。
- SVG图形格式支持多种滤镜和特殊效果,在不改变图像内容的前提下可以实现位图格式中类似文字阴影的效果。[1]
- SVG图形格式可以用来动态生成图形。例如,可用SVG动态生成具有交互功能的地图,嵌入网页中,并显示给终端用户。[2]
缺点[编辑]
- SVG的本地运行环境下的厂家支持程度。
- 由于原始的SVG档是遵从XML语法,导致资料采用未压缩的方式存放,因此相较于其他的矢量图形格式,同样的档案内容会比其他的档案格式稍大。Adobe因此使用gzip压缩开发出压缩的SVG档格式,附档名为 .svgz, 但此种档案格式除了Adobe旗下的软件以外,未被广泛支援使用。
- 旧版的SVG Viewer无法正确显示出使用新版SVG格式的矢量图形。
SVG Basic[编辑]
SVG Basic又称SVGB,是英语“Scalable Vector Graphics, Basic Profile”的简写,可以翻译为“可缩放的矢量图形标准的基本版”。它是SVG的一个子集,而主要目标是为掌上电脑等高端移动设备提供矢量图形显示格式。
SVG Tiny[编辑]
SVG Tiny又称SVGT,是英语“Scalable Vector Graphics, Tiny Profile”的简写,可以翻译为“可缩放的矢量图形标准的微型简化版本”。它也是SVG的一个子集,而主要目标是为手机等低端移动设备提供矢量图形显示格式。
SVG动画[编辑]
脚本错误:没有“main”这个模块。
SVG技术细节[编辑]
SVG主要支持以下几种显示对象:
SVG可以实现动态和交互功能。在DOM模型的基础上,SVG开发设计人员可以利用ECMAScript或者SMIL来进行时序控制或对象的操纵。SVG虽然是文本格式,但是SVG支持利用gzip压缩算法减少文件尺寸,压缩后的文件通常用被称为“SVGZ文件”。
开发历史[编辑]
SVG由1998年成立的W3C SVG工作组启动开发,随着当年提交给W3C的六份标准提案应运而生:
- Web Schematics,来自CCLRC[3]
- Template:Le,来自Adobe Systems、IBM、网景和升阳电脑[4]
- VML,来自Autodesk、惠普、Macromedia、微软和Vision[5]
- Hyper Graphics Markup Language (HGML),来自Template:Le和普利茅斯大学[6]
- WebCGM,来自波音、InterCAP Graphics Systems、Inso Corporation、CCLRC和施乐[7]
- DrawML,来自Excosoft AB[8]
当时工作组是由W3C的Chris Lilley领衔。
SVG 1.x[编辑]
- 2001年9月4日,发布SVG 1.0。
- 2003年1月4日,发布SVG 1.1。
- 2003年1月14日,推出SVG移动子版本:SVG Tiny和SVG Basic。
- 2008年12月22日,发布SVG Tiny 1.2。[9]
- 2011年8月16日,发布SVG 1.1(第2版),成为W3C目前推荐的标准。[10]
- SVG Tiny 1.2 Portable/Secure是SVG Tiny 1.2较安全的一个子集,于2020年7月29日作为IETF草案标准推出。[11]
SVG 2[编辑]
SVG 2弃用了SVG 1.1不受所有浏览器支援的功能,并整合了HTML5和Web开放字型格式(WOFF)的新功能:[12]
- SVG 2以WOFF取代了多个字体元素,像是
glyph和altGlyph。 xml:space属性已被弃用,由CSS取而代之。- 新增HTML5的功能,例如
translate和data-*属性。 - SVG Tiny 1.2的文字处理功能在注释中提及,但尚未在文本中正式化。[13]虽然1.2版中的其他功能也是精心挑选的,[12]但是整体而言,SVG 2并不是SVG tiny 1.2的超集。
W3C目前仍正在研究制定SVG 2,SVG 2于2016年9月15日进入候选推荐阶段,[14]修订版本于2018年8月7日和2018年10月4日发布。[15]最新草案则于2023年3月8日发布。[16]
示例[编辑]
-
示例SVG显示
-
简单SVG图片,样如少女。
-
较为复杂但精细的SVG图片
SVG格式是XML的一种,意即SVG文件其实只是普通的文本文件,用一般的文本编辑器便可查看或修改。
<?xml version="1.0"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN"
"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg xmlns="http://www.w3.org/2000/svg" version="1.1"
width="467" height="462">
<!-- This is the red square: -->
<rect x="80" y="60" width="250" height="250" rx="20" fill="red"
stroke="black" stroke-width="2px" />
<!-- This is the blue square: -->
<rect x="140" y="120" width="250" height="250" rx="40" fill="blue"
stroke="black" stroke-width="2px" fill-opacity="0.7" />
<rect x="180" y="160" width="250" height="250" rx="40" fill="blue"
stroke="green" stroke-width="2px" fill-opacity="0.7" />
</svg>
SVG显示[编辑]
比较著名的SVG项目包括Mozilla SVG Project[17],KDE的KSVG,以及Amaya等。
- Mozilla Firefox自版本1.5发行后,即开始支援SVG格式的显示 。[18]
- Opera 8.0 版开始支援显示Tiny 1.1规格的SVG。
- 基于Java的SVG项目主要有Batik SVG Toolkit等。
- Google Chrome和Safari支持SVG显示。
- Microsoft的Internet Explorer 8.0版及其更老的版本尚未支援SVG,直至由Internet Explorer 9.0版开始支援SVG。[19]
设计工具[编辑]
能够设计SVG图形作品的软件工具包括开放源代码的Inkscape、Scribus和Karbon等,还有专有的Adobe Illustrator、Adobe Animate和CorelDRAW等。
另外也有开放源码、功能简单但容易操作、免安装的在线SVG设计工具,例如Svg-edit。[20]
对于移动设备,安卓系统则可以使用Vector Ink。[21]
参见[编辑]
参考文献[编辑]
- ↑ Template:Cite Web
- ↑ Template:Cite Web
- ↑ Template:Cite web
- ↑ Template:Cite web
- ↑ Template:Cite web
- ↑ Template:Cite web
- ↑ Template:Cite web
- ↑ Template:Cite web
- ↑ Template:Cite web
- ↑ 引用错误:
<ref>标签无效;未给name(名称)为SVG1.1SE的ref(参考)提供文本 - ↑ Template:Cite news
- ↑ 12.0 12.1 Template:Cite web
- ↑ Template:Cite web
- ↑ Template:Cite web
- ↑ Template:Cite web
- ↑ Template:Cite web
- ↑ Template:Cite web
- ↑ Template:Cite web
- ↑ Template:Cite web
- ↑ 脚本错误:没有“citation/CS1”这个模块。
- ↑ Template:Cite web
外部链接[编辑]
- Template:Official websiteTemplate:WaybackTemplate:Error(说明)如果在角色介绍看到此讯息,请参考这个条目修改源代码。
- svgwikiTemplate:Error(说明)如果在角色介绍看到此讯息,请参考这个条目修改源代码。
- SVG WebTemplate:WaybackTemplate:Error(说明)如果在角色介绍看到此讯息,请参考这个条目修改源代码。
- Opera开发网站上关于SVG的展示及教程Template:Error(说明)如果在角色介绍看到此讯息,请参考这个条目修改源代码。
- W3school上关于SVG的教程 Template:Wayback
脚本错误:没有“Navbox”这个模块。 脚本错误:没有“Navbox”这个模块。 Template:Navbox with collapsible sections