我在获取某个绝对定位元素的中心坐标时遇到了问题,该元素是另一个绝对定位元素的子元素。 您可以在此处查看元素顺序的屏幕截图。
为了更好地理解问题,您可以访问我的GitHub存储库。 index.html文件位于“/ Resources”文件夹中。
所以,我有一些可拖动的窗口(使用interact.js),这些窗口在其他可拖动的窗口中,我想通过线条-divs将它们的中心连接起来(使用带有一些变换的div绘制)。
我使用此方法来渲染线条(也许这里存在一些问题)。 我曾尝试使用jsPlumb进行线条绘制,但失败了 :(
这里是获取x和y点的方法。
// bottom right
var x1 = offset1.left - margin1.left + size1.width/2 - (this.dom.getAttribute('data-x') || 0);
var y1 = offset1.top - margin1.top + size1.height/2 - (this.dom.getAttribute('data-y') || 0);
// top right
var x2 = offset2.left - margin2.left + size2.width/2 - (this.dom.getAttribute('data-x') || 0);
var y2 = offset2.top - margin2.top + size2.height/2 - (this.dom.getAttribute('data-y') || 0);
(this.dom.getAttribute('data-x') || 0)- 这是用于Interact.js的。
function getMargins(elem) {
var top = 0, left = 0;
while (elem.parentNode) {
top = top + parseFloat(window.getComputedStyle(elem).marginTop.replace('px', ''));
left = left + parseFloat(window.getComputedStyle(elem).marginLeft.replace('px', ''));
elem = elem.parentNode;
}
return { top: Math.round(top), left: Math.round(left) }
}
function getOffsetRect(elem) {
// (1)
var box = elem.getBoundingClientRect()
// (2)
var body = document.body
var docElem = document.documentElement
// (3)
var scrollTop = window.pageYOffset || docElem.scrollTop || body.scrollTop
var scrollLeft = window.pageXOffset || docElem.scrollLeft || body.scrollLeft
// (4)
var clientTop = docElem.clientTop || body.clientTop || 0
var clientLeft = docElem.clientLeft || body.clientLeft || 0
// (5)
var top = box.top + scrollTop - clientTop
var left = box.left + scrollLeft - clientLeft
return { top: Math.round(top), left: Math.round(left) }
}
你能帮我获取中心坐标吗?提前感谢。