2011-03-14 17:14:20 -04:00
|
|
|
/*
|
2013-01-28 21:03:27 -05:00
|
|
|
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
|
2011-03-14 17:14:20 -04:00
|
|
|
* http://paperjs.org/
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2015-12-27 12:09:25 -05:00
|
|
|
* Copyright (c) 2011 - 2016, Juerg Lehni & Jonathan Puckey
|
2014-01-03 19:47:16 -05:00
|
|
|
* http://scratchdisk.com/ & http://jonathanpuckey.com/
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2011-07-01 06:17:45 -04:00
|
|
|
* Distributed under the MIT license. See LICENSE file for details.
|
|
|
|
*
|
2011-03-14 17:14:20 -04:00
|
|
|
* All rights reserved.
|
|
|
|
*/
|
|
|
|
|
2011-07-31 10:23:26 -04:00
|
|
|
/**
|
|
|
|
* @name DomElement
|
|
|
|
* @namespace
|
|
|
|
* @private
|
|
|
|
*/
|
2012-11-14 01:58:03 -05:00
|
|
|
var DomElement = new function() {
|
2014-08-16 13:24:54 -04:00
|
|
|
// Handles both getting and setting of vendor prefix values
|
|
|
|
function handlePrefix(el, name, set, value) {
|
|
|
|
var prefixes = ['', 'webkit', 'moz', 'Moz', 'ms', 'o'],
|
|
|
|
suffix = name[0].toUpperCase() + name.substring(1);
|
|
|
|
for (var i = 0; i < 6; i++) {
|
|
|
|
var prefix = prefixes[i],
|
|
|
|
key = prefix ? prefix + suffix : name;
|
|
|
|
if (key in el) {
|
|
|
|
if (set) {
|
|
|
|
el[key] = value;
|
|
|
|
} else {
|
|
|
|
return el[key];
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return /** @lends DomElement */{
|
|
|
|
getStyles: function(el) {
|
|
|
|
// If el is a document (nodeType == 9), use it directly
|
|
|
|
var doc = el && el.nodeType !== 9 ? el.ownerDocument : el,
|
|
|
|
view = doc && doc.defaultView;
|
|
|
|
return view && view.getComputedStyle(el, '');
|
|
|
|
},
|
|
|
|
|
|
|
|
getBounds: function(el, viewport) {
|
|
|
|
var doc = el.ownerDocument,
|
|
|
|
body = doc.body,
|
|
|
|
html = doc.documentElement,
|
|
|
|
rect;
|
|
|
|
try {
|
|
|
|
// On IE, for nodes that are not inside the DOM, this throws an
|
|
|
|
// exception. Emulate the behavior of all other browsers, which
|
|
|
|
// return a rectangle of 0 dimensions.
|
|
|
|
rect = el.getBoundingClientRect();
|
|
|
|
} catch (e) {
|
|
|
|
rect = { left: 0, top: 0, width: 0, height: 0 };
|
|
|
|
}
|
|
|
|
var x = rect.left - (html.clientLeft || body.clientLeft || 0),
|
2014-08-25 06:49:14 -04:00
|
|
|
y = rect.top - (html.clientTop || body.clientTop || 0);
|
2014-08-16 13:24:54 -04:00
|
|
|
if (!viewport) {
|
|
|
|
var view = doc.defaultView;
|
|
|
|
x += view.pageXOffset || html.scrollLeft || body.scrollLeft;
|
|
|
|
y += view.pageYOffset || html.scrollTop || body.scrollTop;
|
|
|
|
}
|
|
|
|
return new Rectangle(x, y, rect.width, rect.height);
|
|
|
|
},
|
|
|
|
|
|
|
|
getViewportBounds: function(el) {
|
|
|
|
var doc = el.ownerDocument,
|
|
|
|
view = doc.defaultView,
|
|
|
|
html = doc.documentElement;
|
|
|
|
return new Rectangle(0, 0,
|
|
|
|
view.innerWidth || html.clientWidth,
|
|
|
|
view.innerHeight || html.clientHeight
|
|
|
|
);
|
|
|
|
},
|
|
|
|
|
|
|
|
getOffset: function(el, viewport) {
|
2014-10-02 11:00:40 -04:00
|
|
|
return DomElement.getBounds(el, viewport).getPoint();
|
2014-08-16 13:24:54 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
getSize: function(el) {
|
2014-10-02 11:00:40 -04:00
|
|
|
return DomElement.getBounds(el, true).getSize();
|
2014-08-16 13:24:54 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
2016-01-14 05:43:17 -05:00
|
|
|
* Checks if element is invisibile (display: none, ...).
|
2014-08-16 13:24:54 -04:00
|
|
|
*/
|
|
|
|
isInvisible: function(el) {
|
2014-10-02 11:00:40 -04:00
|
|
|
return DomElement.getSize(el).equals(new Size(0, 0));
|
2014-08-16 13:24:54 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
2016-01-14 05:43:17 -05:00
|
|
|
* Checks if element is visibile in current viewport.
|
2014-08-16 13:24:54 -04:00
|
|
|
*/
|
|
|
|
isInView: function(el) {
|
|
|
|
// See if the viewport bounds intersect with the windows rectangle
|
|
|
|
// which always starts at 0, 0
|
2014-10-02 11:00:40 -04:00
|
|
|
return !DomElement.isInvisible(el)
|
|
|
|
&& DomElement.getViewportBounds(el).intersects(
|
|
|
|
DomElement.getBounds(el, true));
|
2014-08-16 13:24:54 -04:00
|
|
|
},
|
|
|
|
|
2016-01-14 05:43:17 -05:00
|
|
|
/**
|
|
|
|
* Checks if element is inside the DOM.
|
|
|
|
*/
|
|
|
|
isInserted: function(el) {
|
|
|
|
return document.body.contains(el);
|
|
|
|
},
|
|
|
|
|
2014-08-16 13:24:54 -04:00
|
|
|
/**
|
|
|
|
* Gets the given property from the element, trying out all browser
|
|
|
|
* prefix variants.
|
|
|
|
*/
|
|
|
|
getPrefixed: function(el, name) {
|
2016-02-02 11:30:38 -05:00
|
|
|
return el && handlePrefix(el, name);
|
2014-08-16 13:24:54 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
setPrefixed: function(el, name, value) {
|
|
|
|
if (typeof name === 'object') {
|
|
|
|
for (var key in name)
|
|
|
|
handlePrefix(el, key, true, name[key]);
|
|
|
|
} else {
|
|
|
|
handlePrefix(el, name, true, value);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
2011-03-14 17:14:20 -04:00
|
|
|
};
|