/*****

Image Cross Fade Redux
Version 1.0
Last revision: 02.15.2006
steve@slayeroffice.com

Please leave this notice intact. 

Rewrite of old code found here: http://slayeroffice.com/code/imageCrossFade/index.html


*****/
window.addEventListener?window.addEventListener("load",so_init,false):window.attachEvent("onload",so_init);
window.addEventListener?window.addEventListener("load",links_so_init,false):window.attachEvent("onload",links_so_init);


var d=document, imgs = new Array(), zInterval = null, current=0, pause=false;
var afbStart;
var try_init = 0;
var sNoImg = '/images/shownoimg.gif';
var sHttpNoImg = location.protocol + '//' + location.host + sNoImg;

function so_init() {
	if(!d.getElementById || !d.createElement){
  	// in de timing kennelijk iets 'mis'
    try_init += 1;
    if (try_init < 10) setTimeout(so_init,500);
    
    return;
  }
	
	if(!d.getElementById("imageContainer")) {
		return
	}
	imgs = d.getElementById("imageContainer").getElementsByTagName("img");
	if (!imgs) {
  	// ? iets mis met de pagina
    try_init += 1;
    setTimeout(so_init,500);
    return;
  }
  
	var randStart= afbStart - 1; //wordt in template 66 gevuld
  
  // for sure..
	if (isNaN(randStart)) randStart = 0;
  if (randStart < 0) randStart = 0; 
	
	for(i=0;i<imgs.length;i++) imgs[i].xOpacity = 0;

  // bepaal de image om mee te starten
  // begin bij de afbStart - 1 (deze is vast of random bepaald)
	
  var iCntNoImg = 0;
	while (((imgs[randStart].src==sHttpNoImg) || (imgs[randStart].src==sNoImg)) && (iCntNoImg < 20)) {
		// imgs[x+1]; als deze bestaat... anders de 0-de
    iCntNoImg += 1;
		randStart = imgs[randStart+1]?randStart+1:0;
	}

  // gevonden
	imgs[randStart].style.display = "block";
	imgs[randStart].xOpacity = .99;	
	current=randStart;
	setTimeout(so_xfade,5000);  // hier stond 000  dus ...
} 

function so_xfade() {

	// de volgende image ...
  
  // neem de xOpacity over van het actuele plaatje (current)
	cOpacity = imgs[current].xOpacity;

  // het volgende plaatje: x+1 of 0
	nIndex = imgs[current+1]?current+1:0;
	
  var iCntNoImg = 0;
	while (((imgs[nIndex].src==sHttpNoImg) || (imgs[nIndex].src==sNoImg)) && (iCntNoImg < 20)) {
  	// het volgende plaatje zoeken indien shownoimg.gif
    iCntNoImg += 1;
		nIndex = imgs[nIndex+1]?nIndex+1:0;
	}
	if (iCntNoImg == 20)
  {
  	// gewoon de volgende noimg pakken
  	nIndex = imgs[current+1]?current+1:0;
  }
  
  // (next)
	nOpacity = imgs[nIndex].xOpacity;
	
	cOpacity-=.02; // afnemen
	nOpacity+=.02; // toenemen
	
	imgs[nIndex].style.display = "block"; // display de nieuwe
	imgs[current].xOpacity = cOpacity;
	imgs[nIndex].xOpacity = nOpacity;
	
	setOpacity(imgs[current]); 
	setOpacity(imgs[nIndex]);
	
	if(cOpacity<=0) {
		imgs[current].style.display = "none";
    // nieuw plaatje
		current = nIndex;
		setTimeout(so_xfade,2500);
	} else {
    // huidig plaatje
		setTimeout(so_xfade,50);
	}
	
	function setOpacity(obj) {
		if(obj.xOpacity>.99) {
			obj.xOpacity = .99;
			return;
		}
    // misschien loopt die fout bij -0...
		if(obj.xOpacity<0) {
			return;
		}
    
		obj.style.opacity = obj.xOpacity;
		obj.style.MozOpacity = obj.xOpacity;
		obj.style.filter = "alpha(opacity=" + (obj.xOpacity*100) + ")";
	}
	
}

/* Linkerkant */
var links_imgs = new Array(), links_zInterval = null, links_current=0, links_pause=false;
var links_afbStart;
var links_try_init = 0;

function links_so_init() {
	if(!d.getElementById || !d.createElement){
  	// in de timing kennelijk iets 'mis'
    links_try_init += 1;

    if (links_try_init < 10) setTimeout(links_so_init,500);
    
   		return;
	}

	if(!d.getElementById("links_imageContainer")) {
		return
	}
	
	links_imgs = d.getElementById("links_imageContainer").getElementsByTagName("img");
	
	if (!links_imgs) {
	  	// ? iets mis met de pagina
		links_try_init += 1;
		setTimeout(links_so_init,500);
		return;
	}
  
	var links_randStart = links_afbStart - 1; 
  
  // for sure..
	if (isNaN(links_randStart)) links_randStart = 0;
	if (links_randStart < 0) links_randStart = 0; 
	
	for( links_i=0;links_i<links_imgs.length;links_i++) links_imgs[links_i].xOpacity = 0;

  // bepaal de image om mee te starten
  // begin bij de afbStart - 1 (deze is vast of random bepaald)
	
	var links_iCntNoImg = 0;
	while (((links_imgs[links_randStart].src==sHttpNoImg) || (links_imgs[links_randStart].src==sNoImg)) && (links_iCntNoImg < 20)) {
		// imgs[x+1]; als deze bestaat... anders de 0-de
    	links_iCntNoImg += 1;
		links_randStart = links_imgs[links_randStart+1]?links_randStart+1:0;
	}

  // gevonden
	links_imgs[links_randStart].style.display = "block";
	links_imgs[links_randStart].xOpacity = .99;	
	links_current=links_randStart;
	setTimeout(links_so_xfade,5000);  // hier stond 000  dus ...
} 

function links_so_xfade() {

	// de volgende image ...
  
  // neem de xOpacity over van het actuele plaatje (current)
	links_cOpacity = links_imgs[links_current].xOpacity;


  // het volgende plaatje: x+1 of 0
	links_nIndex = links_imgs[links_current+1]?links_current+1:0;
	
 	var links_iCntNoImg = 0;
	while (((links_imgs[links_nIndex].src==sHttpNoImg) || (links_imgs[links_nIndex].src==sNoImg)) && (links_iCntNoImg < 20)) {
  	// het volgende plaatje zoeken indien shownoimg.gif
    links_iCntNoImg += 1;
		links_nIndex = links_imgs[links_nIndex+1]?links_nIndex+1:0;
	}
	if (links_iCntNoImg == 20)
  {
  	// gewoon de volgende noimg pakken
  	links_nIndex = links_imgs[links_current+1]?links_current+1:0;
  }
  
  // (next)
	links_nOpacity = links_imgs[links_nIndex].xOpacity;
	
	links_cOpacity-=.02; // afnemen
	links_nOpacity+=.02; // toenemen
	//	if (console) console.log(links_nOpacity);
	links_imgs[links_nIndex].style.display = "block"; // display de nieuwe
	links_imgs[links_current].xOpacity = links_cOpacity;
	links_imgs[links_nIndex].xOpacity = links_nOpacity;
	
	setOpacity(links_imgs[links_current]); 
	setOpacity(links_imgs[links_nIndex]);
	
	if(links_cOpacity<=0) {
		links_imgs[links_current].style.display = "none";
    // nieuw plaatje
		links_current = links_nIndex;
		setTimeout(links_so_xfade,5000);
	} else {
    // huidig plaatje
		setTimeout(links_so_xfade,50);
	}

	function setOpacity(obj) {
		if(obj.xOpacity>.99) {
			obj.xOpacity = .99;
			return;
		}
		if(obj.xOpacity<0) {
			return;
		}
    
		obj.style.opacity = obj.xOpacity;
		obj.style.MozOpacity = obj.xOpacity;
		obj.style.filter = "alpha(opacity=" + (obj.xOpacity*100) + ")";
	}
	
}

