var $ = function (id) { 
return "string" == typeof id ? document.getElementById(id) : id; 
}; 
var Class = { 
create: function() { 
return function() { 
this.initialize.apply(this, arguments); 
} 
} 
} 
Object.extend = function(destination, source) { 
for (var property in source) { 
destination[property] = source[property]; 
} 
return destination; 
} 
function addEventHandler(oTarget, sEventType, fnHandler) { 
if (oTarget.addEventListener) { 
oTarget.addEventListener(sEventType, fnHandler, false); 
} else if (oTarget.attachEvent) { 
oTarget.attachEvent("on" + sEventType, fnHandler); 
} else { 
oTarget["on" + sEventType] = fnHandler; 
} 
}; 
var Scroller = Class.create(); 
Scroller.prototype = { 
initialize: function(idScroller, idScrollMid, options) { 
var oThis = this, oScroller = $(idScroller), oScrollMid = $(idScrollMid); 
this.SetOptions(options); 
this.Side = this.options.Side || ["up"];//方向 
this.scroller = oScroller; //?象 
this.speed = this.options.Speed; //速度 
this.timer = null; //?? 
this.pauseHeight = 0; //定高 
this.pauseWidth = 0; //定? 
this.pause = 0; //定高(?) 
this.side = 0; //?? 
//用于上下?? 
this.heightScroller = parseInt(oScroller.style.height) || oScroller.offsetHeight; 
this.heightList = oScrollMid.offsetHeight; 
//用于左右?? 
this.widthScroller = parseInt(oScroller.style.width) || oScroller.offsetWidth; 
this.widthList = oScrollMid.offsetWidth; 
//js取不到css?置的height和width 
oScroller.style.overflow = "hidden"; 
oScrollMid.appendChild(oScrollMid.cloneNode(true)); 
oScrollMid.appendChild(oScrollMid.cloneNode(true)); 
addEventHandler(oScroller, "mouseover", function() { oThis.Stop(); }); 
addEventHandler(oScroller, "mouseout", function() { oThis.Start(); }); 
this.Start(); 
}, 
//?置默??性 
SetOptions: function(options) { 
this.options = {//默?值 
Step: 1,//每次?化的px量 
Speed: 20,//速度(越大越慢) 
Side: ["up"],//??方向:"up"是上，"down"是下，"left"是左，"right"是右 
PauseHeight: 0,//隔多高停一次 
PauseWidth: 0,//隔多?停一次 
//?上下和左右一起使用?必??置PauseHeight和PauseWidth??置?向位置 
PauseStep: 3000//停???(PauseHeight或PauseWidth大于0???才有效) 
}; 
Object.extend(this.options, options || {}); 
}, 
//?向 
Turn: function() { 
//通??置方向??的排列??向 
this.Side.push(this.Side.shift().toLowerCase()); 
}, 
//上下?? 
ScrollUpDown: function() { 
this.pause = this.pauseHeight; 
this.scroller.scrollTop = this.GetScroll(this.scroller.scrollTop, this.heightScroller, this.heightList, 
this.options.PauseHeight); 
this.pauseHeight = this.pause; 
var oThis = this; 
this.timer = window.setTimeout(function(){ oThis.Start(); }, this.speed); 
}, 
//左右?? 
ScrollLeftRight: function() { 
this.pause = this.pauseWidth; 
//注意:scrollLeft超?1400?自??回1400 注意?度 
this.scroller.scrollLeft = this.GetScroll(this.scroller.scrollLeft, this.widthScroller, this.widthList, 
this.options.PauseWidth); 
this.pauseWidth = this.pause; 
var oThis = this; 
this.timer = window.setTimeout(function(){ oThis.Start(); }, this.speed); 
}, 
//?取?置???据 
GetScroll: function(iScroll, iScroller, iList, iPause) { 
var iStep = this.options.Step * this.side; 
if(this.side > 0){ 
if(iScroll >= (iList * 2 - iScroller)){ iScroll -= iList; } 
} else { 
if(iScroll <= 0){ iScroll += iList; } 
} 
this.speed = this.options.Speed; 
if(iPause > 0){ 
if(Math.abs(this.pause) >= iPause){ 
this.speed = this.options.PauseStep; this.pause = iStep = 0; this.Turn(); 
} else { 
this.pause += iStep; 
} 
} 
return (iScroll + iStep); 
}, 
//?始 
Start: function() { 
//document.getElementById("test").innerHTML+=sTurn+","; 
//方向?置 
switch (this.Side[0].toLowerCase()) { 
case "right" : 
if(this.widthList < this.widthScroller) return; 
this.side = -1; 
this.ScrollLeftRight(); 
break; 
case "left" : 
if(this.widthList < this.widthScroller) return; 
this.side = 1; 
this.ScrollLeftRight(); 
break; 
case "down" : 
if(this.heightList < this.heightScroller) return; 
this.side = -1; 
this.ScrollUpDown(); 
break; 
case "up" : 
default : 
if(this.heightList < this.heightScroller) return; 
this.side = 1; 
this.ScrollUpDown(); 
} 
}, 
//停止 
Stop: function() { 
clearTimeout(this.timer); 
} 
}; 

