Go Back   CodingForums.com > :: Client side development > JavaScript programming > JavaScript frameworks

Before you post, read our: Rules & Posting Guidelines

Reply
 
Thread Tools Rate Thread
Enjoy an ad free experience by logging in. Not a member yet? Register.
Old 11-24-2011, 08:44 AM   PM User | #1
besly98
New to the CF scene

 
Join Date: Nov 2011
Posts: 1
Thanks: 0
Thanked 0 Times in 0 Posts
besly98 is an unknown quantity at this point
looping indefinitely

Hi All,

I have the following script that i have taken and amended


Code:
var slideshowSpeed = 6000;

var photos = [ {
		"title" : "",
		"image" : "xmas-slide-1.jpg",
		"url" : "",
		"firstline" : "",
		"secondline" : ""
	}, {
		"title" : "",
		"image" : "xmas-slide-2.jpg",
		"url" : "",
		"firstline" : "",
		"secondline" : ""
	}, {
		"title" : "",
		"image" : "xmas-slide-3.jpg",
		"url" : "",
		"firstline" : "",
		"secondline" : ""
	}, {
		"title" : "",
		"image" : "xmas-slide-4.jpg",
		"url" : "",
		"firstline" : "",
		"secondline" : ""
	}
];



$(document).ready(function() {
		
	// Backwards navigation
	$("#back").click(function() {
		stopAnimation();
		navigate("back");
	});
	
	// Forward navigation
	$("#next").click(function() {
		stopAnimation();
		navigate("next");
	});
	
		$("#next1").click(function() {
		stopAnimation();
		navigate("next1");
	});
	
			$("#next2").click(function() {
		stopAnimation();
		navigate("next2");
	});
	
			$("#next3").click(function() {
		stopAnimation();
		navigate("next3");
	});
	
			$("#next4").click(function() {
		stopAnimation();
		navigate("next4");
	});
	

	
	var interval;
	$("#control").toggle(function(){
		stopAnimation();
	}, function() {
	
		// Change the background image to "pause"
		$(this).css({ "background-image" : "url(images/pause.png)" });
		
		// Show the next image
		navigate1("next");
		
		// Start playing the animation
		interval = setInterval(function() {
			navigate("next");
		}, slideshowSpeed);
	});
	
	
	var activeContainer = 1;	
	var currentImg = 0;
	var animating = false;
	var navigate = function(direction) {
	//alert(direction)
		// Check if no animation is running. If it is, prevent the action
		if(animating) {
			return;
		}
		
		// Check which current image we need to show
		if(direction == "next") {
			currentImg++;
			//alert(currentImg)
			if(currentImg == photos.length + 1) {
				currentImg = 1;
			}
		}
else if(direction == "next1") {
			currentImg = 1;
		

		}
else if(direction == "next2") {
			currentImg = 2;
		

		}
else if(direction == "next3") {
			currentImg = 3;
		}
else if(direction == "next4") {
			currentImg = 4;
	

		}		else {
					}
		
		// Check which container we need to use
		var currentContainer = activeContainer;
		if(activeContainer == 1) {
			activeContainer = 2;
		} else {
			activeContainer = 1;
		}
		
		showImage(photos[currentImg - 1], currentContainer, activeContainer);
		
	};
	
	

	
	var currentZindex = 100;
	var showImage = function(photoObject, currentContainer, activeContainer) {
		animating = true;
		
		// Make sure the new container is always on the background
		currentZindex--;
		
		// Set the background image of the new active container
		$("#headerimg" + activeContainer).css({
			"background-image" : "url(images/" + photoObject.image + ")",
			"display" : "block",
			"z-index" : currentZindex
		});
		
		// Hide the header text
		$("#headertxt").css({"display" : "none"});
		
		// Set the new header text
		$("#firstline").html(photoObject.firstline);
		$("#secondline")
			.attr("href", photoObject.url)
			.html(photoObject.secondline);
		$("#pictureduri")
			.attr("href", photoObject.url)
			.html(photoObject.title);
		
		
		// Fade out the current container
		// and display the header text when animation is complete
		$("#headerimg" + currentContainer).fadeOut(function() {
			setTimeout(function() {
				$("#headertxt").css({"display" : "block"});
				animating = false;
			}, 500);
		});
	};
	
	var stopAnimation = function() {
		// Change the background image to "play"
		$("#control").css({ "background-image" : "url(images/play.png)" });
		
		// Clear the interval
		clearInterval(interval);
	};
	
	// We should statically set the first image
	navigate("next");
	
	// Start playing the animation
	interval = setInterval(function() {
		navigate("next");
	}, slideshowSpeed);
	
});
it is suppost to run the #control function indefinitely but it seems to time out after a while.

any idea how to fix it?
Thanks
besly98 is offline   Reply With Quote
Reply

Bookmarks

Jump To Top of Thread


Thread Tools
Rate This Thread
Rate This Thread:

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off

Forum Jump


All times are GMT +1. The time now is 06:51 AM.


Advertisement
Log in to turn off these ads.