mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-07 13:22:07 -05:00
Add support for calculation of cumulative positioned offsets and use it to correctly determine visibility and event positions within canvases nested in relative divs.
This commit is contained in:
parent
082ecf1a64
commit
1b197741fa
1 changed files with 10 additions and 7 deletions
|
@ -15,12 +15,15 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
var DomElement = new function() {
|
var DomElement = new function() {
|
||||||
function cumulate(el, name, parent) {
|
function cumulate(el, name, parent, positioned) {
|
||||||
var left = name + 'Left',
|
var left = name + 'Left',
|
||||||
top = name + 'Top',
|
top = name + 'Top',
|
||||||
x = 0,
|
x = 0,
|
||||||
y = 0;
|
y = 0;
|
||||||
while (el) {
|
// If we're asked to calculate positioned offset, stop at any
|
||||||
|
// parent element that has relative or absolute position.
|
||||||
|
while (el && (!positioned
|
||||||
|
|| !/^(relative|absolute)$/.test(el.style.position))) {
|
||||||
x += el[left] || 0;
|
x += el[left] || 0;
|
||||||
y += el[top] || 0;
|
y += el[top] || 0;
|
||||||
el = el[parent];
|
el = el[parent];
|
||||||
|
@ -29,8 +32,8 @@ var DomElement = new function() {
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
getOffset: function(el, scroll) {
|
getOffset: function(el, positioned, scroll) {
|
||||||
var point = cumulate(el, 'offset', 'offsetParent');
|
var point = cumulate(el, 'offset', 'offsetParent', positioned);
|
||||||
return scroll
|
return scroll
|
||||||
? point.subtract(cumulate(el, 'scroll', 'parentNode'))
|
? point.subtract(cumulate(el, 'scroll', 'parentNode'))
|
||||||
: point;
|
: point;
|
||||||
|
@ -40,8 +43,8 @@ var DomElement = new function() {
|
||||||
return Size.create(el.offsetWidth, el.offsetHeight);
|
return Size.create(el.offsetWidth, el.offsetHeight);
|
||||||
},
|
},
|
||||||
|
|
||||||
getBounds: function(el, scroll) {
|
getBounds: function(el, positioned, scroll) {
|
||||||
return new Rectangle(DomElement.getOffset(el, scroll),
|
return new Rectangle(DomElement.getOffset(el, positioned, scroll),
|
||||||
DomElement.getSize(el));
|
DomElement.getSize(el));
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -59,7 +62,7 @@ var DomElement = new function() {
|
||||||
// See if the scrolled bounds intersect with the windows rectangle
|
// See if the scrolled bounds intersect with the windows rectangle
|
||||||
// which always starts at 0, 0
|
// which always starts at 0, 0
|
||||||
return new Rectangle([0, 0], DomElement.getWindowSize())
|
return new Rectangle([0, 0], DomElement.getWindowSize())
|
||||||
.intersects(DomElement.getBounds(el, true));
|
.intersects(DomElement.getBounds(el, false, true));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue