扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
轮播图自动切换吗?
站在用户的角度思考问题,与客户深入沟通,找到云县网站设计与云县网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:网站制作、网站设计、企业官网、英文网站、手机端网站、网站推广、域名与空间、网络空间、企业邮箱。业务覆盖云县地区。
script language =javascript
var curIndex=0;
//时间间隔 单位毫秒
var timeInterval=1000;
var arr=new Array();
arr[0]="1.jpg";
arr[1]="2.jpg";
arr[2]="3.jpg";
arr[3]="4.jpg";
arr[4]="5.jpg";
arr[5]="6.jpg";
arr[6]="7.jpg";
setInterval(changeImg,timeInterval);
function changeImg()
{
var obj=document.getElementById("obj");
if (curIndex==arr.length-1)
{
curIndex=0;
}
else
{
curIndex+=1;
}
obj.src=arr[curIndex];
}
/script
img id=obj src ="1.jpg" border =0 /
这样能看懂吗?
自己设置每张图片切换的时间间隔,自己设置每张图片的路径,绝对、相对路径都可以。
试试这个图片轮播
有12345数字一起切换
鼠标点一下数字会变换到另一张图片,不点就会自动换
里面有教程和源码
现在没空帮你写代码了,给你个思路自己写吧!轮播肯定是要切换图片的,并且一般切换的时候是从左到右或从右到左慢慢切的,所以你定义一个图片地址数组,再定义两个jlabel用来显示图片,一个JLabel显示当前图片,另一个显示最新图片!好了,现在你定义一个timer定时器来切换,每隔两秒,就判断一下最新的图片是哪个jlabel,然后将另一个jlabel填充新的图片,然后setlocation()来移动图片,x坐标每次向左几个像素,直至移动完成!这样就是一次轮播,当然你需要将两个jlabel放到一个panel中,免得会出现第二个图片多出一截在慢慢移动的情况
最后一个参数表示时间,3000代表3秒,比如说你设置成1000就是1秒,时间越大,速度越慢
function caroAnimate(imgNum) // 定义函数,参数是imgNum,表示图片数量
{
var currNav = 0; //定义变量,初始为0,表示当前图片是所有图片中的第几张。
var timer = "";// 切换时间,
var caroWidth = 320;//定义轮播图片的宽度
var imgArea = $("#adveCaro");///获取轮播图片所在的父级元素
var navArr = $("#nav_adveCaro").find("li");// 查找li元素,统计有多少张图片
var delay = 5000;//延迟切换时间。5秒切换一次
var aniSpeed = 500;//动画时间。也就是0.5秒就切换完成
loopImg(); //调用looImg函数,这里表示开始切换
startTimer(); // 设置动画切换时间
bindNavClick(); //调用用户点击事件,也就是用户点击哪张,就切换到哪张。
function loopImg(){//定义函数
imgArea.append(imgArea.children(":first").clone());///将列表中的第一张图片克隆,并附加到前面定义的父级元素下。
}
function bindNavClick(){///定义点击事件函数
navArr.click(function(){ ///点击事件
var nav = navArr.index($(this));///设置当前点击的序号,保存到nav这个变量里。
if(currNav != nav){
animate(nav);//判断,如果点击的位置不是上次点击的,就开始切换
}
});
}
function startTimer(){//设置动画切换函数
timer = setInterval(autoAnimate, delay);//表示每隔多长时间执行autoAnimate这个函数,也就是实现自动播放
}
function restartTimer(){//设置重新开始时间段,也就是设置,当播放到最后的时候,又重新来过
clearInterval(timer);//清除时间
startTimer();//重新设置时间
}
function autoAnimate(){//动事切换主函数
if(currNav == 0){
imgArea.css("margin-left","0px");//判断,如果是第一张,则设置图片显示区域左边距为0px
}
currNav++;//播放序号自加1,也就是每执行这个函数,就自动加1,相当于currNav=currNav+1
imgArea.animate({"margin-left":caroWidth*(-currNav)}, aniSpeed);//以动画的形式,aniSpeed秒后,将左边距设置父元素的宽度再减去当前的序号。
if(currNav = imgNum){
currNav = 0;//判断当前位置,currNavimgNum表示,已经到最后了,重新设置开始位置为0
}
changNav(currNav);//调用函数,根据上下文,这个功能应该是切换样式用的
}
function animate(nav){
imgArea.stop().animate({"margin-left":caroWidth*(-nav)}, aniSpeed);//这是定义停止动画时执行的特效,和面播放动画时的特效是一样的。
currNav = nav;//设置当前位置
changNav(nav);//改变样式
restartTimer();///重置时间
}
function changNav(nav){//该函数是切换样式用的
navArr.removeClass("ui-feedback");//首先将所有的图片区域样式清除
navArr.eq(nav).addClass("ui-feedback");//再给当前的图片区域加个样式
}
}
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流