//---------------------------------------------------------------------------------------//
// name:       js-slideShow                                                                                  //
// version:   2.1                                                                                                //
// made by:  melko                                                                                             //
// email: melko@gmx.at                                                                                      //
//                                                                                                                    //
// info:                                                                                                             //
//         this script enables you to use so many slideShows as you want to                //
//         have on your page without any extra-programming.                                    //
//         Only you must do is to set the paths and image-names!                               //
//                                                                                                                     //
// features:                                                                                                       //
//              - so many slideShows as you want to have                                             //
//              - easy implementation in the sourcecode                                              //
//              - each slideShow has its own slideShowSpeed and crossFadeDuration      //
//              - choose between random or in the order                                              //
//              - set a fix picture at the start of a slideShow                                       //
//												         //
// important:										         //
//	       - The slideShow MUST be initialized with the same number as the index    //
//                of the images it is containing!! example: images[1] = slideShowNr 1        //
//             - You should never have more slideShows than images defined!!                 //
//----------------------------------------------------------------------------------------//

//Specify the global path to the directory
var bigPath="../slides/";


// pic arrays! FIRST POSITION IN THE ARRAY is the SMALLPATH to the pictures!
// if you no path want, then set "" !! Images starts allways with 0 !
var images = new Array();
// The FIRST slideShow with slideNr = 0 and so on... 

// SLIDEs
images[0] = ["","ski_fahrer.jpg","ski_fahrerin.jpg","ski_gipfel.jpg","ski_lifte.jpg","ski_obergurgl.jpg","ski_paarliegestuhl.jpg","ski_zeigen.jpg","ski_paar.jpg"];
images[1] = ["","hotel_halle.jpg","hotel_halle_bar.jpg","hotel_hotel_nah.jpg","sonnenterr.jpg"];
images[2] = ["","zimmer_1.jpg","berge.jpg","zimmer_3.jpg","zimmer_4.jpg","zimmer_5.jpg","zimmer_6.jpg","zimmer_e.jpg"];
images[3] = ["","start_zimmer.jpg","start_stuhl.jpg","start_stuhlnah.jpg","start_ski.jpg","start_mar.jpg","start_ski2.jpg","start_mantel.jpg","start_alpengluehen.jpg","start_hotel2.jpg"];
images[4] = ["","well_areal.jpg","tex-ruhe.jpg","tex-pano2.jpg","well_bad3.jpg","well_dampf.jpg","well_dampf2.jpg","well_dampf4.jpg","frau-wasser.jpg","well_hallenbad.jpg","well_sauna3.jpg","well_sauna1.jpg"];
images[5] = ["","kids_schneeschuh.jpg","kids_skikurs.jpg","kids_kurs.jpg","kids_fun.jpg","kids_schlitten.jpg","kids_bobo.jpg","kids_2.jpg"];
images[6] = ["","kuli_koch.jpg","kuli_anstossen.jpg","kuli_paar2.jpg","kuli_speise.jpg","kuli_speises.jpg","kuli_stueberl.jpg","kuli_teller.jpg"];
images[7] = ["","bar_bar.jpg","bar-pano.jpg","bar_kamin.jpg","bar_leute.jpg","bar_piano.jpg"];
images[8] = ["","neutral_wellness.jpg","neutral_titel.jpg","berge.jpg","neutral_stueberl.jpg","bar_piano.jpg","neutral_halle.jpg","neutral_halle2.jpg","zimmer_5.jpg","kuli_koch.jpg"];
images[9] = ["","start_zimmer.jpg","start_stuhl.jpg","start_stuhlnah.jpg","start_ski.jpg","start_mar.jpg","start_ski2.jpg","start_mantel.jpg","start_alpengluehen.jpg","start_hotel2.jpg"];
images[10] = ["","beauty-frau.jpg","beauty-frau2.jpg","beauty-frau3.jpg","beauty-mann2.jpg","beauty-raum.jpg"];
images[11] = ["","tex-pano.jpg","tex-ruhe.jpg","tex-pool.jpg","frau-whirl.jpg","tex-sauna3.jpg","tex-pano2.jpg","tex-sauna2.jpg"];


// do not edit anything below this line 
//-------------------------------------------------------------------------------------//
var slideSpeed = new Array();
var crossFade = new Array();  
var index = new Array(); 
var pic = new Array(); 
var smallPath = new Array();
var preLoad = new Array(); 

// Initialize the slideShow... 
// @param slideNr - The slideNr of the slideShow... Every slide shoud start with 1
// @param slideShowSpeed - The speed of the slideShow in ms! (1sec. = 1000ms)
// @param crossFadeDuration - The duration of the crossFade (changing one picture through an other) values: 1, 2, 3,...
// @param random - Indicates if the slideShow shoud choose the pictures randomly or in the order. values; true, false
// @param fixStartPic - Indicates if the slideShow, with random = true, should have a fixStart picture at refreshing the page. Its the first image in the array. values: true, false
function init(slideNr, slideShowSpeed, crossFadeDuration, random, fixStartPic) {

	index[slideNr] = 0;
	slideSpeed[slideNr] = slideShowSpeed;
	crossFade[slideNr] = crossFadeDuration;
	smallPath[slideNr] = images[slideNr][0];
	pic[slideNr] = new Array();
	
	for(var i = 0; i < images[slideNr].length-1; i++){
		pic[slideNr][i] = images[slideNr][i+1];
	}
	
	prepareSlide(slideNr, fixStartPic, random, pic[slideNr].length);
}

// prepareSlide the slideShow, set the pictures-order, fixStartPic and load it into PreLoad-Object
// @param slideNr - The slideNr of the slideShow... Every slide shoud start with 1
// @param fixStartPic - Indicates if the slideShow, with random = true, should have a fixStart picture at refreshing the page. Its the first image in the array. values: true, false 
// @param random - Indicates if the slideShow shoud choose the pictures randomly or in the order. values; true, false
// @param picLength - It's the length of the pic-Array of this slideShow
function prepareSlide(slideNr, fixStartPic, random, picLength){
	
	var duplicate = false;
	var reihenfolge = new Array();
	var z=0;
	
	if(fixStartPic){
		reihenfolge[0] = 0;
		z=1;
	}
	
	while (z != picLength){
		y=Math.floor(Math.random()*(picLength));
		for(i=0;i<reihenfolge.length;i++){	
			if (y==reihenfolge[i]){	
				duplicate=true;
			}
		}
		if (duplicate==true){ 
			duplicate=false;
			continue;
		} 
		else if (duplicate==false) { 
			reihenfolge[z] = y; z+=1; 
			
		}
	}
	preLoad[slideNr] = new Array();
	
	if(random) {
		for(i = 0; i < picLength; i++){
			preLoad[slideNr][i] = new Image();
			preLoad[slideNr][i].src = bigPath + smallPath[slideNr] + pic[slideNr][reihenfolge[i]];	
		}
	} 
	else {
		for (i = 0; i < picLength; i++) { 
			preLoad[slideNr][i] = new Image(); 
			preLoad[slideNr][i].src = bigPath + smallPath[slideNr] + pic[slideNr][i]; 
		} 
	}
}

// Run the slideShow with the slideNr that indicates the special slide. It makes a pause of "slideShowSpeed" before starting it...
// @param slideNr - The slideNr of the slideShow... Every slide shoud start with 1
function runSlideShow(slideNr){
	setTimeout('runSlide('+slideNr+')', slideSpeed[slideNr]); 
}

// Run the slideShow with the slideNr that indicates the special slide
// @param slideNr - The slideNr of the slideShow... Every slide shoud start with 1
function runSlide(slideNr) { 
	var element = document.getElementById("slide"+slideNr);
	
	if (document.all) { 
		element.style.filter='blendTrans(duration='+crossFade[slideNr]+')'
		element.filters.blendTrans.Apply(); 
	} 
	element.src = preLoad[slideNr][index[slideNr]].src; 
	
	if (document.all) { 
		element.filters.blendTrans.Play(); 
	} 
	index[slideNr] += 1; 
	
	if (index[slideNr] > (preLoad[slideNr].length - 1)) {
		index[slideNr] = 0;
	}
	runSlideShow(slideNr); 
}