我正在使用raphael为一个球制作动画,需要在停止动画后找出位置,这是我的代码:
ball.stop();
console.log(ball.attrs.transform);
// t399.6625490203161,180r180
如何将此字符串转换为球的x,y位置?
答案 0 :(得分:5)
您可以使用Element.getBBox
:
var x = ball.getBBox().x;
var y = ball.getBBox().y;
var r = ball.getBBox().height / 2;
console.log(x, y, r);
但要注意:
坐标(element.getBBox().x
,element.getBBox().y
)将指向边界框的左上角。
如果球是一个圆圈,那么这个点甚至不会包含在圆圈中,使用中心的坐标可能更明智。
给定边界框bbox
,那些将是
var x = bbox.x + bbox.width / 2,
y = bbox.y + bbox.height / 2;