//---------------------------------------------------------------------------------------//
//																				         //
// 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] = ["","image_head-hotelansicht1.jpg","image_head-restaurant1.jpg","image_head-restaurant2.jpg","image_head-indoorpool1.jpg","image_head-outdoorpool1.jpg","image_head-outdoorpool2.jpg"];
images[1] = ["","ski_skifahrer2.jpg","ski_boarder.jpg","ski_skigebiet.jpg","ski_skigebiet2.jpg","ski_tiefschnee.jpg","ski_skikurs.jpg","ski_skigruppe.jpg"];
images[2] = ["","winter_pool.jpg","winter_pool2.jpg","hot_ankunft_winter.jpg","hot_bar.jpg","well_pool.jpg","hotel_lounge.jpg","zimmer_sup1.jpg","kul_bismarckstube.jpg","hot_wlan.jpg"];
images[3] = ["","winter_familie.jpg","winter_schneeschuh.jpg","winter_pferde.jpg","winter_rodeln.jpg","winter_landschaft.jpg"];
images[4] = ["","kul_vinothek.jpg","kul_vinothek2.jpg","kul_fuerstenstube.jpg","kul_paarfuerst.jpg","kul_essen.jpg","kul_gasteinerstube.jpg"];
images[5] = ["","kur_wassergym.jpg","kur_akkupunkt.jpg","kur_paar.jpg","kur_stromtherapie.jpg","winter_pool2.jpg","kur_stoll2.jpg","well_therme_aussen.jpg","well_soleheilstollen.jpg","well_famtherme.jpg"];
images[6] = ["","zimmer_1.jpg","zimmer_2.jpg","zimmer_bad.jpg","zimmer_paar.jpg","zimmer_3.jpg","zimmer_tv.jpg"];
images[7] = ["","well_sauna.jpg","well_rondell.jpg","well_indoorpool.jpg","well_outdoorpool2.jpg","well_therme_aussen.jpg","well_soleheilstollen.jpg"];
images[8] = ["","herbst_bergschnee.jpg","herbst_brauchtum.jpg","herbst_frauenbach.jpg","herbst_landschaft.jpg","sport_golf.jpg","herbst_walk.jpg","sommer_wandern.jpg"];
images[9] = ["","well_pool.jpg","hotel_lounge.jpg","hot_ankunft_sommer.jpg","hot_bar.jpg","zimmer_sup1.jpg","zimmer_paar.jpg","kul_bismarckstube.jpg","hot_wlan.jpg"];
images[10] = ["","sommer_see.jpg","sport_golf.jpg","sommer_wandern.jpg","hotel_pool.jpg","well_outdoorpool2.jpg","sommer_kurpark.jpg","sommer_huettenmusi.jpg","sommer_wandernsee.jpg","sommer_walking_asphalt.jpg"];
images[11] = ["","fz_hohenwerfen.jpg","fz_glockner.jpg","fz_casino.jpg","fz_eisriesenwelt.jpg"];
images[12] = ["","ort.jpg","ort_winte.jpg"];
images[13] = ["","well_sauna.jpg","well_rondell.jpg","well_indoorpool.jpg","well_outdoorpool2.jpg","winter_pool.jpg","winter_pool2.jpg","well_soleheilstollen.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); 
}