Skip to content

Instantly share code, notes, and snippets.

@fermion
Forked from gf3/viewable.js
Created September 24, 2009 16:53
Show Gist options
  • Star 3 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save fermion/192865 to your computer and use it in GitHub Desktop.
Save fermion/192865 to your computer and use it in GitHub Desktop.
Percentage of element in viewport
Element.addMethods({
viewable: function(el) {
// INIT
el = $(el);
var scroll = document.viewport.getScrollOffsets();
var viewport = document.viewport.getDimensions();
var offsets = el.cumulativeOffset();
var dimensions = el.getDimensions();
// Sanity check
if (el.getStyle('display') == 'none' || el.getStyle('visibility') == 'hidden') return 0;
// Fix offsets based on scroll
offsets.top = offsets.top - scroll.top;
offsets.left = offsets.left - scroll.left;
// Build visible dimensions
var visible_dimensions = {width: dimensions.width, height: dimensions.height};
// Top
if (offsets.top < 0) {
if (Math.abs(offsets.top) > dimensions.height) return 0; // Sanity check
else {
visible_dimensions.height -= Math.abs(offsets.top);
}
}
// Left
if (offsets.left < 0) {
if (Math.abs(offsets.left) > dimensions.width) return 0; // Sanity check
else {
visible_dimensions.width -= Math.abs(offsets.left);
}
}
// Bottom
var bottomPos = offsets.top + dimensions.height;
if (bottomPos > viewport.height) {
var diff = bottomPos - viewport.height;
if (diff > dimensions.height) return 0; // Sanity check
else {
visible_dimensions.height -= diff;
}
}
// Right
var rightPos = offsets.left + dimensions.width;
if (rightPos > viewport.width) {
var diff = rightPos - viewport.width;
if (diff > dimensions.width) return 0; // Sanity check
else {
visible_dimensions.width -= diff;
}
}
// Return
return (visible_dimensions.width * visible_dimensions.height) / (dimensions.width * dimensions.height);
}
});
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment