摘自《新兴网络》
<html>
<head>
<title>JS 实现3D立体效果的图片幻灯切换</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<style>
html {background:#000}
body, ul {margin:0;padding:0}
li {list-style:none}
img {border:none;display:block}
.slide-wp {
width: 500px;
height: 300px;
overflow: hidden;
position: absolute;
left: 50%;
top: 50%;
margin-left: -250px;
margin-top: -150px;
}
.nav-wp {
position: absolute;
background: #ccc;
top: 50%;
margin-top: 170px;
left: 50%;
margin-left: -100px;
border-radius: 4px;
-moz-border-radius: 4px;
-webkit-border-radius: 4px;
padding: 0 20px 6px 10px;
_padding: 0 20px 2px 10px;
}
.nav li {
float: left;
margin-left: 10px;
font-size: 20px;
font-weight: bold;
font-family: tahoma;
color: #22739e;
cursor: pointer;
height: 22px;
}
.nav li.cur{color: #ff7a00}
.next {
position:absolute;
top: 0;
left: 160px;
padding: 4px 8px;
color: #ff7a00;
background: #ccc;
height: 20px;
border-radius: 4px;
-moz-border-radius: 4px;
-webkit-border-radius: 4px;
cursor: pointer;
}
</style>
</head>
<body>
<h2 style="color:#fff">对于使用IE6的同学看到的斑点,我只能表示很无奈。。。</h2>
<div id="slider" class="slide-wp">
<ul>
<li><a href="http://www.newxing.com/" target="_blank"><img src="http://www.newxing.com/img/450/1.jpg" alt="" /></a></li>
<li><a href="http://www.newxing.com/" target="_blank"><img src="http://www.newxing.com/img/450/2.jpg" alt="" /></a></li>
<li><a href="http://www.newxing.com/" target="_blank"><img src="http://www.newxing.com/img/450/3.jpg" alt="" /></a></li>
<li><a href="http://www.newxing.com/" target="_blank"><img src="http://www.newxing.com/img/450/4.jpg" alt="" /></a></li>
<li><a href="http://www.newxing.com/" target="_blank"><img src="http://www.newxing.com/img/450/5.jpg" alt="" /></a></li>
</ul>
</div>
<div class="nav-wp">
<ul id="nav" class="nav">
<li onclick="mySlider.pos(0)">●</li>
<li onclick="mySlider.pos(1)">●</li>
<li onclick="mySlider.pos(2)">●</li>
<li onclick="mySlider.pos(3)">●</li>
<li onclick="mySlider.pos(4)">●</li>
</ul>
<a class="next" onclick="mySlider.move()">next</a>
</div>
<script type="text/javascript">
var HR = {
$ : function(i) {return document.getElementById(i)},
$$ : function(c, p) {return p.getElementsByTagName(c)},
ce : function(i, t) {
var o = document.createElement(i);
t.appendChild(o);
return o;
}
};
HR.slider3D = function () {
var init = function (o) {
this.o = o;
var wp = HR.$(o.id), ul = HR.$$('ul', wp)[0], li = this.li = HR.$$('li', ul);
this.l = li.length;
this.w = wp.offsetWidth;
this.h = wp.offsetHeight;
this.at = o.auto? o.auto : 4;
var con = this.con = HR.ce('div', wp);
con.style.cssText = 'position:absolute;left:0;top:0;width:'+this.w+'px;height:'+this.h+'px';
ul.style['display'] = 'none';
this.a1 = HR.ce('a', con);
this.a1.style.cssText = 'position:absolute;left:0;top:0;overflow:hidden';
this.a2 = HR.ce('a', con);
this.a2.style.cssText = 'position:absolute;top:0;right:0;overflow:hidden';
this.a1.innerHTML = this.a2.innerHTML = '<img alt="" />';
this.img = HR.$$('img', ul);
this.s = o.maskSize ? o.maskSize : 5;
this.mask11 = HR.ce('span', this.a1);
this.mask12 = HR.ce('span', this.a1);
this.mask21 = HR.ce('span', this.a2);
this.mask22 = HR.ce('span', this.a2);
this.pos(0);
}
init.prototype = {
pos : function (i) {
clearInterval(this.li[i].a); clearInterval(this.au); this.au = 0; this.cur = i;
var navli = HR.$$('li', HR.$(this.o.navId));
for (var j=0; j<navli.length; j++) {
navli[j].className = i == j ? 'cur' : '';
}
var img1 = HR.$$('img', this.a1)[0], img2 = HR.$$('img', this.a2)[0], _this = this;
img1.src = i==0 ? this.img[this.l-1].src : this.img[i-1].src;
img1.width = this.w;
img2.src = this.img[i].src;
img2.width = 0;
img1.height = img2.height = this.h;
this.mask11.style.cssText = 'position:absolute;left:0;top:0;font-size:0;overflow:hidden;width:0;height:0;border-color:black transparent transparent black;border-style:solid dashed dashed solid;border-width:0 '+this.w/2+'px';
this.mask12.style.cssText = 'position:absolute;left:0;bottom:0;font-size:0;overflow:hidden;width:0;height:0;border-color:transparent transparent black black;border-style:dashed dashed solid solid;border-width:0 '+this.w/2+'px';
this.mask21.style.cssText = 'position:absolute;right:0;top:0;font-size:0;overflow:hidden;width:0;height:0;border-color:black black transparent transparent;border-style:solid solid dashed dashed;border-width:0px';
this.mask22.style.cssText = 'position:absolute;right:0;bottom:0;font-size:0;overflow:hidden;width:0;height:0;border-color:transparent black black transparent;border-style:dashed solid solid dashed;border-width:0px';
this.li[i].a = setInterval(function(){_this.anim(i)}, 20);
},
anim : function (i) {
var w1 = HR.$$('img', this.a1)[0].width, w2 = HR.$$('img', this.a2)[0].width;
if (w2 == this.w) {
clearInterval(this.li[i].a);
HR.$$('img', this.a1)[0].width = 0;
HR.$$('img', this.a2)[0].width = this.w;
this.mask11.style.borderLeftWidth = this.mask11.style.borderRightWidth = this.mask12.style.borderLeftWidth = this.mask12.style.borderRightWidth = '0px';
this.mask11.style.borderTopWidth = this.mask11.style.borderBottomWidth = this.mask12.style.borderTopWidth = this.mask12.style.borderBottomWidth = this.h/this.s + 'px';
this.mask21.style.borderLeftWidth = this.mask21.style.borderRightWidth = this.mask22.style.borderLeftWidth = this.mask22.style.borderRightWidth = this.w/2 + 'px';
this.mask21.style.borderTopWidth = this.mask21.style.borderBottomWidth = this.mask22.style.borderTopWidth = this.mask22.style.borderBottomWidth = '0px';
}else {
HR.$$('img', this.a1)[0].width -= Math.ceil((this.w-w2)*.13);
HR.$$('img', this.a2)[0].width += Math.ceil((this.w-w2)*.13);
this.mask11.style.borderLeftWidth = this.mask11.style.borderRightWidth = this.mask12.style.borderLeftWidth = this.mask12.style.borderRightWidth = HR.$$('img', this.a1)[0].width/2 + 'px';
this.mask11.style.borderTopWidth = this.mask11.style.borderBottomWidth = this.mask12.style.borderTopWidth = this.mask12.style.borderBottomWidth = HR.$$('img', this.a2)[0].width*this.h/(this.s*this.w) + 'px';
this.mask21.style.borderLeftWidth = this.mask21.style.borderRightWidth = this.mask22.style.borderLeftWidth = this.mask22.style.borderRightWidth = HR.$$('img', this.a2)[0].width/2 + 'px';
this.mask21.style.borderTopWidth = this.mask21.style.borderBottomWidth = this.mask22.style.borderTopWidth = this.mask22.style.borderBottomWidth = this.h/this.s - HR.$$('img', this.a2)[0].width*this.h/(this.s*this.w) + 'px';
if (!this.au) this.auto();
}
},
auto : function () {
var _this = this;
this.au = setInterval(function(){_this.move()}, this.at*1000);
},
move : function () {
var n = this.cur==this.l-1 ? 0 : this.cur+1;
this.pos(n);
}
}
return init;
}();
var mySlider = new HR.slider3D({
id: 'slider',
maskSize: 6,
navId: 'nav',
auto: 4
})</SCRIPT></body>
</html>
效果图如下:
- 大小: 124.6 KB
分享到:
相关推荐
立体图片幻灯切换效果代码(html代码,javascript).pdf
3D立体手机触屏图片切换代码是一款基于jquery.gallery.js插件实现的手机触屏幻灯片切换特效。
此Jquery插件实现了3D旋转图片立体展示幻灯片插件,功能非常酷。有兴趣的同学可以试着做一下。 包括了以下功能: 1、可支持鼠标滚轮控制图片360度旋转 2、鼠标支持左右方向控制按钮来控制图片旋转的方向 3、...
js图片3d切换、图片立体切换、图片左右变换、图片展示、图片平面展示切换、图片平面切换
js css3图片切换立体旋转代码是一款3D旋转的图片轮播特效。
3D立体手机触屏图片切换代码是一款基于jquery gallery js插件实现的手机触屏幻灯片切换特效。
51:___有点炫的JavaScript立体图片展示 52:___根据鼠标放上切换内容制作的图片导航 53:___浮动的图片广告 54:___清爽简洁的图片交替导航效果 55:___用CSS实现图片的双边框效果 56:___禁止在图片上使用右键 57:___竖...
一款用JavaScript模仿3D立体切换效果的js焦点幻灯片特效,使用方法很简单:用鼠标拖拽图片向左右方向就好~
27. jQuery实现图片3D立体感的前后轮番展示特效 28. jQuery实现图片取景器仿相机拍照功能的插件photoShoot 29. jQuery实现图片变色特效插件与实例下载如jquery图片变灰色 30. jquery实现图片可拖动展示的实例...
html5带立体感觉幻灯片是一款jquery html5实现的带立体效果幻灯片左右切换代码。
这是一款基于javascript实现支持键盘控制的左右切换立体式图片轮播效果,特别有立体感,最重要的一点是可以利用键盘进行控制。 特性介绍: 1.轻松的改变幻灯变的宽度。 2.轻易改变下一张展示图片的数量。 3....
js+css3图片切换立体旋转代码是一款3D旋转的图片轮播特效。
一款用JavaScript模仿3D立体切换效果的js焦点幻灯片特效,能自动播放幻灯图或手动控制,幻灯图尺寸500×300像素。可以自定义幻灯数量和链接网址。
圆形幻灯片切换是一款基于jquery实现的3D圆形立体旋转木马。
一款用JavaScript模仿3D立体切换效果的js焦点幻灯片特效,能自动播放幻灯图或手动控制,幻灯图尺寸500×300像素。可以自定义幻灯数量和链接网址。
27. jQuery实现图片3D立体感的前后轮番展示特效 28. jQuery实现图片取景器仿相机拍照功能的插件photoShoot 29. jQuery实现图片变色特效插件与实例下载如jquery图片变灰色 30. jquery实现图片可拖动展示的实例下载...
27. jQuery实现图片3D立体感的前后轮番展示特效 28. jQuery实现图片取景器仿相机拍照功能的插件photoShoot 29. jQuery实现图片变色特效插件与实例下载如jquery图片变灰色 30. jquery实现图片可拖动展示的实例下载...
HTML5 3D折页立体焦点图代码是一款基于jQuery HTML5实现的3D立体图片切换特效。
jQuery手机3D展示特效是一款手机默认平铺倾斜显示,鼠标点击图片手机3D立体带描述显示,支持自动延迟切换幻灯片。