透過原生JS,點擊事件,滑鼠按下、滑鼠抬起和滑鼠移動事件,實現3d立方體的拖曳旋轉,並將旋轉角度即時的反應至介面上顯示。
實現原理:透過取得滑鼠點擊螢幕時的座標和滑鼠移動時的座標,來獲得滑鼠在X軸、Y軸移動的距離,將距離即時賦值給transform屬性
從而透過改變transform:rotate屬性值來達到3d立方體旋轉的效果
HTML程式碼區塊:
<body> <input type="button" class="open" value="点击散开"/> <input type="text" class="xNum" value=""/>//X轴旋转角度 <input type="text" class="yNum" value=""/>//Y轴旋转角度 <input type="text" class="zNum"/> <div class="big_box"> <div class="box"> <span></span> <span></span> <span></span> <span></span> <span></span> <span></span> </div> </div> </body>
CSS程式碼區塊:
<style> body{cursor: url("img/openhand1.png"),auto;} .big_box{ width: 500px; height: 500px; margin: 200px auto; } .box{ -webkit-transform-style: preserve-3d; -moz-transform-style: preserve-3d; -ms-transform-style: preserve-3d; transform-style: preserve-3d; transform-origin:100px 100px 00px; position: relative; transform: rotatex(0deg) rotatey(0deg) rotatez(0deg)scale3d(0.7,0.7,0.7); } .box span{ transition: all 1s linear; } span{ display: block; position: absolute; width: 200px; height: 200px; box-sizing: border-box; border:1px solid #999; /*opacity: 0.7;*/ text-align: center; line-height: 200px; font-size: 60px; font-weight: 700; border-radius: 12%; } .box span:nth-child(1){ background-color: deepskyblue; transform-origin: left; transform: rotatey(-90deg) translatex(-100px);//左 } .box span:nth-child(2){ background-color: red; transform-origin: right; transform: rotatey(90deg) translatex(100px) ;//右 } .box span:nth-child(3){ background-color: green; transform-origin: top; transform: rotatex(90deg) translatey(-100px) ;//上 } .box span:nth-child(4){ background-color: #6633FF; transform-origin: bottom; transform: rotatex(-90deg) translatey(100px);//下 } .box span:nth-child(5){ background-color: gold; transform: translatez(-100px);//后 } .box span:nth-child(6){ background-color: #122b40; transform: translatez(100px);//前 } .box:hover span{ opacity: 0.3; } .box:hover{ animation-play-state:paused;//设置动画暂停 } </style>
JS程式碼區塊:
<script> move(); clickBox(); //鼠标按下且移动时触发, function move(){ var body = document.querySelector("body"); var box = document.querySelector(".box"); var xNum =document.querySelector(".xNum"); var yNum =document.querySelector(".yNum"); var x = 0,y = 0,z = 0; var xx = 0,yy = 0; var xArr = [],yArr = []; window.onmousedown = function (e) {//鼠标按下事件 body.style.cursor = 'url("img/closedhand1.png"),auto'; xArr[0] = e.clientX/2;//获取鼠标点击屏幕时的坐标 yArr[0] = e.clientY/2; window.onmousemove = function (e) {//鼠标移动事件————当鼠标按下且移动时触发 xArr[1] = e.clientX/2;//获取鼠标移动时第一个点的坐标 yArr[1] = e.clientY/2; yy += xArr[1] - xArr[0];//获得鼠标移动的距离 xx += yArr[1] - yArr[0]; xNum.value = xx+"°";//将所获得距离数字赋值给input显示旋转角度 yNum.value = yy+"°"; //将旋转角度写入transform中 box.style.transform = "rotatex("+xx+"deg) rotatey("+yy+"deg) rotatez(0deg)scale3d(0.7,0.7,0.7)"; xArr[0] = e.clientX/2; yArr[0] = e.clientY/2; } }; window.onmouseup = function () {//鼠标抬起事件————用于清除鼠标移动事件, body.style.cursor = 'url("img/openhand1.png"),auto'; window.onmousemove = null; } } //点击事件、负责立方体盒子的六面伸展 function clickBox(){ var btn = document.querySelector(".open"); var box = document.querySelector(".box"); var son = box.children; var value = 0; //存储立方体散开时的transform参数 var arr0 = ["rotatey(-90deg) translatex(-100px)","rotatey(90deg) translatex(100px)","rotatex(90deg) translatey(-100px)",<br>"rotatex(-90deg) translatey(100px)","translatez(-100px)","translatez(100px)"]; //存储立方体合并时的transform参数 var arr1 = ["rotatey(-90deg) translatex(-100px)translatez(100px)","rotatey(90deg) translatex(100px)translatez(100px)",<br>"rotatex(90deg) translatey(-100px)translatez(100px)","rotatex(-90deg) translatey(100px)translatez(100px)","translatez(-200px)","translatez(200px)"]; btn.onclick = function(){ if(value == 0){ value = 1; btn.value = "点击合并"; for(var i=0;i<arr1.length;i++){ son[i].style.transform = arr1[i]; console.log(son[i]) } }else if(value == 1){ value = 0; btn.value = "点击散开"; for(var j=0;j<arr0.length;j++){ son[j].style.transform = arr0[j]; console.log(j); } } }; } </script>
以上所述是小編給大家介紹的基於css3 js實現滑鼠拖曳3d立方體旋轉 的相關知識,希望對大家有幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對PHP中文網的支持!
更多基於css3新屬性transform及原生js實作滑鼠拖曳3d立方體旋轉相關文章請關注PHP中文網!

文章討論了CSS FlexBox,這是一種佈局方法,用於有效地對齊和分佈響應設計中的空間。它說明了FlexBox用法,將其與CSS網格進行了比較,並詳細瀏覽了瀏覽器支持。

本文討論了使用CSS創建響應網站的技術,包括視口元標籤,靈活的網格,流體媒體,媒體查詢和相對單元。它還涵蓋了使用CSS網格和Flexbox一起使用,並推薦CSS框架

本文討論了CSS盒裝屬性,該屬性控制了元素維度的計算方式。它解釋了諸如Content-Box,Border-Box和Padding-Box之類的值,以及它們對佈局設計和形式對齊的影響。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

WebStorm Mac版
好用的JavaScript開發工具

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

禪工作室 13.0.1
強大的PHP整合開發環境