非常酷炫漂亮的3D立体照片展示墙 纯JAVASCRIPT显示

简介: 分享下一个3d显示照片墙的纯JavaScript效果demo,效果很酷炫。可以通过鼠标上下左右拉动,从而把照片墙进行360°展示


今天主要给大家分享下一个3d显示照片墙的纯JavaScript效果demo,效果很酷炫。可以通过鼠标上下左右拉动,从而把照片墙进行360°展示。

鼠标停止后,在操作过程中,会发现,照片会以某角度轴,继续滑动一段距离。核心JavaScript代码见如下,下方链接有百度网盘分享链接,大家有兴趣可以down下来玩玩。先上图:

酷炫3d照片墙

酷炫3d照片墙

 

酷炫3d照片墙可3d移动展示

酷炫3d照片墙可3d移动展示


<script type="text/javascript">

   /*rotateX/rotateY/rotateZ可以帮助理解三维坐标,*/web前端中文站
   /*则translateZ则可以帮你理解透视位置(translateZ的功能就是让元素在自己的眼前或近或远)*/

   window.onload=function(){
     var oUl=document.getElementById("ul1");
     var aImg=document.getElementsByTagName("img");
     var aLi=oUl.getElementsByTagName("li");
     var deg=360/aLi.length;
     for(var i=0;i<aLi.length;i++){
       //每张图片缩放的时间
       aLi[i].style.transition='all 0.5s '+((aLi.length-1-i)*0.2)+'s'; 
       aLi[i].style.WebkitTransform='rotateY('+deg*i+'deg) translateZ(450px)';
       aLi[i].style.MozTransform='rotateY('+deg*i+'deg) translateZ(450px)';
     }
 
     //禁止拖动照片 www.lisa33xiaoq.net
     document.onselectstart=function(){
     return false;
   } 
   for(var i=0;i<aImg.length;i++){
   aImg[i].setAttribute("ondragstart", "return false")
   }
   var roY=0;
   var roX=-10;
   var xN=0;
   var yN=0;
   var timer=null;
   document.onmousedown=function(ev){
   var ev=ev||event;
   var disX_=ev.clientX;
   var disY_=ev.clientY;
 
   document.onmousemove=function(ev){
   var ev=ev||event;
   var disX=ev.clientX;
   var disY=ev.clientY;
 
   xN=disX-disX_;
   yN=disY-disY_;
 
   roY+=xN*0.1;
   roX-=yN*0.1;

   oUl.style.WebkitTransform='perspective(800px) rotateX('+roX+'deg) rotateY('+roY+'deg)';
   oUl.style.MozTransform='perspective(800px) rotateX('+roX+'deg) rotateY('+roY+'deg)';
 
   disX_=ev.clientX;
   disY_=ev.clientY;
   }
 
   //实现鼠标按着滑动后,松开鼠标,画面继续跟进 差值 进行滑动
   document.onmouseup=function(){
   document.onmousemove=null;

   timer=setInterval(function(){
   xN=xN*0.99;
   yN=yN*0.99;
   if(Math.abs(xN)<=0.5 && Math.abs(yN)<=0.5){ 
   //决定滑动的周期,如果乘以 1.0,则一直滑动下去不停止
   clearInterval(timer);
   }
   roY+=xN*0.5;
   roX-=yN*0.5; 

   oUl.style.WebkitTransform='perspective(800px) rotateX('+roX+'deg) rotateY('+roY+'deg)'; 
   //360 浏览器适用这个
   //oUl.style.MozTransform='perspective(800px) rotateX('+roX+'deg) rotateY('+roY+'deg)';
   },30)
 }
}
   //取消鼠标右键
   document.oncontextmenu=function(){
   return false;
   }
   document.onkeydown=function(ev){
   var ev=ev||event;
 
   if(ev.keyCode==123){
   return false
   }
  }
 }
</script> 

在线演示


原文链接:https://www.lisa33xiaoq.net/1190.html


目录
相关文章
|
3月前
|
JavaScript
js实现图片3D轮播效果(收藏)
js实现图片3D轮播效果(收藏)
26 0
|
7月前
|
JavaScript 前端开发 索引
用Three.js搞个炫酷3D地球
地球人怎么可以不会画地球!从canvas画地球贴图开始,用Three.js手把手教你实现一个炫酷的3D地球!
用Three.js搞个炫酷3D地球
|
8月前
|
JavaScript 前端开发 CDN
JavaScript 实现 3D 模型
JavaScript 实现 3D 模型
|
4月前
|
人工智能 JavaScript Linux
基于Three.js的3D自动纹理化开发包
DreamTexture.js 基于 Three.js 和稳定扩散(stable diffusion) AI 模型开发,用于实现 3D 模型的自动纹理化。
56 0
|
8月前
|
JavaScript 前端开发
探索3D魔力:与Three.js共舞的五大库和工具
探索3D魔力:与Three.js共舞的五大库和工具
94 0
|
8月前
|
JavaScript 前端开发 C++
用Three.js搞个3D金字塔
来来来,进来就看用Three.js搞个简单的3D金字塔!祝福大家都能成为金字塔顶端的大佬!嘛哩嘛哩哄!祈祷成功!
|
8月前
|
JavaScript 前端开发 API
用Three.js搞一个3D词云
2D词云经常用,是时候升级了,用一下3D词云!用Three.js搞一个3D词云!快快快!点进来瞅瞅!
|
8月前
|
JSON 数据格式
用Three.js搞个炫酷3D字体
三角形飞啊飞~飞啊飞~飞到一起,成了彩色字体!点击进来就看如何用three.js实现炫酷3D字体!!
用Three.js搞个炫酷3D字体
|
9月前
|
JavaScript 前端开发 API
码上开火车-Three.js 3D Web 游戏案例分享
码上开火车-Three.js 3D Web 游戏案例分享
227 0
|
9月前
|
存储 前端开发 定位技术
用Three.js搞个炫酷的3D区块地图
常用的3D区块地图除了那个区块,还要满足波纹散点、渐变柱体、飞线、下钻上卷、视角适配等,点开我,这就安排!用Three.js给你搞一个!
用Three.js搞个炫酷的3D区块地图