我试图在HTML文档中实现一项功能,允许用户在嵌入式SVG框中拖放...' ...
我找到了this,但很快就意识到该脚本只适用于普通的SVG文件......
请记住,我是一名过去半年一直专注于汇编语言的程序员。从那里跳到这个抽象的环境是一个巨大的进步。
现在我试图找出缩放部分:
所以我制作了这个HTML文件:
<html>
<head>
<title>Forum Risk! v0.0.1</title>
<script type="text/javascript" src="svglib.js" ></script>
</head>
<body>
<!-- SVG embedded directly for example purpose... I'm planning to use <embed> -->
<svg xmlns="http://www.w3.org/2000/svg" version="1.1" onmousewheel="mouseWheelHandler(e);">
<g id="viewport" transform="matrix(1,0,0,1,200,200)" >
<circle cx="100" cy="50" r="40" stroke="black" stroke-width="2" fill="red"/>
</g>
</svg>
</body>
svglib.js
的内容是:
var scrollSensitivity = 0.2
function mouseWheelHandler(e) {
var evt = window.event || e;
var scroll = evt.detail ? evt.detail * scrollSensitivity : (evt.wheelDelta / 120) * scrollSensitivity;
var transform = document.getElementById("viewport").getAttribute("transform").replace(/ /g,"");
var vector = transform.subString(transform.indexOf("("),transform.indexOf(")")).split(",")
vector[0] = (parseInt(vector[0]) + scroll) + '';
vector[3] = vector[0];
document.getElementById("viewport").setAttribute("transform",
"matrix(".concat(vector.join(), ")"));
return true;
}
我使用http://www.javascriptkit.com/javatutors/onmousewheel.shtml作为参考。
但问题是,只要我用Chrome打开HTML文件,SVG就会出现,但是当我用鼠标滚轮滚动时,根本没有任何事情发生......
我完全理解这一切吗?
答案 0 :(得分:3)
解决了!显然onmousewheel属性没有正确处理事件...至少我必须通过javascript直接添加一个事件监听器到SVG画布才能使它工作!
答案 1 :(得分:-3)
通常,使用裸javascript实现这些东西并不是一个好主意。有很多很棒的库允许你在几行中完成这些工作,并且错误的可能性要小得多。
我想到的一个突出例子是d3。 this mashup中的功能似乎非常符合您的要求。
如果你想为你的应用程序实现类似的东西,你基本上只需要在缩放事件上重新计算变换矩阵。 d3可以为您提供鼠标事件数据,还可以简化更改属性的过程。查看来源并试一试!