js實(shí)現(xiàn)3D旋轉(zhuǎn)效果
本文實(shí)例為大家分享了js實(shí)現(xiàn)3D旋轉(zhuǎn)效果的具體代碼,供大家參考,具體內(nèi)容如下
實(shí)現(xiàn)效果:

實(shí)現(xiàn)過程:
步驟一:先寫一個(gè)簡單的html結(jié)構(gòu),創(chuàng)建一個(gè)box盒子,里面放對應(yīng)的圖片(也可以用js創(chuàng)建圖片,這里為了好理解,我們直接用html創(chuàng)建).
<body><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=""> <img src="./img/12.jpg" alt=""> </div>
步驟二:給盒子和圖片,設(shè)置對應(yīng)的樣式
<style>
*{
margin: 0;
padding: 0;
}
body {
background-color: #000;
/*overflow: hidden;*/
}
#box{
width:133px;
height: 200px;
margin: 200px auto;
position:relative;
border: 1px solid #fff;
transform-style: preserve-3d;
/*2.transform–style屬性指定嵌套元素是在三維空間中呈現(xiàn)。(使用此屬性必須先使用transform 屬性)*/
/*perspective:800px;*/
/*3.設(shè)置透視距離*/
transform:perspective(800px) rotateX(-15deg) rotateY(0deg) ; deg);
}
#box img{
position: absolute;
top:0;
left: 0;
width: 100%;
height: 100%;
border-radius: 3px;
box-shadow: 0px 0px 5px #fff;
/*4.設(shè)置圖片陰影*/
/*-webkit-box-reflect: below 15px -webkit-linear-gradient(top,rgba(0,0,0,0) 40%,rgba(0,0,0,.5) 100%);*/
/*-webkit-box-reflect:below 8px -webkit-linear-gradient(top,rgba(0,0,0,0)40%,rgba(0,0,0,.5)100%);*/
-webkit-box-reflect:below 10px -webkit-linear-gradient(transparent,transparent 50%,rgba(0,0,0,.6));
/*5.設(shè)置圖片倒影:直接記住吧(3個(gè)值。1. direction 定義方向,取值包括 above 、 below 、 left 、 right。);2. offset定義反射偏移的距離;3.mask-box-image定義遮罩圖像,該圖像將覆蓋投影區(qū)域。如果省略該參數(shù)值,則默認(rèn)為無遮罩圖像。*/
}
</style>
第三步: js
<script>
// //js動(dòng)態(tài)添加11個(gè)img標(biāo)簽
// //創(chuàng)建11個(gè)img標(biāo)簽的辦法
// var box=document.getElementById('box');
// for(var i=1;i<=11;i++){//有多少張圖就循環(huán)多少次
// var imgs= document.createElement('img');
// imgs.setAttribute("src", "img/"+i+".jpg");
// box.appendChild(imgs);}
//當(dāng)頁面加載完畢后再執(zhí)行代碼
window.onload=function ( ) {
//1.獲取元素
var oWrap=document.getElementById('box');
var oImg=oWrap.children;
// var oImgLen=oImg.length;
var deg=360/oImg.length;//3.每個(gè)需要旋轉(zhuǎn)的度數(shù)
// 定義一個(gè)開始的度數(shù)
var roX=-10;
var roY=0;
var x,y,x_,y_,xN,yN,time=null;
//2.遍歷所有的img標(biāo)簽
for(var i=0;i<oImg.length;i++){
// oImg[i].style.cssText='transform:rotateY('+i*deg+'deg ) translateZ(350px);transition:1s'+ (oImgLen-i)*0.1 +'s;';
oImg[i].style.transform = 'rotateY('+ i*deg + 'deg) translateZ(350px)';
oImg[i].style.transition ='all 1s '+ (oImg.length-i-1)*0.1 +'s';
//transition:設(shè)置過渡
oImg[i].ondragstart=function ( ) {
return false;
}
}
//3.事件處理
document.onmousedown=function ( e ) {
clearInterval(time);
e=e||window.event;
x_=e.clientX;
y_=e.clientY;
// console.log ( "鼠標(biāo)按下了" )
this.onmousemove=function ( e ) {
e=e||window.event;
//獲取滾動(dòng)的X和Y軸
//client:鼠標(biāo)觸發(fā)點(diǎn)相對于頁面可視區(qū)域左上角距離
x=e.clientX;
y=e.clientY;
//兩點(diǎn)之間的差值:第一次走的時(shí)候兩值相等,第二次走的時(shí)候x已經(jīng)更新,但x_沒更新,所以兩個(gè)差值就是xN;
xN=x-x_;
yN=y-y_;
//差值拼接到旋轉(zhuǎn)的Y里面去
roY+=xN*0.2;//水平拖影響Y軸;
roX-=yN*0.2;
oWrap.style.transform='perspective(800px) rotateX('+roX+'deg) rotateY('+roY+'deg)';
// var oDiv =document.createElement('div');
// this.body.appendChild(oDiv);
// oDiv.style.cssText='width:5px;height:5px; background:red;position:absolute;left:'+x+"px;top:"+y+"px";
x_=e.clientX;
y_=e.clientY;
}
this.onmouseup=function ( ) {
// console.log ( "鼠標(biāo)抬起了" )
this.onmousemove= null;
//設(shè)置一個(gè)定時(shí)器,實(shí)現(xiàn)后面慣性效果8
time=setInterval(function ( ) {
//無限乘以零點(diǎn)95它會接近0的狀態(tài)
xN*=0.95;
yN*=0.95;
//當(dāng)它小到0.1時(shí)停止計(jì)時(shí)器
if(Math.abs(xN)<0.1 && Math.abs(yN)<0.1){//Math.abs()是返回絕對值
clearInterval(time);
}
//差值拼接到旋轉(zhuǎn)的Y里面去
roY+=xN*0.2;//水平拖影響Y軸;
roX-=yN*0.2;
oWrap.style.transform='perspective(800px) rotateX('+roX+'deg) rotateY('+roY+'deg)';
},30)
}
}
}
</script>
附件:完整版代碼
<!DOCTYPE html >
<html lang="en" onselectstart="return false;">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
*{
margin: 0;
padding: 0;
}
body {
background-color: #000;
}
#box{
width:133px;
height: 200px;
margin: 100px auto;
position:relative;
/* border: 1px solid #fff; 測試用到*/
transform-style: preserve-3d;
/*2.transform–style屬性指定嵌套元素是在三維空間中呈現(xiàn)。(使用此屬性必須先使用transform 屬性)*/
/*perspective:800px;*/
/*3.設(shè)置透視距離*/
transform:perspective(800px) rotateX(-15deg) rotateY(0deg) ; }
#box img{
position: absolute;
top:0;
left: 0;
width: 100%;
height: 100%;
border-radius: 3px;
box-shadow: 0px 0px 5px #fff;
/*4.設(shè)置圖片陰影*/
-webkit-box-reflect:below 10px -webkit-linear-gradient(transparent,transparent 50%,rgba(0,0,0,.6));
/*方法2-webkit-box-reflect:below 8px -webkit-linear-gradient(top,rgba(0,0,0,0)40%,rgba(0,0,0,.5)100%);*/
/*5.設(shè)置圖片倒影:直接記住吧(3個(gè)值。1. direction 定義方向,取值包括 above 、 below 、 left 、 right。);2. offset定義反射偏移的距離;3.mask-box-image定義遮罩圖像,該圖像將覆蓋投影區(qū)域。如果省略該參數(shù)值,則默認(rèn)為無遮罩圖像。*/
}
</style>
</head>
<body>
<div id="box">
<img src="./img/1.jpg" >
<img src="./img/2.jpg" >
<img src="./img/3.jpg" >
<img src="./img/4.jpg" >
<img src="./img/5.jpg" >
<img src="./img/6.jpg" >
<img src="./img/7.jpg" >
<img src="./img/8.jpg" >
<img src="./img/9.jpg" >
<img src="./img/10.jpg" >
<img src="./img/11.jpg" >
<img src="./img/12.jpg" >
</div>
<script>
// //js動(dòng)態(tài)添加11個(gè)img標(biāo)簽
// //創(chuàng)建11個(gè)img標(biāo)簽的辦法
// var box=document.getElementById('box');
// for(var i=1;i<=11;i++){//有多少張圖就循環(huán)多少次
// var imgs= document.createElement('img');
// imgs.setAttribute("src", "img/"+i+".jpg");
// box.appendChild(imgs);}
//當(dāng)頁面加載完畢后再執(zhí)行代碼
window.onload=function ( ) {
//1.獲取元素
var oWrap=document.getElementById('box');
var oImg=oWrap.children;
// var oImgLen=oImg.length;
var deg=360/oImg.length;//3.每個(gè)需要旋轉(zhuǎn)的度數(shù)
// 定義一個(gè)開始的度數(shù)
var roX=-10;
var roY=0;
var x,y,x_,y_,xN,yN,time=null;
//2.遍歷所有的img標(biāo)簽
for(var i=0;i<oImg.length;i++){
// oImg[i].style.cssText='transform:rotateY('+i*deg+'deg ) translateZ(350px);transition:1s'+ (oImgLen-i)*0.1 +'s;';
oImg[i].style.transform = 'rotateY('+ i*deg + 'deg) translateZ(350px)';
oImg[i].style.transition =' all 1s '+ (oImg.length-i-1)*0.1 +'s';
//transition:設(shè)置過渡
oImg[i].ondragstart=function ( ) {
return false;
}
}
//3.事件處理
document.onmousedown=function ( e ) {
clearInterval(time);
e=e||window.event;
x_=e.clientX;
y_=e.clientY;
// console.log ( "鼠標(biāo)按下了" )
this.onmousemove=function ( e ) {
e=e||window.event;
//獲取滾動(dòng)的X和Y軸
//client:鼠標(biāo)觸發(fā)點(diǎn)相對于頁面可視區(qū)域左上角距離
x=e.clientX;
y=e.clientY;
//兩點(diǎn)之間的差值:第一次走的時(shí)候兩值相等,第二次走的時(shí)候x已經(jīng)更新,但x_沒更新,所以兩個(gè)差值就是xN;
xN=x-x_;
yN=y-y_;
//差值拼接到旋轉(zhuǎn)的Y里面去
roY+=xN*0.2;//水平拖影響Y軸;
roX-=yN*0.2;
oWrap.style.transform='perspective(800px) rotateX('+roX+'deg) rotateY('+roY+'deg)';
// var oDiv =document.createElement('div');
// this.body.appendChild(oDiv);
// oDiv.style.cssText='width:5px;height:5px; background:red;position:absolute;left:'+x+"px;top:"+y+"px";這三行是測試用的
x_=e.clientX;
y_=e.clientY;
}
this.onmouseup=function ( ) {
// console.log ( "鼠標(biāo)抬起了" )
this.onmousemove= null;
//設(shè)置一個(gè)定時(shí)器,實(shí)現(xiàn)后面慣性效果8
time=setInterval(function ( ) {
//無限乘以零點(diǎn)95它會接近0的狀態(tài)
xN*=0.95;
yN*=0.95;
//當(dāng)它小到0.1時(shí)停止計(jì)時(shí)器
if(Math.abs(xN)<0.1 && Math.abs(yN)<0.1){//Math.abs()是返回絕對值
clearInterval(time);
}
//差值拼接到旋轉(zhuǎn)的Y里面去
roY+=xN*0.2;//水平拖影響Y軸;
roX-=yN*0.2;
oWrap.style.transform='perspective(800px) rotateX('+roX+'deg) rotateY('+roY+'deg)';
},30)
}
}
}
</script>
</body>
</html>
最后附上源碼地址
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- js實(shí)現(xiàn)圖片旋轉(zhuǎn)的三種方法
- JS實(shí)現(xiàn)全景圖效果360度旋轉(zhuǎn)
- 特漂亮的JS圖片排列旋轉(zhuǎn)效果代碼
- 純JS實(shí)現(xiàn)旋轉(zhuǎn)圖片3D展示效果
- JS實(shí)現(xiàn)圖片平面旋轉(zhuǎn)的方法
- three.js實(shí)現(xiàn)圍繞某物體旋轉(zhuǎn)
- JavaScript canvas實(shí)現(xiàn)圍繞旋轉(zhuǎn)動(dòng)畫
- JavaScript實(shí)現(xiàn)旋轉(zhuǎn)輪播圖
- js實(shí)現(xiàn)圖片旋轉(zhuǎn) js滾動(dòng)鼠標(biāo)中間對圖片放大縮小
- js CSS3實(shí)現(xiàn)卡牌旋轉(zhuǎn)切換效果
相關(guān)文章
php gethostbyname獲取域名ip地址函數(shù)詳解
php gethostbyname獲取域名ip地址函數(shù),需要根據(jù)域名得到ip地址的朋友有福了。2010-01-01
Webpack 4如何動(dòng)態(tài)切割JS注入文件名詳解
這篇文章主要給大家介紹了關(guān)于Webpack 4如何動(dòng)態(tài)切割JS注入文件名的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Webpack4具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07
微信小程序使用webview頁面轉(zhuǎn)pdf文件代碼示例
工作需求,將webview的內(nèi)容導(dǎo)出到pdf輸出,下面這篇文章主要給大家介紹了關(guān)于微信小程序使用webview頁面轉(zhuǎn)pdf文件的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-09-09
JS獲取iframe中marginHeight和marginWidth屬性的方法
這篇文章主要介紹了JS獲取iframe中marginHeight和marginWidth屬性的方法,涉及javascript操作iframe屬性的技巧,并分析了marginHeight和marginWidth屬性的功能,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04
用javascript實(shí)現(xiàn)截取字符串包含中文處理的函數(shù)
一直不知道js可以截取中文字符,呵呵,原理用正則表達(dá)式,匹配中文的長度,中文算兩個(gè),因?yàn)樗阋粋€(gè),是個(gè)好東西,推薦大家收藏2008-04-04
JavaScript實(shí)現(xiàn)基礎(chǔ)排序算法的示例詳解
這篇文章主要為大家詳細(xì)介紹了如何利用JavaScript實(shí)現(xiàn)基礎(chǔ)排序算法,如:冒泡排序、選擇排序、插入排序和快速排序,感興趣的可以了解一下2022-06-06
JavaScript iframe 實(shí)現(xiàn)多窗口通信實(shí)例詳解
這篇文章主要為大家介紹了JavaScript iframe 實(shí)現(xiàn)多窗口通信實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10

