| 10楼#发布于:2004-09-02 09:17 
					<DIV align=center><TABLE #ffffd0; WIDTH: 100%; mso-cellspacing: 1.5pt; mso-padding-alt: 7.5pt 7.5pt 7.5pt 7.5pt" cellPadding=0 width="100%" bgColor=#ffffd0 border=0><TR><TD #ece9d8; PADDING-RIGHT: 7.5pt; BORDER-TOP: #ece9d8; PADDING-LEFT: 7.5pt; PADDING-BOTTOM: 7.5pt; BORDER-LEFT: #ece9d8; PADDING-TOP: 7.5pt; BORDER-BOTTOM: #ece9d8; BACKGROUND-COLOR: transparent" vAlign=top><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan; mso-outline-level: 1" align=left><B>Scalable Vector Graphics (SVG) for Web Mapping<p></p></B></P><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan; mso-outline-level: 3" align=left><B>Report in Cartographic Visualisation course at University of Gavle<p></p></B></P><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan; mso-outline-level: 3" align=left><B>Robert Siirilä 2000-11-06<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>Internet is build on open standards. There are standards for transfering data, for text documents, for requests, for images etc. To recently there was no standard for vector graphics. Web site creators have to make complicated detours to make dynamic graphics. Today we have this standard: Scalable Vector Graphics (SVG). <p></p></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>This paper gives a brief introduction to SVG, compares it with the traditional methods of map rendering. The paper further shows the some features of SVG, example implementations and discuss how to create vector maps dynamically from the server. <p></p></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left><B>Short cut to the examples:</B> <a><FONT color=#0869b3>Animated SVG</FONT></A> ¦ <a><FONT color=#0869b3>Interactive SVG</FONT></A> ¦ <a><FONT color=#0869b3>Facility Information</FONT></A><p></p></P><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan; mso-outline-level: 3" align=left><B>Introduction<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>SVG is an open-standard vector graphics language describing 2D graphics with HTML-like markup text. SVG allows for three types of graphic objects: vector graphic shapes, images and text. Graphical objects can be grouped, styled, transformed and composited into previously rendered objects. The feature set includes nested transformations, clipping paths, alpha masks, filter effects and template objects. <p></p></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>SVG can be interactive and dynamic. Animations can be defined and triggered either by embedding SMIL animation elements or via ECMAscript (Javascript). <p></p></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>A sample svg-file. The style-attribute is stylesheet CSS:
 <svg> <rect x="10" y="10" width="100" height="100" style="fill:rgb(255 255 208) ;stroke: rgb(255 208 0) ; stroke-width: 5"/> </svg> <a><FONT color=#0869b3>Sample SVG</FONT></A> <p></p></P><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan; mso-outline-level: 3" align=left><B>SVG compared to other map rendering approaches<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>Three main approaches for render graphics on the web: <p></p></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-pagination: widow-orphan" align=left><B>Raster image<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-pagination: widow-orphan" align=left>GIF, TIF, JPG, PNG and other bitmap formats.<p></p></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>Images are suitable for fuzzy objects, like a fuzzy car driving very fast in a map of Goteborg. <v:shapetype><v:stroke joinstyle="miter"></v:stroke><v:formulas><v:f eqn="if lineDrawn pixelLineWidth 0"></v:f><v:f eqn="sum @0 1 0"></v:f><v:f eqn="sum 0 0 @1"></v:f><v:f eqn="prod @2 1 2"></v:f><v:f eqn="prod @3 21600 pixelWidth"></v:f><v:f eqn="prod @3 21600 pixelHeight"></v:f><v:f eqn="sum @0 0 1"></v:f><v:f eqn="prod @6 1 2"></v:f><v:f eqn="prod @7 21600 pixelWidth"></v:f><v:f eqn="sum @8 21600 0"></v:f><v:f eqn="prod @7 21600 pixelHeight"></v:f><v:f eqn="sum @10 21600 0"></v:f></v:formulas><v:path connecttype="rect" gradientshapeok="t" extrusionok="f"></v:path><lock aspectratio="t" v:ext="edit"></lock></v:shapetype><v:shape><v:imagedata></v:imagedata><lock v:ext="edit" cropping="t"></lock><w:wrap type="square"></w:wrap></v:shape><p></p></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>Dynamic maps are created with a map engine on the server. A new image must be sended to the client when the user zooms or pans the map. The fact that images doesn't need plug-ins or applets is an advantage over vector graphics. Examples of commercial map engines with this approach: MapInfo Xtreme, AutoDesk MapGuide <p></p></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-pagination: widow-orphan" align=left><B>Binary vector graphics<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-pagination: widow-orphan" align=left>Java-applets, Macromedia Flash and Adobe PDF.<p></p></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>The server streams binary code to a client-side java-applet. The fallbacks with this approach is that a often heavy applet must be downloaded before use. Applets doesn't have the many graphical features of "real" vector formats, applets have a tendency to be slow and full with bugs. A consequense of the complicated and unforgiving nature of Java. Why use programs inside programs when it's not necessary? The binary format is favourable for map owners - no one can steal the maps. Example of commercial map engines with this approach: ESRI ArcIMS <p></p></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>Macromedia Flash and Adobe PDF need plug-ins to be rendered. They have both many, but not all, of the graphics features of SVG. But they are proprietary binary formats. To edit these you need to buy their programs. The formats are not standards neither compliant with web standards. <p></p></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>An another disadvantage of binary formats, both vector and raster, is that the different parts of the document are not visible for text-searching. They are invisible for search-engines. <p></p></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-pagination: widow-orphan" align=left><B>Text-based vector graphics<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-pagination: widow-orphan" align=left>Microsoft's Vector Markup Language (VML), Adobe's Precision Graphics Markup Language (PGML) and SVG. VML and PGML are obsolete today. SVG is a convergence of those two formats. Virtual Reality Modelling Language (VRML) is also capable to render 2D graphics.<p></p></P><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan; mso-outline-level: 3" align=left><B>Some features of SVG<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-pagination: widow-orphan" align=left><B>Scripting<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>SVG with ECMAScript. This example shows how attributes can be changed with event-handling. In this case the color-attibute and text-data of elements changes depening on the position of the mouse <p></p></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left><a><FONT color=#0869b3>Interactive SVG</FONT></A> <p></p></P><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan; mso-outline-level: 4" align=left><B>Animation<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>SVG with SMIL-animation. SMIL is a XML language for streaming media. This example shows how attributes of elements change with time. The coordinates in this case. The example also shows the graphical difference between vector graphics and raster graphics. The background is a raster image of University of Gavle. The example further shows different painting (gradients) and transparency effects. <p></p></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left><a><FONT color=#0869b3>Animated SVG</FONT></A> <p></p></P><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan; mso-outline-level: 3" align=left><B>An Example: Facility Information<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>This is an example of a dynamic map. The application shows information about the students living in House 31, which is a part of the Midgardslunden Hall of Residence. The hall is located just behind the Midgard Student Association House in Gavle. This map shows basic dynamical features. When mouse moves over an object the object gets highlighted and information is shown on the attribute table. <p></p></P><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-pagination: widow-orphan" align=left><a><FONT color=#0869b3>Facility Information</FONT></A><p></p></P><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan; mso-outline-level: 3" align=left><B>Dynamically created vector maps<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>How to extract maps from a spatial database? Which approach is preferable when user needs to collect data from different parts from a spatial database and visualize this collection on the browser? The common approach today is a map engine, combined with a webserver and a databasemanager, that produces a raster map and send it to the user's browser. <p></p></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>SVG is a markup format like html. So it would be possible to send SVG text to the browser instead of a raster image. The raster image engine would be unnecessary. XML is also a markup format, so instead of a external database it would be possible to use XML as a database format. So with this approach we need only a web server that understands XML. No raster image engines and database management systems. Easy and simple compared to the common approach. <p></p></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>We can look at the XML format as content and SVG as presentation. Now we can use XSLT (eXtended Style Language, Transformation). The XSLT extracts data from the XML database and transforms it to SVG. This could make things easier. We have to make a transformation specification, ie how to visualize different kinds of data. Then we need a dynamically made XSLT from user request to extract data from the XML database. To make dynamic XSLT is a task for the web server. <p></p></P><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan; mso-outline-level: 3" align=left><B>Conclusion<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left>Textual vector graphics would make the maps on the web more interactive and simplify the server technology. Simple means fast and more bugfree. The major problem is that this is a new approach in this area. There are not sufficient knowledge and supported software. There are lot of questions and unsolved problems, known and unknown, when moving from a theoretical idea to a real implementation. <p></p></P><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan; mso-outline-level: 3" align=left><B>References<p></p></B></P><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan; mso-outline-level: 4" align=left><B>Other standards and open source<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left><a href="http://www.libpng.org/pub/png/png.html" target="_blank" ><FONT color=#0869b3>Portable Network Graphics (PNG) Home Site</FONT></A> <a href="http://www.libpng.org/pub/mng/" target="_blank" ><FONT color=#0869b3>Multiple-Image Network Graphics (MNG)</FONT></A> <a href="http://www.jsworld.com/ecmascript/" target="_blank" ><FONT color=#0869b3>ECMAScript Tutorial</FONT></A> (ECMA-262) The only open-standard scripting language for the web<p></p></P><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan; mso-outline-level: 4" align=left><B>SVG Papers<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left><a href="http://www.w3.org/TR/SVG/" target="_blank" ><FONT color=#0869b3>W3C Scalable Vector Graphics (SVG) 1.0 Specification</FONT></A> <a href="http://www.oasis-open.org/cover/svg.html" target="_blank" ><FONT color=#0869b3>Oasis, The XML Cover Pages: W3C SVG</FONT></A> <a href="http://www.w3c.org/" target="_blank" ><FONT color=#0869b3>W3C - World Wide Web Consortium</FONT></A> The developer of SVG, XML, XSLT, HTML and more<p></p></P><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan; mso-outline-level: 4" align=left><B>SVG Software<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left><a href="http://www.sun.com/software/xml/developers/svg/" target="_blank" ><FONT color=#0869b3>Sun's SVG pages</FONT></A> Tutorials and software for Dynamic SVG rendering and more <a href="http://www.adobe.com/svg" target="_blank" ><FONT color=#0869b3>Adobe SVG Zone</FONT></A> Tutorials and download Adobe SVG Viewer <a href="http://www.ionic.be/ionic/svg/" target="_blank" ><FONT color=#0869b3>IONIC SVG Renderer</FONT></A> <a href="http://sis.cmis.csiro.au/svg/" target="_blank" ><FONT color=#0869b3>CSIRO SVG Toolkit</FONT></A><p></p></P><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan; mso-outline-level: 4" align=left><B>SVG Creations<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left><a href="http://www.pinkjuice.com/SVG/" target="_blank" ><FONT color=#0869b3>Pinkjuice</FONT></A> With the most extensive collection of links about SVG <a href="http://www.kevlindev.com/" target="_blank" ><FONT color=#0869b3>KevLinDev</FONT></A> SVG and JavaScript<p></p></P><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan; mso-outline-level: 4" align=left><B>SVG Maps<p></p></B></P><P #ffffd0; MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto; mso-pagination: widow-orphan" align=left><a href="http://www.carto.net/papers/svg/index_e.html" target="_blank" ><FONT color=#0869b3>cartpapers:svg</FONT></A> Andreas Neumann and Andre Winter - The leading svg-map makers. <p></p></P><P 0cm 0cm 0pt; TEXT-ALIGN: center; mso-pagination: widow-orphan" align=center><a href="http://www.student.hig.se/~tp98rsa/index.html" target="_blank" ><FONT color=#0869b3>Home</FONT></A> ¦ <a href="http://www.student.hig.se/~tp98rsa/geocollab/authors.html" target="_blank" ><FONT color=#0869b3>People</FONT></A> ¦ <a href="http://www.student.hig.se/~tp98rsa/geocollab/projects.html" target="_blank" ><FONT color=#0869b3>Projects</FONT></A><p></p></P><DIV class=MsoNormal style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: center; mso-pagination: widow-orphan" align=center><FONT color=#0869b3><HR align=center width="100%" SIZE=2></FONT></DIV><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-pagination: widow-orphan" align=left>© 2000 Robert Siirilä. Last revised 2001-11-10. <SCRIPT language=JavaScript type=text/javascript>
sw="none";sd="none";ref=""+escape(document.referrer);  </SCRIPT><SCRIPT language=JavaScript1.2 type=text/javascript>sw=screen.width;nav=navigator.appName;sc=(nav!="Netscape")?screen.colorDepth:screen.pixelDepth;  </SCRIPT><SCRIPT language=JavaScript type=text/javascript>function doit(str) {document.writeln(str);}qs="&sw="+sw+"&sc="+sc+"&ref="+ref;url='http://counter49.bravenet.com/index.php?';url += 'id=347629&usernum=4200230388&cpv=1';curl='http://counter49.bravenet.com/counter.php?id=347629&usernum=4200230388';doit('<a href="'+url+'" target="_blank" ><img src="'+curl+qs+'"></a>')  
<script><a href="http://counter49.bravenet.com/index.php?id=347629;usernum=4200230388;cpv=1" target="_blank" ><v:shape><v:imagedata></v:imagedata></v:shape></A><a href="http://counter49.bravenet.com/index.php?id=347629;usernum=4200230388;cpv=1" target="_blank" ><v:shape><v:imagedata></v:imagedata></v:shape></A><p></p></P></TD><TD #ece9d8; PADDING-RIGHT: 7.5pt; BORDER-TOP: #ece9d8; PADDING-LEFT: 7.5pt; PADDING-BOTTOM: 7.5pt; BORDER-LEFT: #ece9d8; PADDING-TOP: 7.5pt; BORDER-BOTTOM: #ece9d8; BACKGROUND-COLOR: transparent"><P 0cm 0cm 0pt; TEXT-ALIGN: left; mso-pagination: widow-orphan" align=left><FONT face="Times New Roman"> <p></p></FONT></P></TD></TR></TABLE></DIV><P 0cm 0cm 0pt"><FONT face="Times New Roman"> <p></p></FONT></P> | |
| 
 | 
| 11楼#发布于:2004-09-02 09:10 
					<P>关注的人比较多,呵呵。</P>
 <P>真正使用 的人比较少;首先得有项目支撑,然后得有领导支持(长时间研究)。</P> <P>SVG的技术支持也不怎么样,现在也是处于初始阶段。</P> <P>另外:SVG的应用如果不能和当前的主流GIS平台结合的话,可能推广起来比较困难,毕竟现在的GIS市场已经如火如荼,而推广只靠Micro显然不行,必须和GIS厂家联手,合作。那又是什么时候。</P> [此贴子已经被作者于2004-9-2 9:14:17编辑过] | |
| 
 | 
| 12楼#发布于:2004-09-01 11:16 
					是啊。看过一些svg的例子,功能的确很强大,希望能看到更多的应用				 | |
| 
 | 
上一页
下一页
 
			
			
						
			
			
						
			
		 
							
 
				
 
				



