Я'м пытаюсь нарисовать линию по диагонали между нижним правом углу один div в правом верхнем углу другого. Если возможно, я хотел бы сделать это без jQuery. Это возможно?
Это выиграл'т работать с IE8 или ниже из-за ограничений в CSS.
function getOffset( el ) {
var rect = el.getBoundingClientRect();
return {
left: rect.left + window.pageXOffset,
top: rect.top + window.pageYOffset,
width: rect.width || el.offsetWidth,
height: rect.height || el.offsetHeight
};
}
function connect(div1, div2, color, thickness) { // draw a line connecting elements
var off1 = getOffset(div1);
var off2 = getOffset(div2);
// bottom right
var x1 = off1.left + off1.width;
var y1 = off1.top + off1.height;
// top right
var x2 = off2.left + off2.width;
var y2 = off2.top;
// distance
var length = Math.sqrt(((x2-x1) * (x2-x1)) + ((y2-y1) * (y2-y1)));
// center
var cx = ((x1 + x2) / 2) - (length / 2);
var cy = ((y1 + y2) / 2) - (thickness / 2);
// angle
var angle = Math.atan2((y1-y2),(x1-x2))*(180/Math.PI);
// make hr
var htmlLine = "<div style='padding:0px; margin:0px; height:" + thickness + "px; background-color:" + color + "; line-height:1px; position:absolute; left:" + cx + "px; top:" + cy + "px; width:" + length + "px; -moz-transform:rotate(" + angle + "deg); -webkit-transform:rotate(" + angle + "deg); -o-transform:rotate(" + angle + "deg); -ms-transform:rotate(" + angle + "deg); transform:rotate(" + angle + "deg);' />";
//
// alert(htmlLine);
document.body.innerHTML += htmlLine;
}
Редактировать (для других с такой же проблемой):
Если вам нужно, например, создать линию из двух углов, которые не являются верхней и правой нижней ДИВС, перейти в этот раздел кодекса:
// bottom right
var x1 = off1.left + off1.width;
var y1 = off1.top + off1.height;
// top right
var x2 = off2.left + off2.width;
var y2 = off2.top;
где вы видите + выкл. 1.ширина
и + выкл. 1.Высота
, что означает, что код вычисляет положение снизу или справа от div. Удалить + выкл. 1.ширина " или " + выкл. 1.высота
, чтобы получить в левой или верхней части див.
Редактировать обновлено более стандартная функция getOffset. Если вы хотите получить действительно анальный вы'д, наверное, тоже надо добавить документ.функцию documentelement.клиент[влево/вверх] и ходить offsetParent дерево, но я думаю, что getBoundingClientRect() и window.страницы[х/г]смещение являются достаточными для примера такой.
Есть способ сделать это без jq не.