移动旋转的SVG元素

move rotated SVG element

本文关键字:元素 SVG 旋转 移动      更新时间:2023-09-26

那么,我有一个SVG矩形,我可以移动到鼠标位置,使用mouseonmove。

它工作得很好,但是当我来旋转它时,运动很好,但是它有一个基于旋转角度的奇怪偏移。我猜cos/sin代码有问题,但我不知道哪里出了问题。

var container = document.getElementById("container"); 
var rect = document.getElementById("rect");
var grados = document.getElementById("grados");
var group = document.getElementById("group");
grados.addEventListener("change",rotate);
container.addEventListener("mousemove", move);
var angle = 0;
var radian = angle * Math.PI / 180;
var cos = Math.cos(radian);
var sin = Math.sin(radian);
function move(e){
    var x = ((e.offsetX * cos) + (e.offsetY * sin));
    var y = ((-e.offsetX * sin) + (e.offsetY * cos));
    rect.setAttribute('x',x);
    rect.setAttribute('y',y);
}
function rotate(e){
    console.log(e);
    group.style.transform='rotate('+e.target.value+'deg)';
    angle = e.target.value;
    radian = angle * Math.PI / 180;
    cos = Math.cos(radian);
    sin = Math.sin(radian);
     
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
ROTATE<input id="grados" type="number" value="1">
<svg id="container"style="width: 400px;height:400px;border:1px solid black;">
<svg>
<g id="group"style="transform:rotate(0deg);transform-origin:50% 50%;">
<rect id="rect"  x="20" y="5" width="50px" height="50px" style="fill:red;stroke-width:3;stroke:blue"></rect>
    </g>
 </svg>
</svg>
链接到jsdfiddle: https://jsfiddle.net/es179Lzn/1/

谢谢

好吧,经过几天的工作,我明白了。看起来我这样做是对的,但它会导致transform-origin: '50% 50%'性质的奇怪行为。我只是把它取下来,一切都正常了。(有一些bug,但是问题已经解决了)

所以我把答案留给以后。