//---------------------------------------------------------------------------------------//
// 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="";

// 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... 

// HeadSlide "Hotel"
images[0] = ["","headimage_start_winter1.jpg","headimage_start_winter2.jpg","headimage_start_winter3.jpg","headimage_start_winter4.jpg","headimage_start_winter5.jpg","headimage_start_winter6.jpg"];
images[1] = ["","headimage_start_sommer1.jpg","headimage_start_sommer2.jpg","headimage_start_sommer3.jpg","headimage_start_sommer4.jpg"];
images[2] = ["","headimage_sommer1.jpg","headimage_sommer2.jpg","headimage_sommer3.jpg","headimage_sommer4.jpg","headimage_sommer5.jpg"];
images[3] = ["","headimage_winter1.jpg","headimage_winter2.jpg","headimage_winter3.jpg","headimage_winter4.jpg","headimage_winter5.jpg"];
images[4] = ["","headimage_ski1.jpg","headimage_ski2.jpg","headimage_ski3.jpg","headimage_ski4.jpg","headimage_ski5.jpg","headimage_ski6.jpg"];
images[5] = ["","headimage_wandern1.jpg","headimage_wandern2.jpg","headimage_wandern3.jpg","headimage_wandern4.jpg","headimage_wandern5.jpg","headimage_wandern6.jpg"];
images[6] = ["","headimage_aktiv1.jpg","headimage_aktiv2.jpg","headimage_aktiv3.jpg","headimage_aktiv4.jpg","headimage_aktiv5.jpg","headimage_aktiv6.jpg","headimage_aktiv7.jpg"];
images[7] = ["","headimage_winterspass1.jpg","headimage_winterspass2.jpg","headimage_winterspass3.jpg","headimage_winterspass4.jpg","headimage_winterspass5.jpg","headimage_winterspass6.jpg"];
images[8] = ["","headimage_ausflug1.jpg","headimage_ausflug2.jpg","headimage_ausflug3.jpg","headimage_ausflug4.jpg","headimage_ausflug5.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];
}

prepareSlideSlideSlideSlideSlideSlideSlide(slideNr, fixStartPic, random, pic[slideNr].length);
}

// Prepare 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 prepareSlideSlideSlideSlideSlideSlideSlide(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
// @param slideNr - The slideNr of the slideShow... Every slide shoud start with 1
function runSlideShow(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;
	}
	setTimeout('runSlideShow('+slideNr+')', slideSpeed[slideNr]); 
}
