
timSpeed=50;
contHeight=210;

//If you want it to move faster you can set this lower:
var speed=5;

//Sets variables to keep track of what's happening
var loop, timer;

function checkBrowser() {
	this.ver=navigator.appVersion;
	this.dom=document.getElementById?1:0;
	this.ie5=(this.ver.indexOf("MSIE 5")>-1 && this.dom)?1:0;
	this.ie4=(document.all && !this.dom)?1:0;
	this.ns5=(this.dom && parseInt(this.ver) >= 5) ?1:0;
	this.ns4=(document.layers && !this.dom)?1:0;
	this.ns6=(this.dom && parseInt(this.ver) >= 5) ?1:0;
	this.bw=(this.ie5 || this.ie4 || this.ns4 || this.ns5);
	return this;
}

bw = new checkBrowser();

//Object constructor
function scrollObj(obj,nest){
	nest=(!nest) ? '':'document.'+nest+'.';
	this.el=bw.dom?document.getElementById(obj):bw.ie4?document.all[obj]:bw.ns4?eval(nest+'document.'+obj):0;
	this.css=bw.dom?document.getElementById(obj).style:bw.ie4?document.all[obj].style:bw.ns4?eval(nest+'document.'+obj):0;
	this.scrollHeight=bw.ns4?this.css.document.height:this.el.offsetHeight;
	this.clipHeight=bw.ns4?this.css.clip.height:this.el.offsetHeight;
	this.scrollWidth=bw.ns4?this.css.document.width:this.el.offsetWidth;
	this.clipWidth=bw.ns4?this.css.clip.width:this.el.offsetWidth;
	if (bw.ns6) {
		if (this.scrollHeight<document.height){
			this.scrollHeight=document.height;
		}
		if (this.scrollWidth<document.width){
			this.scrollWidth=document.width;
		}
	}
	this.up=goUp;this.down=goDown;
	this.left=goLeft;this.right=goRight;
	this.moveIt=moveIt; this.x; this.y;
	this.obj = obj + "Object";
	eval(this.obj + "=this");
	return this;
}

function moveIt(x,y){
		  this.x=x;this.y=y;
		  this.css.left=this.x;
		  this.css.top=this.y;
}

//Makes the object go up
function goDown(move){
		  if(this.y>-this.scrollHeight+oCont.clipHeight){
					 this.moveIt(0,this.y-move);
								if(loop) setTimeout(this.obj+".down("+move+")",speed);
		  }
}
//Makes the object go down
function goUp(move){
		  if(this.y<0){
					 this.moveIt(0,this.y-move);
					 if(loop) setTimeout(this.obj+".up("+move+")",speed);
		  }
}

//Makes the object go left
function goLeft(move){
		  if(this.x>-this.scrollWidth+oCont.clipWidth){
					 this.moveIt(this.x-move,0);
								if(loop) setTimeout(this.obj+".left("+move+")",speed);
		  }
}
//Makes the object go rigth
function goRight(move){
		  if(this.x<0){
					 this.moveIt(this.x-move,0);
					 if(loop) setTimeout(this.obj+".right("+move+")",speed);
		  }
}

//Calls the scrolling functions. Also checks whether the page is loaded or not.
function scroll(speed){
		  if(loaded){
					 loop=true;
					 if(speed>0) oScroll.down(speed)
					 else oScroll.up(speed);
		  }
}

function scroll_h(speed){
		  if(loaded){
					 loop=true;
					 if(speed>0) oScroll.left(speed)
					 else oScroll.right(speed);
		  }
}


//Stops the scrolling (called on mouseout)
function noScroll(){
		  loop=false;
		  if(timer) clearTimeout(timer);
}
//Makes the object
var loaded;
function scrollInit(){
		  if (bw == null) bw = new checkBrowser();
		  oCont=new scrollObj('divCont');
		  oScroll=new scrollObj('BlocScroll','divCont');
		  oScroll.moveIt(0,0);
		  oCont.css.visibility='visible';
		  loaded=true;
		  return true;
}
