//---------------------------------------------------------------------------------------//
// 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] = ["","zimmer_pavillon.jpg","hotel_3er.jpg","hotel_donau_sonnenuntergang.jpg","hotel_nah.jpg","reception.jpg","landhotel_wachau.jpg","landhotel.jpg","fuernbergstubn.jpg"];
images[1] = ["","buffet.jpg","erdbeere.jpg","fuernbergstubn.jpg","fuernbergstubn2.jpg","gedeck.jpg","pav1.jpg","urbanistubn.jpg","marillen.jpg","pavillion.jpg","pavillion2.jpg","pavillion3er.jpg"];
images[2] = ["","weingaerten.jpg","melk.jpg","frau_weingarten.jpg","donau_panorama.jpg","donau_schiff.jpg","wachau_panorama.jpg","wachau_pano.jpg","aggstein.jpg","frau_hangematte.jpg","radfahrer_rast.jpg","radler_donau.jpg"];
images[3] = ["","aggstein.jpg","artstetten.jpg","rosenburg.jpg","duernstein.jpg","schallaburg.jpg"];
images[4] = ["","maedchen_wasser.jpg","sonnenuntergang.jpg","weinberg.jpg","picknick.jpg","rad_montage.jpg","donauradweg.jpg","pavillion.jpg","frau_donau.jpg","fuernbergstubn2.jpg","duernstein.jpg"];
images[5] = ["","melk_bibliothek.jpg","melk_innenhof.jpg","melk_statue.jpg","melk_stift.jpg","melk_turm.jpg","melk.jpg","melk3.jpg"];
images[6] = ["","heuriger_1.jpg","heuriger_2.jpg","heuriger_3.jpg","heuriger_mannfrau.jpg","heuriger_aussen.jpg","heuriger_aussen2.jpg"];
images[7] = ["","seminar1.jpg","seminar2.jpg","seminar3.jpg","seminarraum_3.jpg"];
images[8] = ["","zimmer_suite1.jpg","zimmer.jpg","zimmer_bad.jpg","zimmer_dusche.jpg","zimmer1.jpg","zimmer_suite2.jpg","zimmer2.jpg","paar_im_bett.jpg"];
images[9] = ["","aussen-winter.jpg","emmersdorf-winter.jpg","weihnachten.jpg","winter.jpg"];
images[10] = ["","roes_1.jpg","roes_2.jpg","roes_3.jpg","roes_4.jpg"];
images[11] = ["","sp_1.jpg","sp_2.jpg","sp_3.jpg","sp_walk.jpg","1_rad_collage.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]); 
}