如何在raphael中找到元素的位置?

时间:2012-08-06 03:38:37

标签: javascript raphael

我正在使用raphael为一个球制作动画,需要在停止动画后找出位置,这是我的代码:

ball.stop();
console.log(ball.attrs.transform);
// t399.6625490203161,180r180

如何将此字符串转换为球的x,y位置?

1 个答案:

答案 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().xelement.getBBox().y)将指向边界框的左上角。
如果球是一个圆圈,那么这个点甚至不会包含在圆圈中,使用中心的坐标可能更明智。

给定边界框bbox,那些将是

var x = bbox.x + bbox.width / 2,
    y = bbox.y + bbox.height / 2;