js实现3D旋转相册


Posted in Javascript onAugust 02, 2020

本文实例为大家分享了js实现3D旋转相册的具体代码,供大家参考,具体内容如下

效果展示:

js实现3D旋转相册

使用图片:

js实现3D旋转相册js实现3D旋转相册

剩余自己随意 图片大小为133*200

代码展示:

<!DOCTYPE html>
<!--设置图片的拖拽事件 不可用-->
<html lang="en" ondragstart="return false">
<head>
 <meta charset="UTF-8">
 <title>3D效果</title>
 <style>
  * {
   background-color: #000;
 
  }
 
  .container {
   border: 1px solid yellow;
   perspective: 800px;
   overflow: hidden;
  }
 
  .box {
   position: relative;
   border: 1px solid #f00;
   width: 133px;
   height: 200px;
   margin: 300px auto;
   transform-style: preserve-3d;
   transform:rotateX(-20deg) rotateY(0deg);
  }
 
  img {
   position: absolute;
   /*设置图片倒影效果*/
   -webkit-box-reflect:below 5px -webkit-gradient(linear,left top, left bottom,from( transparent),color-stop(40%,transparent),to(rgba(250,250,250,0.4)));
  }
 
 </style>
</head>
<body>
<div class="container">
 <div class="box">
  <img src="img/1.jpg" alt="">
  <img src="img/2.jpg" alt="">
  <img src="img/3.jpg" alt="">
  <img src="img/4.jpg" alt="">
  <img src="img/5.jpg" alt="">
  <img src="img/6.jpg" alt="">
  <img src="img/7.jpg" alt="">
  <img src="img/8.jpg" alt="">
  <img src="img/9.jpg" alt="">
  <img src="img/10.jpg" alt="">
  <img src="img/11.jpg" alt="">
 </div>
</div>
 
<script>
 // a 获取所有 img 元素
  var mimg = document.querySelectorAll("img");
  var mlength = mimg.length;
 // 动态获取 图片的旋转角度
 var mdeg = 360/mlength;
 
 //获取box 容器
 var mbox = document.querySelector(".box");
 
 
 /*页面加载后执行。。效果*/
  window.onload= function () {
   // 1 图片旋转动画
   for(var i = 0;i<mlength;i++){
    // console.log(mimg);
    //每张图片 1 60 2 120 3 180 4 240  60为图片的平分角
    mimg[i].style.transform = "rotateY("+(mdeg*i)+"deg) translateZ(350px)";
   // 添加过渡效果  动画执行多长时间 多久后开始执行动画 此时的效果 从最后一张开始动画
   //  console.log(mlength-i);
    mimg[i].style.transition = "1s "+(mlength-i)*0.1+"s"; //  0.1 动画调节
    //从第一张开始动画
    // mimg[i].style.transition = "1s "+i+"s";
   }
 
 
  // 获取鼠标点的位置 获取 差值 改变 转换的rotate: x y
   var newX,newY,lastX,lastY,cvalueX,cvalueY, rotX=-20,rotY=0;
  // 鼠标滑动后改变效果 (使用鼠标 按下 替换点击事件)
   document.onmousedown = function (e) {
   // 鼠标点击
   //  console.log("点击");
    lastX = e.clientX;
    lastY = e.clientY;
   // 鼠标移动
    this.onmousemove = function (e) {
     // console.log("移动");
    newX = e.clientX;
    newY = e.clientY;
     console.log(newX +" "+newY);
 
     //获取移动的差值
     cvalueX = newX-lastX;
     cvalueY = newY-lastY;
 
     //获取旋转的角度
     rotX -= cvalueY; /*因为要向前运动所以是负值*/
     rotY += cvalueX;
 
    // 将角度添加上 img容器
     mbox.style.transform = "rotateX("+rotX*0.1+"deg) rotateY("+rotY*0.1+"deg)"
    // 差值太大(转动太快) 调节每次的差值是和上一次差 而不是之前差(初始值的差)
     lastX = newX;
     lastY = newY;
 
    }
   // 鼠标抬起
    this.onmouseup = function () {
     // console.log("抬起");
    // 要停止移动的方法
     this.onmousemove = null;
    }
 
   }
  }
 
</script>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript while语句和do while语句的区别分析
Dec 08 Javascript
jquery中ajax学习笔记4
Oct 16 Javascript
jQuery实现的Tab滑动选项卡及图片切换(多种效果)小结
Sep 14 Javascript
jQuery实现元素拖拽并cookie保存顺序的方法
Feb 20 Javascript
下雪了 javascript实现雪花飞舞
Aug 02 Javascript
javascript事件模型介绍
May 31 Javascript
Angular中使用$watch监听object属性值的变化(详解)
Apr 24 Javascript
jquery.uploadifive插件怎么解决上传限制图片或文件大小问题
May 08 jQuery
Angularjs在360兼容模式下取数据缓存问题的解决办法
Jun 22 Javascript
总结js中的一些兼容性易错的问题
Dec 18 Javascript
微信小程序图表插件wx-charts用法实例详解
May 20 Javascript
vscode中使用npm安装babel的方法
Aug 02 Javascript
js实现双色球效果
Aug 02 #Javascript
js实现tab栏切换效果
Aug 02 #Javascript
原生js canvas实现鼠标跟随效果
Aug 02 #Javascript
原生js+canvas实现下雪效果
Aug 02 #Javascript
jQuery实现滑动开关效果
Aug 02 #jQuery
jQuery实现开关灯效果
Aug 02 #jQuery
JavaScript实现动态生成表格
Aug 02 #Javascript
You might like
PHP网站备份程序代码分享
2011/06/10 PHP
PHP静态文件生成类实例
2014/11/29 PHP
jQuery中的常用事件总结
2009/12/27 Javascript
JQuery UI DatePicker中z-index默认为1的解决办法
2010/09/28 Javascript
Jquery UI震动效果实现原理及步骤
2013/02/04 Javascript
浅谈jQuery中的事件
2015/03/23 Javascript
浅谈利用JavaScript进行的DDoS攻击原理与防御
2015/06/04 Javascript
底部悬浮通栏可以关闭广告位的实现方法
2016/06/01 Javascript
js实现碰撞检测特效代码分享
2016/10/16 Javascript
详解MVC如何使用开源分页插件(shenniu.pager.js)
2016/12/16 Javascript
微信小程序 商城开发(ecshop )简单实例
2017/04/07 Javascript
jQuery查找dom的几种方法效率详解
2017/05/17 jQuery
Node.js学习之TCP/IP数据通讯(实例讲解)
2017/10/11 Javascript
nodejs 使用nodejs-websocket模块实现点对点实时通讯
2018/11/28 NodeJs
vue.js引入外部CSS样式和外部JS文件的方法
2019/01/06 Javascript
微信小程序全局变量功能与用法详解
2019/01/22 Javascript
React实现todolist功能
2020/12/28 Javascript
从源码角度来回答keep-alive组件的缓存原理
2021/01/18 Javascript
python2.7 mayavi 安装图文教程(推荐)
2017/06/22 Python
详解Python文本操作相关模块
2017/06/22 Python
详解Python里使用正则表达式的ASCII模式
2017/11/02 Python
Python 加密与解密小结
2018/12/06 Python
Python3实现监控新型冠状病毒肺炎疫情的示例代码
2020/02/13 Python
keras实现多GPU或指定GPU的使用介绍
2020/06/17 Python
使用css实现android系统的loading加载动画
2019/07/25 HTML / CSS
精油和天然健康美容产品:Art Naturals
2018/01/27 全球购物
判断单链表中是否存在环
2012/07/16 面试题
介绍一下gcc特性
2012/01/20 面试题
vue路由实现登录拦截
2021/03/24 Vue.js
如何编写优秀的食品项目创业计划书
2014/01/23 职场文书
六查六看自查材料
2014/02/17 职场文书
简历里的自我评价范文
2014/02/24 职场文书
企业环保标语
2014/06/10 职场文书
优秀中职教师事迹材料
2014/08/26 职场文书
学生上课说话检讨书
2014/10/25 职场文书
golang在GRPC中设置client的超时时间
2021/04/27 Golang