以文本方式查看主题 - 中文XML论坛 - 专业的XML技术讨论区 (http://bbs.xml.org.cn/index.asp) -- 『 SVG/GML/VRML/X3D/XAML 』 (http://bbs.xml.org.cn/list.asp?boardid=21) ---- 【求助2】关于viewBox拖拽后的偏移~有经验的大大指导下~! (http://bbs.xml.org.cn/dispbbs.asp?boardid=21&rootid=&id=63720) |
-- 作者:kd2008 -- 发布时间:6/13/2008 5:42:00 PM -- 【求助2】关于viewBox拖拽后的偏移~有经验的大大指导下~! 我先说下我现在要实现的要求,我要通过一个svg中一个元素(比如一个rect)的id,让页面定位放大显示以这个元素为中心的场景,现在通过修改viewBox属性已经能定位元素了,但是现在有两个问题,首先是定位显示的场景的大小确不固定(每次查找后放大缩小不一样),好像靠得比较边的元素会显示得很大,然后再定位中间点的又会缩放到很小,不知道为什么?第二个问题也是最重要的问题,就是我如果使用了svg Viewer提供的拖拽功能,显示区域好像就整体偏移了,我再定位,定位后的viewBox就没办法准确找到元素了,这时viewBox好像加载了我拖拽的偏移量,我不知道怎么把这个处理掉,让它拖拽后还是能准确定位。希望知道的大大能不吝赐教,实在感谢了! |
-- 作者:tamefox -- 发布时间:6/22/2008 7:52:00 AM -- 我觉得第二个问题你最好把系统提供的拖拽功能屏蔽掉 |
-- 作者:tommypeng -- 发布时间:3/4/2009 4:17:00 PM -- LZ的问题可以回答你: 这个问题涉及到embed容器和SVG图形本身两个坐标系统,也就是说SVG图形中某个节点的偏移(放大)量与两个坐标系统息息相关。如果仅仅针对SVG图形本身这个坐标系统来讲,某个节点的偏移和放大量你应该很容易得到吧?那么请再想一下,SVG图形本身与embed容器间的坐标关系又是如何的呢?请看mbed两个属性width和height,它们与SVG图形本身的大小在你获取该节点的算法中构成一个比例关系,也是算法的一个必要条件。 我对SVG研究不是很深,但我在项目中完成过一个功能:在有上百个节点的拓扑图中,通过查找得到一个节点,并将它自动移动到屏幕中间(注意是屏幕,这样又产生了第三个坐标系统),不管你移动过多少次,放大缩小多少次,可以放到屏幕的中间。这是由一个比较复杂的算法实现的,通过采集20多条数据推导出的一个公式。 还有就是在GIS系统中用到SVG的矩阵变换,也是关于坐标系统的,略知一二,用的是中国地图,节点是精确的经纬度坐标,由于项目不需要如此精确,在代码里都被我注了,放着以后用的着的时候用。 SVG的坐标系统是挺有意思的,等你搞懂了,就什么都不怕了,其他都是很easy的问题。 给你些思路,祝你也能实现这个功能!我不是经常上来看的,不知道什么时候再来看一看,呵呵。 |
-- 作者:zz2119_cn -- 发布时间:3/9/2009 7:46:00 PM -- [求助]关于鼠标拖拽svg图像 下面这段代码是我从网上找的,是实现鼠标拖拽svg图像,但是我运行时,会报错。 TrueCoords = SVGRoot.createSVGPoint(); GrabPoint = SVGRoot.createSVGPoint(); 就是上面这两行代码报错,说没有该createSVGPoint()属性。 请大家看看如何解决! function Init(evt) { // these svg points hold x and y values... // this will serve as the canvas over which items are dragged. function Grab(evt) { // you cannot drag the background itself, so ignore any attempts to mouse down on it // move this element to the "top" of the display, so it is (almost) // turn off all pointer events to the dragged element, this does 2 things: // we need to find the current position and translation of the grabbed element, } // if we don't currently have an element in tow, don't do anything // apply a new tranform translation to the dragged element, to display // turn the pointer-events back on, so we can grab this item later // set the global variable to null, so nothing will be dragged until we |
W 3 C h i n a ( since 2003 ) 旗 下 站 点 苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》 |
8,460.938ms |