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

    >> 本版讨论SVG, GML, X3D, VRML, VML, XAML, AVALON, Batik等基于XML的图形技术,以及有关GIS的应用。
    [返回] W3CHINA.ORG讨论区 - 语义网·描述逻辑·本体·RDF·OWLXML.ORG.CN讨论区 - 高级XML应用『 SVG/GML/VRML/X3D/XAML 』 → SVG: 如何用javascript處理移動多個不定數目的圖形? 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 7370 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: SVG: 如何用javascript處理移動多個不定數目的圖形? 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     huajen_chen 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:7
      积分:68
      门派:XML.ORG.CN
      注册:2010/1/26

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给huajen_chen发送一个短消息 把huajen_chen加入好友 查看huajen_chen的个人资料 搜索huajen_chen在『 SVG/GML/VRML/X3D/XAML 』的所有贴子 引用回复这个贴子 回复这个贴子 查看huajen_chen的博客楼主
    发贴心情 SVG: 如何用javascript處理移動多個不定數目的圖形?

    您好,
       移動固定數量的圖形時我是以addEventListener來完成圖形拖曳的動作(有幾個圖形就寫幾遍).  但是如果現在一開始我不會知道有多少個圖形是可以拖曳的(可能1-500), 圖形個數會在與使用者互動的過程一直增加(add功能)或減少(remove功能), 請問我該如何處理這樣的需求?
       例如有一個畫布一開始是空的, 使用者可以按add鍵加一個圖形(例如圓形)到畫布上, 一旦加到畫布上就必須可以在畫布上被拖曳; 當然畫布上的圖形也要可以隨著被滑鼠點選後被移除.

      請您幫幫忙, 謝謝!!


       收藏   分享  
    顶(0)
      




    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2010/1/26 18:02:00
     
     gj1989816 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:9
      积分:79
      门派:XML.ORG.CN
      注册:2009/12/18

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给gj1989816发送一个短消息 把gj1989816加入好友 查看gj1989816的个人资料 搜索gj1989816在『 SVG/GML/VRML/X3D/XAML 』的所有贴子 引用回复这个贴子 回复这个贴子 查看gj1989816的博客2
    发贴心情 
    使用 g 元素 来包住所以的元素,在 transform   g元素
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2010/1/27 9:38:00
     
     huajen_chen 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:7
      积分:68
      门派:XML.ORG.CN
      注册:2010/1/26

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给huajen_chen发送一个短消息 把huajen_chen加入好友 查看huajen_chen的个人资料 搜索huajen_chen在『 SVG/GML/VRML/X3D/XAML 』的所有贴子 引用回复这个贴子 回复这个贴子 查看huajen_chen的博客3
    发贴心情 
    樓上的朋友,
       能不能麻煩你說清楚點...?  不是要單純的移動, 是要以滑鼠拖曳. 以下是我的做法.
    <g id="g01" transform="scale(1.0)">
    <rect id="rect001" x="100" y="100" width="0.1cm" height="1cm" fill="white" stroke="blue" stroke-width="1"/>
    <rect id="rect002" x="100" y="200" width="0.1mm" height="1cm" fill="white" stroke="blue" stroke-width="1"/>
    </g>
    ...
    rectangle001 = document.getElementById('rect001');
    rectangle002 = document.getElementById('rect002');
    rectangle001.addEventListener("mousedown", mousedown_listener001, false);
    rectangle002.addEventListener("mousedown", mousedown_listener002, false);
    function mousedown_listener001(evt)
    {
        dx001 = rectangle001.x.baseVal.value - evt.clientX;
        dy001 = rectangle001.y.baseVal.value - evt.clientY;
        document.addEventListener("mousemove", mousemove_listener001, true);
        document.addEventListener("mouseup", mouseup_listener001, true);
    }
    function mousedown_listener002(evt)
    {
        dx002 = rectangle002.x.baseVal.value - evt.clientX;
        dy002 = rectangle002.y.baseVal.value - evt.clientY;
        document.addEventListener("mousemove", mousemove_listener002, true);
        document.addEventListener("mouseup", mouseup_listener002, true);
    }
    function mousemove_listener001(evt)
    {
        var id = rectangle001.ownerSVGElement.suspendRedraw(1000);
        rectangle001.x.baseVal.value = evt.clientX + dx001;
        rectangle001.y.baseVal.value = evt.clientY + dy001;
        rectangle001.ownerSVGElement.unsuspendRedraw(id);
    }
    function mousemove_listener002(evt)
    {
        var id = rectangle002.ownerSVGElement.suspendRedraw(1000);
        rectangle002.x.baseVal.value = evt.clientX + dx002;
        rectangle002.y.baseVal.value = evt.clientY + dy002;
        rectangle002.ownerSVGElement.unsuspendRedraw(id);
    }
    function mouseup_listener001(evt)
    {
        document.removeEventListener("mousemove", mousemove_listener001, true);
        document.removeEventListener("mouseup", mouseup_listener001, true);
    }
    function mouseup_listener002(evt)
    {
        document.removeEventListener("mousemove", mousemove_listener002, true);
        document.removeEventListener("mouseup", mouseup_listener002, true);
    }
       但是如果一开始我不会知道有多少个图形是可以拖曳的(可能1-500个), 图形个数会在与使用者互动的过程一直增加(add功能)或减少(remove功能), 请问我该如何处理这样的需求?
       例如有一个SVG画布一开始是空的, 使用者可以按add键加一个图形(例如方形)到画布上, 一旦加到画布上就必须可以立即在画布上被拖曳; 当然画布上的图形也要可以随著被滑鼠点选后(例如double click)被移除. 请问该如何做?!  
       请帮帮忙, 谢谢!!
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2010/1/27 11:50:00
     
     Joey0720080246 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:4
      积分:93
      门派:XML.ORG.CN
      注册:2007/10/12

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给Joey0720080246发送一个短消息 把Joey0720080246加入好友 查看Joey0720080246的个人资料 搜索Joey0720080246在『 SVG/GML/VRML/X3D/XAML 』的所有贴子 引用回复这个贴子 回复这个贴子 查看Joey0720080246的博客4
    发贴心情 
    js写一个鼠标拖曳对象MouseDragging. 用面向对象来解决
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2010/1/31 11:23:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 SVG/GML/VRML/X3D/XAML 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/11/27 7:30:50

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

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