//---------------------------------------------------------------------------------------//
// 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.jpg","hotel.jpg","1bett.jpg","paar_ufer.jpg","1_hotel_collage.jpg","restaurant_kachelofen.jpg","vinothek.jpg"];
images[1] = ["","buffet.jpg","gedeck_kerze.jpg","rest_vino.jpg","stueberl.jpg","hotel_gedeck.jpg","stueberl_vino_teller.jpg","marillenknoedel.jpg","restaurant.jpg","restaurant_kachelofen.jpg","vinothek.jpg"];
images[2] = ["","weingarten.jpg","melk.jpg","frau_weingarten.jpg","1wachau.jpg","1_rad_collage.jpg","wachau_panorama.jpg","marillenbaum.jpg","schiff_frau.jpg","picknick.jpg","traube_pano.jpg","haengematte.jpg","wachau_pano.jpg","radler_rast_donau.jpg","sonnenuntergang.jpg"];
images[3] = ["","aggstein.jpg","artstetten.jpg","rosenburg.jpg","duernstein.jpg","schallaburg.jpg"];
images[4] = ["","wasser_maedchen.jpg","restaurant_kachelofen.jpg","1_rad_collage.jpg","schiff.jpg","vinothek.jpg","picknick2.jpg","radweg.jpg","maedchen_wasser_sitzt.jpg","haengematte.jpg","duernstein.jpg"];
images[5] = ["","melk_turm.jpg","melk_bibliothek.jpg","melk.jpg","melk2.jpg","melk3.jpg","melk_kirche.jpg","melk_innenhof.jpg"];
images[6] = ["","hafer1.jpg","hafer2.jpg","hafer4.jpg","hafer5.jpg","hafer6.jpg"];
images[7] = ["","portal_1.jpg","portal_2.jpg","portal_3.jpg","portal_4.jpg","portal_5.jpg","portal_6.jpg","portal_7.jpg"];
images[8] = ["","jagd_1.jpg","jagd_2.jpg","jagd_3.jpg","jagd_4.jpg","jagd_5.jpg","jagd_6.jpg"];
images[9] = ["","roes_1.jpg","roes_2.jpg","roes_3.jpg","roes_4.jpg"];
images[10] = ["","sp_1.jpg","sp_2.jpg","sp_3.jpg","sp_walk.jpg","sonnenuntergang.jpg","1_rad_collage.jpg"];
images[11] = ["","aussen-winter2.jpg","winter.jpg","weihnachten.jpg"];
images[12] = ["","aussen-winter2.jpg","zimmer.jpg","restaurant_kachelofen.jpg","winter-atmosphaere.jpg","1bett.jpg","vinothek.jpg","winter.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]); 
}