新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论SVG, GML, X3D, VRML, VML, XAML, AVALON, Batik等基于XML的图形技术,以及有关GIS的应用。
    [返回] 中文XML论坛 - 专业的XML技术讨论区XML.ORG.CN讨论区 - 高级XML应用『 SVG/GML/VRML/X3D/XAML 』 → Svg脚本编程简介(一) 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 7983 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: Svg脚本编程简介(一) 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     卷积内核 帅哥哟,离线,有人找我吗?
      
      
      威望:8
      头衔:总统
      等级:博士二年级(版主)
      文章:3942
      积分:27590
      门派:XML.ORG.CN
      注册:2004/7/21

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给卷积内核发送一个短消息 把卷积内核加入好友 查看卷积内核的个人资料 搜索卷积内核在『 SVG/GML/VRML/X3D/XAML 』的所有贴子 访问卷积内核的主页 引用回复这个贴子 回复这个贴子 查看卷积内核的博客楼主
    发贴心情 Svg脚本编程简介(一)

    本文主要介绍SVG的脚本编程,并分别给出放大、缩小,查询,鼠标事件等实例。

    一、           SVG简介

    SVG,全称为Scalable Vector Graphics(可伸缩矢量图形)。它是W3C制定的、用矢量描述图形的XML应用标准。它有着许多的优点,比如可扩充性(scalable),动态的,交互性强。SVG支持无极放大,对SVG图片进行任意比例的放大都不会损害图片的显示(没有太多的失真),其他诸如BMP,JPEG格式的图片都不支持无级放大。SVG有动画元素,只要在SVG文件中嵌入SVG动画元素就可以实现动画效果了。同时SVG也定义了丰富的事件,包括鼠标事件和键盘事件,只要对SVG进行相关的脚本编程就可以实现SVG文件的交互操作。

    SVG带有许多基本的图形元素,只要通过组合基本图形元素就可以构建出SVG文件。

    二、           SVG脚本编程

    在SVG中,可以通过脚本编程来实现一些比较复杂的交互操作。SVG用<script>元素来在SVG文档中插入脚本,它的功能几乎和HTML中的<script>标记一样。其一般格式为:

    <script type=”text/JavaScript”>

    <![CDATA[

                 <!—这里插入脚本程序段-->

          ]]>

    </script>

    <script>有两个属性,type=”content-type”,这里指明所用的script语言的类型。默认情况下script采用的语言是JavaScript语言。Xlink:href=”<uri>”指明引用外部脚本文件的url。下面的例子演示了SVG中的鼠标事件。

    <svg width="400" height="200">

    <script><![CDATA[

    function showmsg()

    {

    alert("you had clicked the green rect");

    }

    ]]></script>

    <g id="rect1">

    <rect id="rectangle" onclick="showmsg()" x="50" y="50" width="100" height="50" style="fill:green"/></g>

    </svg>

    在文本中输入上面代码,用IE打开,然后用鼠标点击绿色的矩形,将会提示“你点击了矩形”的信息。

    所以如果要实现对SVG的脚本编程,只需要在相关的元素上增加事件处理函数(onclick="showmsg()"),然后在<script>标记中实现相关函数就可以了。

    另外时间处理函数的实现除可以放在SVG的<script>标记中外,也可以放在SVG嵌入的父HTML文件中,这样的话也可以方便的实现SVG和HTML的数据交换。例如下面的例子。

    Svg文件:1.svg

    <svg width="400" height="200">

    <g id="rect1">

    <rect id="rectangle" onclick="showmsg()" x="50" y="50" width="100" height="50" style="fill:green"/></g>

    </svg>

    HTML文件:a.html

    <html><head><title>SVG事件</title>

    <script language=javascript>

    <!—

    function showmsg()

    {

    Alert("you had clicked the green rect ");

    }

    //-->

    </script>

    <body >

    <embed name="id1" pluginspage=”http://www.adobe.com/svg/viewer/install/” align="top" src="1.svg" height="200px" width="200px" type="image/svg+xml">

    </body>

    </html>

    当你打开a.html文件后,你会发现效果跟上面的例子一样。

    SVG支持的事件有很多,比较常用的有onclick,onmousedown,onmouseup,onmouseout,onmousemove,onload等等。更多的事件请查看:

    http://www.w3.org/TR/SVG/interact.html

    (另一部分为http://www.csdn.net/Develop/read_article.asp?id=26677)


       收藏   分享  
    顶(0)
      




    ----------------------------------------------
    事业是国家的,荣誉是单位的,成绩是领导的,工资是老婆的,财产是孩子的,错误是自己的。

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/1/12 16:20:00
     
     _phoenix 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(猛啃高等数学)
      文章:25
      积分:153
      门派:XML.ORG.CN
      注册:2005/4/8

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给_phoenix发送一个短消息 把_phoenix加入好友 查看_phoenix的个人资料 搜索_phoenix在『 SVG/GML/VRML/X3D/XAML 』的所有贴子 引用回复这个贴子 回复这个贴子 查看_phoenix的博客2
    发贴心情 
    谢了.
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/4/12 23:57:00
     
     henrybenben 帅哥哟,离线,有人找我吗?
      
      
      等级:大二(研究C++)
      文章:50
      积分:257
      门派:XML.ORG.CN
      注册:2005/4/13

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给henrybenben发送一个短消息 把henrybenben加入好友 查看henrybenben的个人资料 搜索henrybenben在『 SVG/GML/VRML/X3D/XAML 』的所有贴子 引用回复这个贴子 回复这个贴子 查看henrybenben的博客3
    发贴心情 
    thanks:)
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/4/13 21:22:00
     
     ljb622 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:2
      积分:70
      门派:XML.ORG.CN
      注册:2005/4/19

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给ljb622发送一个短消息 把ljb622加入好友 查看ljb622的个人资料 搜索ljb622在『 SVG/GML/VRML/X3D/XAML 』的所有贴子 引用回复这个贴子 回复这个贴子 查看ljb622的博客4
    发贴心情 
    不知道你是否知道如果用C++语言作为脚本,实现某个操作例如点击鼠标右键显示一些内容,是否能实现。谢谢。
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/4/27 17:46:00
     
     zzzzzz2 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(猛啃高等数学)
      文章:40
      积分:150
      门派:XML.ORG.CN
      注册:2005/5/10

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给zzzzzz2发送一个短消息 把zzzzzz2加入好友 查看zzzzzz2的个人资料 搜索zzzzzz2在『 SVG/GML/VRML/X3D/XAML 』的所有贴子 引用回复这个贴子 回复这个贴子 查看zzzzzz2的博客5
    发贴心情 
    有C++ 的脚本语言吗?我怎么没有听说过啊?

    现在在Web中使用Javascript已经是大势所趋了,VBScript在Web上比JavaScript少。

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/5/11 12:48:00
     
     suming 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(高数修炼中)
      文章:22
      积分:143
      门派:XML.ORG.CN
      注册:2005/5/11

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给suming发送一个短消息 把suming加入好友 查看suming的个人资料 搜索suming在『 SVG/GML/VRML/X3D/XAML 』的所有贴子 引用回复这个贴子 回复这个贴子 查看suming的博客6
    发贴心情 
    试了,弹出的框框说对象错误。没说那句:you had clicked the green rect
    这到底是咋回事啊?
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/5/13 16:26:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 SVG/GML/VRML/X3D/XAML 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2025/7/23 4:47:56

    本主题贴数6,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    125.000ms