• 明天我们家宝宝满月了
  • 一晚上忙了好几个小时,终于把支付前台通知解决了
  • 原计划要增加另外一种支付方案,现在可能要被搁置了
  • 今天上午刚刚注册了华为云,然后刚刚华为云的客服小姐姐就来电话了,小姐姐声音挺好听的
  • 今天无意中注册了华为云,然后发现跟阿里云基本一个模样,甚至连价格都一样
  • 继续测试一下
  • 发现一个问题就是,微信语音发送说说的时候,不要拦截没有UA的数据请求
  • 测试一下连接
  • 终于下雪了
  • 有赞的支付暂时用不了了,所以重新开发另一个支付插件

纯JS实现旋转木马图片展示效果

网络技术 云落 4年前 (2015-06-13) 560次浏览 已收录 7个评论
文章目录[隐藏]

纯粹原生JavaScript实现类似旋转木马的图片展示效果

spruce-image(3)_看图王

JS代码

 <meta content="text/html; charset=utf-8" http-equiv="Content-Type" />
<style type="text/css">
#show{position:relative;margin:20px auto;width:800px;}
.item{position:absolute;height:40px;width:60px;background:#999999;border:1px solid #eeeeee;cursor:pointer;}</style>
<script>
var len;
var showerObj;
var listObj;
var showerWidth=800;
var showerHeight=400;
var r;
var cR=0;
var ccR=0;
var timer=0;
window.onload=function(){
	showerObj=document.getElementById("show");
	listObj=showerObj.getElementsByTagName("div");
	len=listObj.length;
	r=Math.PI/180*360/len;
	for(var i=0;i<len;i++){
		var item=listObj[i];
		item.style.top=showerHeight/2+Math.sin(r*i)*showerWidth/2-20+"px";
		item.style.left=showerWidth/2+Math.cos(r*i)*showerWidth/2-30+"px";
		item.rotate=(r*i+2*Math.PI)%(2*Math.PI);
		item.onclick=function(){
			cR=Math.PI/2-this.rotate;
			timer || (timer=setInterval(rotate,10));
			
		}
	
	}
	var rX=showerObj.offsetLeft+showerWidth/2;
	var ry=showerObj.offsetTop+showerHeight/2;
	
	var rotate=function(){
		ccR=(ccR+2*Math.PI)%(2*Math.PI);
		if(cR-ccR<0) cR=cR+2*Math.PI;
		if(cR-ccR<Math.PI){
			ccR=ccR+(cR-ccR)/19;
		}else{
			ccR=ccR-(2*Math.PI+ccR-cR)/19;
		
		}
		
		if(Math.abs((cR+2*Math.PI)%(2*Math.PI)-(ccR+2*Math.PI)%(2*Math.PI))<Math.PI/720){
			ccR=cR;
			clearInterval(timer);
			timer=0;
		}
		
		for(var i=0;i<len;i++){
			var item=listObj[i];
			var w,h;
			var sinR=Math.sin(r*i+ccR);
			var cosR=Math.cos(r*i+ccR);
			w=60+0.6*60*sinR;
			h=(40+0.6*40*sinR);
			item.style.cssText +=";width:"+w+"px;height:"+h+"px;top:"+parseInt(showerHeight/2+sinR*showerWidth/2/3-w/2)+"px;left:"+parseInt(showerWidth/2+cosR*showerWidth/2-h/2)+"px;z-index:"+parseInt(showerHeight/2+sinR*showerWidth/2/3-w/2)+";";
	
		}
	}
	
	document.getElementById("l").onclick=function(){
		cR=(cR+r+2*Math.PI)%(2*Math.PI);
		timer || (timer=setInterval(rotate,10));
	}
	document.getElementById("r").onclick=function(){
		cR=(cR-r+2*Math.PI)%(2*Math.PI);
		timer || (timer=setInterval(rotate,10));
	}
	rotate();
}
</script><input id="l" type="button" value="left" /> <input id="r" type="button" value="right" />
<div id="show">
<div class="item">1</div>
<div class="item">2</div>
<div class="item">3</div>
<div class="item">4</div>
<div class="item">5</div>
<div class="item">6</div>
<div class="item">7</div>
<div class="item">8</div>
<div class="item">9</div>
<div class="item">0</div>
<div class="item">a</div>
<div class="item">b</div>
<div class="item">1</div>
<div class="item">2</div>
<div class="item">3</div>
</div>

代码演示

代码演示
-- 完 --
weinxin
扫码订阅,第一时间获得更新
微信扫码二维码,订阅我们网站的动态,另外不定时发送WordPress小技巧,你可以随时退订,欢迎订阅哦~

乐趣公园 , 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:纯JS实现旋转木马图片展示效果
喜欢 (32)
云落
关于作者:
无折腾,不生活,我是一个WordPress菜鸟,一个玩淘宝的卖家,欢迎你认识我,我是云落!
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址