Javascript 延时效果 : displaying 30 images/second (read for more detail)

标签 javascript image slideshow timelapse

我有一个客户为他的投资组合网站制作了一个“视觉日记”,其中包含他每天拍摄一次的照片,持续 365 天。他要我把这些放在一起做成一个延时效果片。我考虑过使用 Flash,但最终选择了 JavaScript。

需要发生的是:图像循环非常非常快,没有过渡或任何东西,只有图像-图像-图像等。大约 30/fps 或类似速度。当您单击闪烁的图像时,它会停在您选择的图像上,以便用户查看。当您再次点击时,幻灯片会再次开始播放。

我的问题是我是一个 PHP/XHTML/CSS 专家,对 JavaScript 不是很了解。我可以很高兴地将它集成到任何页面中,但它只是编写让我感到困扰的 JavaScript。

在他的主页上,我有这段代码用于显示基本的幻灯片 - 带有过渡效果等。它在 HTML 中,但我敢肯定你可以理解代码:

<!-- Code for slideshow -->
<!-- Found on http://www.webdeveloper.com/forum/showthread.php?t=81441 -->

<SCRIPT LANGUAGE="JavaScript">
<!-- Begin
// Set slideShowSpeed (milliseconds)
var slideShowSpeed = 3000;
// Duration of crossfade (seconds)
var crossFadeDuration = 3;
// Specify the image files
var Pic = new Array();
// to add more images, just continue
// the pattern, adding to the array below

Pic[0] = '1.jpg'
Pic[1] = '2.jpg'
Pic[2] = '3.jpg'
Pic[3] = '4.jpg'
Pic[4] = '5.jpg'
Pic[5] = '6.jpg'
Pic[6] = '7.jpg'
Pic[7] = '8.jpg'
Pic[8] = '9.jpg'
Pic[9] = '10.jpg'
Pic[10] = '11.jpg'
Pic[11] = '12.jpg'
Pic[12] = '13.jpg'
Pic[13] = '14.jpg'
Pic[14] = '15.jpg'
Pic[15] = '16.jpg'
Pic[16] = '17.jpg'
Pic[17] = '18.jpg'
Pic[18] = '19.jpg'
Pic[19] = '20.jpg'

// do not edit anything below this line
var t;
var j = 0;
var p = Pic.length;
var preLoad = new Array();
for (i = 0; i < p; i++) {
preLoad[i] = new Image();
preLoad[i].src = Pic[i];
}
function runSlideShow() {
if (document.all) {
document.images.SlideShow.style.filter="blendTrans(duration=2)";
document.images.SlideShow.style.filter="blendTrans(duration=crossFadeDuration)";
document.images.SlideShow.filters.blendTrans.Apply();
}
document.images.SlideShow.src = preLoad[j].src;
if (document.all) {
document.images.SlideShow.filters.blendTrans.Play();
}
j = j + 1;
if (j > (p - 1)) j = 0;
t = setTimeout('runSlideShow()', slideShowSpeed);
}
//  End -->
</script>

有没有办法修改这段代码来关闭所有的过渡效果,让它在你点击/再次启动时停止播放?否则,引用一些不同的代码会有帮助。

谢谢大家!

jack

最佳答案

您似乎在使用特定于 IE 的代码。我建议在专用的 JavaScript 库中使用各种效果模块,例如 MooTools (我个人的最爱),jQuery , 或 Prototype + script.aculo.us .

要停止幻灯片放映,您应该能够简单地清除超时 t:

clearTimeout(t);

此外,您不应该引用 setTimeout 的第一个参数。向它传递一个函数引用:

setTimeout(runSlideShow, slideShowSpeed);

关于Javascript 延时效果 : displaying 30 images/second (read for more detail),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2126994/

相关文章:

javascript - 如何将视频嵌入到没有自己网站详细信息的网站中?

javascript - Chrome 无法识别我对 javascript 文件所做的更改并加载旧代码?

html - rails : Image as a link

android - 错误的 Xamarin 形成图像维度

slideshow - Jssor 幻灯片与生成的内容

javascript - 更改图像幻灯片幻灯片中的图像

Android Image Slider 无法隐藏页面指示器

javascript - Jquery .delay().fadeOut 取消/清除队列..可能吗?如何?

jquery - 图像延迟加载(jQuery)后如何更改CSS?

javascript - 操作 MongoDB 响应 NodeJS