-
-
Save ScottPhillips/4138804 to your computer and use it in GitHub Desktop.
Animate scrolling to an element or offset
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/*! | |
* requires jQuery | |
* usage: | |
* Scroller.to({ offset: 100 }); | |
* Scroller.to({ target: $('#main') }); | |
* | |
* advanced usage (with additional easing function not provided here) | |
* Scroller.to({ target: $('#main'), delay: 500, multiplier: 1.5, easing: 'easeOutQuad' }); | |
*/ | |
var Scroller = (function() | |
{ | |
var scroll = { | |
options: { | |
el: $('html:not(:animated),body:not(:animated)'), | |
multiplier: 1, | |
offset: undefined, | |
easing: 'swing', | |
delay: 0 | |
}, | |
_scrolling: false | |
}; | |
scroll.to = function(options) | |
{ | |
var height = { | |
top: $(window).scrollTop(), | |
doc: $(document).height(), | |
win: $(window).height() | |
}; | |
if (height.doc <= height.win) { | |
return; | |
} | |
var config = $.extend({}, scroll.options); | |
config = $.extend(config, options || {}); | |
config.offset = isNaN(config.offset) ? config.target.offset().top : config.offset; | |
var offset = config.offset, | |
distance = Math.abs(height.top - offset); | |
if (height.top < offset) { | |
var max = height.doc - height.win; | |
if (offset > max) { | |
distance -= offset - max; | |
} | |
} | |
if (distance) { | |
if (scroll._scrolling) { | |
scroll.stop(); | |
} | |
scroll._scrolling = true; | |
scroll.timeout = window.setTimeout(function() { | |
config.el.animate({ scrollTop: Math.floor(offset) }, distance * config.multiplier, config.easing, function() | |
{ | |
scroll._scrolling = false; | |
}); | |
}, config.delay); | |
} | |
}; | |
scroll.stop = function() | |
{ | |
if (scroll.timeout) { | |
window.clearTimeout(scroll.timeout); | |
scroll.timeout = null; | |
} | |
scroll.options.el.stop(); | |
scroll._scrolling = false; | |
}; | |
scroll.isScrolling = function() | |
{ | |
return scroll._scrolling; | |
}; | |
return scroll; | |
})(); |
The Ziunx Android Emulator is a cutting-edge, free application designed to replicate the Nintendo Switch experience on Android and iOS devices. This emulator allows gamers to enjoy their favorite Switch titles without needing the actual console, bringing the Nintendo Switch experience directly to your mobile device.
You can download latest games and apps free from https://apkgstore.net// Give it a try right now.
Nice implementation of smooth scrolling! This kind of functionality really enhances user experience. If you’re into advanced mobile solutions or need a phone service that’s both efficient and cutting-edge, you might want to check out Tesla. It offers some great features for tech enthusiasts.
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
These are such great ideas and ways to help me improve bloxd io and solve my problems. This online game is my new product and it will bring you to 9+ environments to survive and fight in the pixel world. Are you ready to join it? Let's go!