0byt3m1n1
Path:
/
data
/
applications
/
aps
/
tikiwiki
/
3.2.0-5
/
standard
/
htdocs
/
lib
/
mootools
/
src
/
Plugins
/
[
Home
]
File: Scroller.js
/* Script: Scroller.js Contains the <Scroller>. License: MIT-style license. */ /* Class: Scroller The Scroller is a class to scroll any element with an overflow (including the window) when the mouse cursor reaches certain buondaries of that element. You must call its start method to start listening to mouse movements. Note: The Scroller requires an XHTML doctype. Arguments: element - required, the element to scroll. options - optional, see options below, and <Fx.Base> options. Options: area - integer, the necessary boundaries to make the element scroll. velocity - integer, velocity ratio, the modifier for the window scrolling speed. Events: onChange - optionally, when the mouse reaches some boundaries, you can choose to alter some other values, instead of the scrolling offsets. Automatically passes as parameters x and y values. */ var Scroller = new Class({ options: { area: 20, velocity: 1, onChange: function(x, y){ this.element.scrollTo(x, y); } }, initialize: function(element, options){ this.setOptions(options); this.element = $(element); this.mousemover = ([window, document].contains(element)) ? $(document.body) : this.element; }, /* Property: start The scroller starts listening to mouse movements. */ start: function(){ this.coord = this.getCoords.bindWithEvent(this); this.mousemover.addListener('mousemove', this.coord); }, /* Property: stop The scroller stops listening to mouse movements. */ stop: function(){ this.mousemover.removeListener('mousemove', this.coord); this.timer = $clear(this.timer); }, getCoords: function(event){ this.page = (this.element == window) ? event.client : event.page; if (!this.timer) this.timer = this.scroll.periodical(50, this); }, scroll: function(){ var el = this.element.getSize(); var pos = this.element.getPosition(); var change = {'x': 0, 'y': 0}; for (var z in this.page){ if (this.page[z] < (this.options.area + pos[z]) && el.scroll[z] != 0) change[z] = (this.page[z] - this.options.area - pos[z]) * this.options.velocity; else if (this.page[z] + this.options.area > (el.size[z] + pos[z]) && el.scroll[z] + el.size[z] != el.scrollSize[z]) change[z] = (this.page[z] - el.size[z] + this.options.area - pos[z]) * this.options.velocity; } if (change.y || change.x) this.fireEvent('onChange', [el.scroll.x + change.x, el.scroll.y + change.y]); } }); Scroller.implement(new Events, new Options);