var x; var delai; //Pensez à intégrer slide.css function fade(X) { x = X; if (isIE){ document.slshw.filters.blendTrans.apply(); document.slshw.src="slide/s"+x+".jpg"; document.slshw.filters.blendTrans.play(); } else{ crossfade(document.getElementById('slshw'), 'slide/s'+x+'.jpg', '1', '') //document.slshw.src="slide/s"+x+".jpg"; } x--; if (x == 53) {x =83} delai = setTimeout('fade('+x+')',5000); } // IXF1.11 :: Image cross-fade // ***************************************************** // DOM scripting by brothercake -- http://www.brothercake.com/ //****************************************************** //global object var ixf = { 'clock' : null, 'count' : 1 } /******************************************************* /***************************************************************************** List the images that need to be cached *****************************************************************************/ ixf.imgs = [ 'slide/s53.jpg', 'slide/s54.jpg', 'slide/s55.jpg', 'slide/s56.jpg', 'slide/s57.jpg', 'slide/s58.jpg', 'slide/s59.jpg', 'slide/s60.jpg', 'slide/s61.jpg', 'slide/s62.jpg', 'slide/s63.jpg', 'slide/s64.jpg', 'slide/s65.jpg', 'slide/s66.jpg', 'slide/s67.jpg', 'slide/s68.jpg', 'slide/s69.jpg', 'slide/s70.jpg', 'slide/s71.jpg', 'slide/s72.jpg', 'slide/s73.jpg', 'slide/s74.jpg', 'slide/s75.jpg', 'slide/s76.jpg', 'slide/s77.jpg', 'slide/s78.jpg', 'slide/s79.jpg', 'slide/s80.jpg', 'slide/s81.jpg', 'slide/s82.jpg', 'slide/s83.jpg', ]; /***************************************************************************** *****************************************************************************/ //cache the images ixf.imgsLen = ixf.imgs.length; ixf.cache = []; for(var ix=0; ix 0 && typeof ixf.obj.filters.alpha == 'object' && typeof ixf.obj.filters.alpha.opacity == 'number') ? 'ie' : 'none'; } else { ixf.type = 'none'; } //change the image alt text if defined if(typeof arguments[3] != 'undefined' && arguments[3] != '') { ixf.obj.alt = arguments[3]; } //if any kind of opacity is supported if(ixf.type != 'none') { //create a new image object and append it to body //detecting support for namespaced element creation, in case we're in the XML DOM ixf.newimg = document.getElementsByTagName('body')[0].appendChild(document.createElement('img')); //set positioning classname ixf.newimg.className = 'idupe'; //move it to superimpose original image ixf.newimg.style.left = ixf.getRealPosition(ixf.obj, 'x') + 'px'; ixf.newimg.style.top = ixf.getRealPosition(ixf.obj, 'y') + 'px'; //set src to new image src ixf.newimg.src = ixf.src //copy and convert fade duration argument ixf.length = parseInt(arguments[2], 10) * 1000; //create fade resolution argument as 20 steps per transition ixf.resolution = parseInt(arguments[2], 10) * 20; //start the timer ixf.clock = setInterval('ixf.crossfade()', ixf.length/ixf.resolution); } //otherwise if opacity is not supported else { //just do the image swap ixf.obj.src = ixf.src; } } }; //crossfade timer function ixf.crossfade = function() { //decrease the counter on a linear scale ixf.count -= (1 / ixf.resolution); //if the counter has reached the bottom if(ixf.count < (1 / ixf.resolution)) { //clear the timer clearInterval(ixf.clock); ixf.clock = null; //reset the counter ixf.count = 1; //set the original image to the src of the new image ixf.obj.src = ixf.src; } //set new opacity value on both elements //using whatever method is supported switch(ixf.type) { case 'ie' : ixf.obj.filters.alpha.opacity = ixf.count * 100; ixf.newimg.filters.alpha.opacity = (1 - ixf.count) * 100; break; case 'khtml' : ixf.obj.style.KhtmlOpacity = ixf.count; ixf.newimg.style.KhtmlOpacity = (1 - ixf.count); break; case 'moz' : //restrict max opacity to prevent a visual popping effect in firefox ixf.obj.style.MozOpacity = (ixf.count == 1 ? 0.9999999 : ixf.count); ixf.newimg.style.MozOpacity = (1 - ixf.count); break; default : //restrict max opacity to prevent a visual popping effect in firefox ixf.obj.style.opacity = (ixf.count == 1 ? 0.9999999 : ixf.count); ixf.newimg.style.opacity = (1 - ixf.count); } //now that we've gone through one fade iteration //we can show the image that's fading in ixf.newimg.style.visibility = 'visible'; //keep new image in position with original image //in case text size changes mid transition or something ixf.newimg.style.left = ixf.getRealPosition(ixf.obj, 'x') + 'px'; ixf.newimg.style.top = ixf.getRealPosition(ixf.obj, 'y') + 'px'; //if the counter is at the top, which is just after the timer has finished if(ixf.count == 1) { //remove the duplicate image ixf.newimg.parentNode.removeChild(ixf.newimg); } }; //get real position method ixf.getRealPosition = function() { this.pos = (arguments[1] == 'x') ? arguments[0].offsetLeft : arguments[0].offsetTop; this.tmp = arguments[0].offsetParent; while(this.tmp != null) { this.pos += (arguments[1] == 'x') ? this.tmp.offsetLeft : this.tmp.offsetTop; this.tmp = this.tmp.offsetParent; } return this.pos; };