/*==================================================* $Id: slideshow.js,v 1.16 2003/10/14 12:39:00 pat Exp $ Copyright 2000-2003 Patrick Fitzgerald http://slideshow.barelyfitz.com/ This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *==================================================*/ // There are two objects defined in this file: // "slide" - contains all the information for a single slide // "slideshow" - consists of multiple slide objects and runs the slideshow //================================================== // slide object //================================================== function slide(src,link,text, price, target,attr) { // This is the constructor function for the slide object. // It is called automatically when you create a new slide object. // For example: // s = new slide(); // Image URL this.src = src; // Link URL this.link = link; // Text to display this.text = text; // Price to display this.price = price; // Name of the target window ("_blank") this.target = target; // Custom duration for the slide, in milliseconds. // This is an optional parameter. // this.timeout = 3000 // Attributes for the target window: // width=n,height=n,resizable=yes or no,scrollbars=yes or no, // toolbar=yes or no,location=yes or no,directories=yes or no, // status=yes or no,menubar=yes or no,copyhistory=yes or no // Example: "width=200,height=300" this.attr = attr; // Create an image object for the slide if (document.images) { this.image = new Image(); } // Flag to tell when load() has already been called this.loaded = false; //-------------------------------------------------- this.load = function() { // This method loads the image for the slide if (!document.images) { return; } if (!this.loaded) { this.image.src = this.src; this.loaded = true; } } //-------------------------------------------------- this.hotlink = function() { // This method jumps to the slide's link. // If a window was specified for the slide, then it opens a new window. var mywindow; // If this slide does not have a link, do nothing if (!this.link) return; // Open the link in a separate window? if (this.target) { // If window attributes are specified, // use them to open the new window if (this.attr) { mywindow = window.open(this.link, this.target, this.attr); } else { // If window attributes are not specified, do not use them // (this will copy the attributes from the originating window) mywindow = window.open(this.link, this.target); } // Pop the window to the front if (mywindow && mywindow.focus) mywindow.focus(); } else { // Open the link in the current window location.href = this.link; } } } //================================================== // slideshow object //================================================== function slideshow( slideshowname ) { // This is the constructor function for the slideshow object. // It is called automatically when you create a new object. // For example: // ss = new slideshow("ss"); // Name of this object // (required if you want your slideshow to auto-play) // For example, "SLIDES1" this.name = slideshowname; // When we reach the last slide, should we loop around to start the // slideshow again? this.repeat = true; // Number of images to pre-fetch. // -1 = preload all images. // 0 = load each image is it is used. // n = pre-fetch n images ahead of the current image. // I recommend preloading all images unless you have large // images, or a large amount of images. this.prefetch = 1; // IMAGE element on your HTML page. // For example, document.images.SLIDES1IMG this.image; // ID of a DIV element on your HTML page that will contain the text. // For example, "slides2text" // Note: after you set this variable, you should call // the update() method to update the slideshow display. this.textid; // ID of a DIV element on your HTML page that will contain the price. // For example, "slides2price" // Note: after you set this variable, you should call // the update() method to update the slideshow display. this.priceid; // TEXTAREA element on your HTML page. // For example, document.SLIDES1FORM.SLIDES1TEXT // This is a depracated method for displaying the text, // but you might want to supply it for older browsers. this.textarea; // Milliseconds to pause between slides. // Individual slides can override this. this.timeout = 5000; // Hook functions to be called before and after updating the slide // this.pre_update_hook = function() { } // this.post_update_hook = function() { } // These are private variables this.slides = new Array(); this.current = 0; this.timeoutid = 0; //-------------------------------------------------- // Public methods //-------------------------------------------------- this.add_slide = function(slide) { // Add a slide to the slideshow. // For example: // SLIDES1.add_slide(new slide("s1.jpg", "link.html")) var i = this.slides.length; // Prefetch the slide image if necessary if (this.prefetch == -1) { slide.load(); } this.slides[i] = slide; } //-------------------------------------------------- this.play = function(timeout) { // This method implements the automatically running slideshow. // If you specify the "timeout" argument, then a new default // timeout will be set for the slideshow. // Make sure we're not already playing this.pause(); // If the timeout argument was specified (optional) // then make it the new default if (timeout) { this.timeout = timeout; } // If the current slide has a custom timeout, use it; // otherwise use the default timeout if (typeof this.slides[ this.current ].timeout != 'undefined') { timeout = this.slides[ this.current ].timeout; } else { timeout = this.timeout; } // After the timeout, call this.loop() this.timeoutid = setTimeout( this.name + ".loop()", timeout); } //-------------------------------------------------- this.pause = function() { // This method stops the slideshow if it is automatically running. if (this.timeoutid != 0) { clearTimeout(this.timeoutid); this.timeoutid = 0; } } //-------------------------------------------------- this.update = function() { // This method updates the slideshow image on the page // Make sure the slideshow has been initialized correctly if (! this.valid_image()) { return; } // Call the pre-update hook function if one was specified if (typeof this.pre_update_hook == 'function') { this.pre_update_hook(); } // Convenience variable for the current slide var slide = this.slides[ this.current ]; // Determine if the browser supports filters var dofilter = false; if (this.image && typeof this.image.filters != 'undefined' && typeof this.image.filters[0] != 'undefined') { dofilter = true; } // Load the slide image if necessary slide.load(); // Apply the filters for the image transition if (dofilter) { // If the user has specified a custom filter for this slide, // then set it now if (slide.filter && this.image.style && this.image.style.filter) { this.image.style.filter = slide.filter; } this.image.filters[0].Apply(); } // Update the image. this.image.src = slide.image.src; // Play the image transition filters if (dofilter) { this.image.filters[0].Play(); } // Update the text this.display_text(); // Update the price this.display_price(); // Call the post-update hook function if one was specified if (typeof this.post_update_hook == 'function') { this.post_update_hook(); } // Do we need to pre-fetch images? if (this.prefetch > 0) { var next, prev, count; // Pre-fetch the next slide image(s) next = this.current; prev = this.current; count = 0; do { // Get the next and previous slide number // Loop past the ends of the slideshow if necessary if (++next >= this.slides.length) next = 0; if (--prev < 0) prev = this.slides.length - 1; // Preload the slide image this.slides[next].load(); this.slides[prev].load(); // Keep going until we have fetched // the designated number of slides } while (++count < this.prefetch); } } //-------------------------------------------------- this.goto_slide = function(n) { // This method jumpts to the slide number you specify. // If you use slide number -1, then it jumps to the last slide. // You can use this to make links that go to a specific slide, // or to go to the beginning or end of the slideshow. // Examples: // onClick="myslides.goto_slide(0)" // onClick="myslides.goto_slide(-1)" // onClick="myslides.goto_slide(5)" if (n == -1) { n = this.slides.length - 1; } if (n < this.slides.length && n >= 0) { this.current = n; } this.update(); } //-------------------------------------------------- this.goto_random_slide = function(include_current) { // Picks a random slide (other than the current slide) and // displays it. // If the include_current parameter is true, // then // See also: shuffle() var i; // Make sure there is more than one slide if (this.slides.length > 1) { // Generate a random slide number, // but make sure it is not the current slide do { i = Math.floor(Math.random()*this.slides.length); } while (i == this.current); // Display the slide this.goto_slide(i); } } //-------------------------------------------------- this.next = function() { // This method advances to the next slide. // Increment the image number if (this.current < this.slides.length - 1) { this.current++; } else if (this.repeat) { this.current = 0; } this.update(); } //-------------------------------------------------- this.previous = function() { // This method goes to the previous slide. // Decrement the image number if (this.current > 0) { this.current--; } else if (this.repeat) { this.current = this.slides.length - 1; } this.update(); } //-------------------------------------------------- this.shuffle = function() { // This method randomly shuffles the order of the slides. var i, i2, slides_copy, slides_randomized; // Create a copy of the array containing the slides // in sequential order slides_copy = new Array(); for (i = 0; i < this.slides.length; i++) { slides_copy[i] = this.slides[i]; } // Create a new array to contain the slides in random order slides_randomized = new Array(); // To populate the new array of slides in random order, // loop through the existing slides, picking a random // slide, removing it from the ordered list and adding it to // the random list. do { // Pick a random slide from those that remain i = Math.floor(Math.random()*slides_copy.length); // Add the slide to the end of the randomized array slides_randomized[ slides_randomized.length ] = slides_copy[i]; // Remove the slide from the sequential array, // so it cannot be chosen again for (i2 = i + 1; i2 < slides_copy.length; i2++) { slides_copy[i2 - 1] = slides_copy[i2]; } slides_copy.length--; // Keep going until we have removed all the slides } while (slides_copy.length); // Now set the slides to the randomized array this.slides = slides_randomized; } //-------------------------------------------------- this.get_text = function() { // This method returns the text of the current slide return(this.slides[ this.current ].text); } //-------------------------------------------------- this.get_price = function() { // This method returns the price of the current slide return(this.slides[ this.current ].price); } //-------------------------------------------------- this.get_all_text = function(before_slide, after_slide) { // Return the text for all of the slides. // For the text of each slide, add "before_slide" in front of the // text, and "after_slide" after the text. // For example: // document.write("
';
if (slide.link) {
$html += '';
}
$html += '';
if (slide.link) {
$html += "<\/a>";
}
if (slide.text) {
$html += "
\n" + slide.text;
}
if (slide.price) {
$html += "
\n" + slide.price;
}
$html += "<\/P>" + "\n\n";
}
// Make the HTML browser-safe
$html = $html.replace(/\&/g, "&" );
$html = $html.replace(//g, ">" );
return('' + $html + '
');
}
//==================================================
// Private methods
//==================================================
//--------------------------------------------------
this.loop = function() {
// This method is for internal use only.
// This method gets called automatically by a JavaScript timeout.
// It advances to the next slide, then sets the next timeout.
// If the next slide image has not completed loading yet,
// then do not advance to the next slide yet.
// Make sure the next slide image has finished loading
if (this.current < this.slides.length - 1) {
next_slide = this.slides[this.current + 1];
if (next_slide.image.complete == null || next_slide.image.complete) {
this.next();
}
} else { // we're at the last slide
this.next();
}
// Keep playing the slideshow
this.play( );
}
//--------------------------------------------------
this.valid_image = function() {
// Returns 1 if a valid image has been set for the slideshow
if (!this.image)
{
return false;
}
else {
return true;
}
}
//--------------------------------------------------
this.getElementById = function(element_id) {
// This method returns the element corresponding to the id
if (document.getElementById) {
return document.getElementById(element_id);
}
else if (document.all) {
return document.all[element_id];
}
else if (document.layers) {
return document.layers[element_id];
} else {
return undefined;
}
}
//==================================================
// Deprecated methods
// I don't recommend the use of the following methods,
// but they are included for backward compatibility.
// You can delete them if you don't need them.
//==================================================
//--------------------------------------------------
this.set_image = function(imageobject) {
// This method is deprecated; you should use
// the following code instead:
// s.image = document.images.myimagename;
// s.update();
if (!document.images)
return;
this.image = imageobject;
}
//--------------------------------------------------
this.set_textarea = function(textareaobject) {
// This method is deprecated; you should use
// the following code instead:
// s.textarea = document.form.textareaname;
// s.update();
this.textarea = textareaobject;
this.display_text();
}
//--------------------------------------------------
this.set_textid = function(textidstr) {
// This method is deprecated; you should use
// the following code instead:
// s.textid = "mytextid";
// s.update();
this.textid = textidstr;
this.display_text();
}
//--------------------------------------------------
this.set_priceid = function(priceidstr) {
// This method is deprecated; you should use
// the following code instead:
// s.textid = "mytextid";
// s.update();
this.priceid = priceidstr;
this.display_price();
}
}
SLIDES = new slideshow("SLIDES");
s = new slide();
s.src = "http://imagehost.gsmls.com/ihomefinder/20/2336820_0.jpg";
s.link = "http://www.idxre.com/idx/detail.cfm?cid=11313&pid=2336820&bid=146";
s.text = "
$12,900,000
7 Beds - 6 Full | 3 Partial Baths
$3,750,000
6 Beds - 8 Full | 2 Partial Baths
$3,750,000
6 Beds - 3 Full | 3 Partial Baths
$2,900,000
5 Beds - 6 Full | 1 Partial Baths
$2,825,000
5 Beds - 4 Full | 2 Partial Baths
$2,495,000
5 Beds - 4 Full | 1 Partial Baths
$2,490,000
6 Beds - 5 Full | 2 Partial Baths
$2,295,000
5 Beds - 5 Full | 1 Partial Baths
$2,195,000
4 Beds - 3 Full | 2 Partial Baths
$2,195,000
5 Beds - 5 Full | 2 Partial Baths
$1,999,000
7 Beds - 6 Full | 1 Partial Baths
$1,850,000
4 Beds - 3 Full | 2 Partial Baths
$1,795,000
9 Beds - 5 Full | 1 Partial Baths
$1,750,000
6 Beds - 3 Full | 1 Partial Baths
$1,600,000
5 Beds - 4 Full | 1 Partial Baths
$1,595,000
5 Beds - 4 Full | 2 Partial Baths
$1,499,000
4 Beds - 5 Full | 1 Partial Baths
$1,399,000
4 Beds - 3 Full | 1 Partial Baths
$1,250,000
5 Beds - 4 Full | 1 Partial Baths
$1,239,000
3 Beds - 4 Full | 1 Partial Baths
$1,199,000
3 Beds - 3 Full | 1 Partial Baths
$1,195,000
5 Beds - 3 Full | 2 Partial Baths
$1,115,000
3 Beds - 2 Full | 1 Partial Baths
$1,078,000
4 Beds - 3 Full | 1 Partial Baths
$995,000
4 Beds - 3 Full | 1 Partial Baths
$995,000
2 Beds - 4 Full | 2 Partial Baths
$995,000
4 Beds - 3 Full | 1 Partial Baths
$949,000
4 Beds - 2 Full | 1 Partial Baths
$899,000
6 Beds - 2 Full | 3 Partial Baths
$849,000
5 Beds - 3 Full | 2 Partial Baths
$839,000
4 Beds - 2 Full | 2 Partial Baths
$835,000
5 Beds - 2 Full | 1 Partial Baths
$799,000
4 Beds - 2 Baths
$775,000
5 Beds - 3 Full | 1 Partial Baths
$770,000
4 Beds - 1 Full | 1 Partial Baths
$759,000
4 Beds - 2 Full | 2 Partial Baths
$709,000
3 Beds - 1 Full | 1 Partial Baths
$699,900
3 Beds - 2 Baths
$699,000
4 Beds - 2 Full | 1 Partial Baths
$699,000
4 Beds - 2 Baths
$699,000
5 Beds - 2 Full | 1 Partial Baths
$699,000
3 Beds - 2 Full | 1 Partial Baths
$698,200
4 Beds - 2 Full | 1 Partial Baths
$695,000
3 Beds - 2 Full | 1 Partial Baths
$655,000
3 Beds - 2 Full | 1 Partial Baths
$650,000
3 Beds - 2 Baths
$649,000
3 Beds - 1 Full | 1 Partial Baths
$640,000
3 Beds - 2 Baths
$639,000
3 Beds - 2 Full | 1 Partial Baths
$627,000
3 Beds - 2 Full | 1 Partial Baths
$595,000
2 Beds - 1 Baths
$579,000
4 Beds - 2 Full | 1 Partial Baths
$575,000
3 Beds - 2 Baths
$524,900
3 Beds - 2 Full | 1 Partial Baths
$519,000
4 Beds - 2 Full | 1 Partial Baths
$500,000
2 Beds - 2 Baths
$475,000
3 Beds - 2 Baths
$475,000
3 Beds - 1 Full | 1 Partial Baths
$475,000
4 Beds - 2 Baths
$469,000
2 Beds - 2 Full | 1 Partial Baths
$439,000
2 Beds - 2 Full | 1 Partial Baths
$429,000
4 Beds - 2 Full | 1 Partial Baths
$427,000
3 Beds - 2 Baths
$425,000
4 Beds - 1 Full | 1 Partial Baths
$389,000
4 Beds - 1 Baths
$365,000
2 Beds - 2 Baths
$349,000
3 Beds - 1 Baths
$329,000
2 Beds - 1 Baths
$309,000
2 Beds - 1 Baths
$12,000
5 Beds - 5 Full | 1 Partial Baths
$ 7,500
9 Beds - 5 Full | 1 Partial Baths
$ 6,500
3 Beds - 4 Full | 1 Partial Baths
$ 4,700
3 Beds - 2 Full | 1 Partial Baths
$ 3,500
- 1 Full | 1 Partial Baths
$ 3,000
2 Beds - 1 Baths
$ 2,950
2 Beds - 2 Full | 1 Partial Baths
$ 2,650
3 Beds - 1 Full | 1 Partial Baths
$ 2,500
1 Beds - 1 Baths
$ 2,300
4 Beds - 1 Baths
$ 1,250
1 Beds - 1 Baths');
document.write(' ');
document.write(' ');
document.write(' ');
document.write(' ');
document.write('
');
document.write(' ');
document.write(' ');
document.write(' ');
document.write('
');
document.write(' ');
document.write(' ');
document.write('');
SLIDES.goto_slide(0)
if (document.images)
{
SLIDES.set_image(document.images.SLIDESIMG);
SLIDES.set_textid("SLIDESTEXT"); // optional
SLIDES.set_priceid("SLIDESPRICE");
SLIDES.update();
SLIDES.play(); //optional
}
');
document.write('