亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

JavaScript實現的3D旋轉魔方動畫效果實例代碼

2024-05-06 16:53:53
字體:
來源:轉載
供稿:網友

JS1K是JavaScript編程競賽——參加競賽的規則很簡單,腳本必須小于1K,競賽網站開始也只是為了娛樂,卻意外地收到了很多優秀的作品。

這是2016年JS1k上傳的作品,用幾十行代碼實現的一個3D旋轉魔方:

JavaScript,3D旋轉魔方,動畫效果

代碼如下:

function z(t, e) {  return t? e? t.appendChild(e) : "width:"+t+"px;height:"+t+"px;position:absolute;" : document.createElement("div")}function w() {  ++t==360&&(t=0, x=++x%3)  for (i in m) 2 == m[i][s[x]] ? m[i][u][a] = r+s[x]+"(" + t + "deg)" : 0;  c[u][a] = r+"3d(1,1,1," + t + "deg)", 	requestAnimationFrame(w)}var a = "transform",	p = "background-color:",	y = a+"-style:preserve-3d;",  u = "style",  v = "cssText",  B = z(),  c = z(),  t = x = 0,  d, e, f, g, h, k, l, m = [], n, i, r="rotate", s = ["X","Y","Z"];B[u][v] = "perspective:900px;"+z(600)+p+"#666";c[u][v] = y + z(240) +"top:30%;left:30%", z(B, c), z(window.b, B);for (l = 27; l--; z(c, f)) {  f = z(),   f[u][v] = y + z(240),   f.X = g = l % 3,   f.Y = h = (l - g) % 9 / 3,   f.Z = k = ~~(l / 9), e = z(),   e[u][v] = y + z(80) +a+":translate3d(" + 80 * g + "px," + 80 * h + "px," + 80 * (k-1) + "px)";  for (n = 6; n--; z(e, d))   	d = z(),   	d[u][v] = y + z(72) + "border-radius:9px;border:4px solid #000;opacity:0.9;"+a+":"+r+"X(" + (4 > n ? 90 * n : 0)  + "deg)"+r+"Y(" + (4 > n ? 0 : 4 == n ? -90 : 90) + "deg)translateZ(40px);"+p+   	(0==n&&2==k?"#05C":1==n&&0==h?"#FD0": 2==n&&0==k?"#0A6":3==n&&2==h?"#FFF":4==n&&0==g?"#F60":5==n&&2==g?"#C24":"#000");  z(f, e), m.push(f)}w();

知識點擴展

JS如何實現旋轉的魔方,瀏覽器從其他標簽頁回來依然勻速旋轉?

<!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8">  <meta name="viewport" content="width=device-width, initial-scale=1.0">  <meta http-equiv="X-UA-Compatible" content="ie=edge">  <title>Document</title></head><body>  <div class="cube" onclick="stop()">    <div class="front">front</div>    <div class="back">back</div>    <div class="left">left</div>    <div class="right">right</div>    <div class="top">top</div>    <div class="bottom">bottom</div>  </div></body><style>  .cube {    width: 400px;    height: 400px;    transition: all 3s;    margin: 300px auto;    /* 作用于所有3d轉換的子元素 設置給父級 */    /* perspective: 1000px; */    /* transform: rotateX(30deg) rotateY(45deg); */    /* 平面到立方 默認值:平面flat*/    transform-style: preserve-3d;    position: relative;  }  /* div:hover {    transform: rotateY(90deg) translateZ(-200px);    opacity: 0.5;  } */  .front,  .back,  .left,  .right,  .top,  .bottom {    width: 100%;    height: 100%;    text-align: center;    line-height: 400px;    position: absolute;    opacity: 0.9;    left: 0;    top: 0;  }  .front {    background-color: palevioletred;    background-image: url('http://img1.gtimg.com/tj/pics/hv1/117/208/2153/140051982.jpg');    transform: translateZ(200px);  }  .back {    background-color: yellow;    transform: translateZ(-200px);    background-image: url('https://ss1.bdstatic.com/70cFuXSh_Q1YnxGkpoWK1HF6hhy/it/u=841408372,3004217725&fm=11&gp=0.jpg');  }  .left {    background-color: pink;    background-image: url('https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=2388632836,3966607624&fm=26&gp=0.jpg');    transform: rotateY(90deg) translateZ(-200px)  }  .right {    background-color: yellowgreen;    background-image: url('https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=192610795,467565159&fm=26&gp=0.jpg');    transform: rotateY(90deg) translateZ(200px)  }  .top {    background-color: skyblue;    background-image: url("https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=2936477803,4198185787&fm=15&gp=0.jpg");    transform: rotateX(90deg) translateZ(200px)  }  .bottom {    background-color: orange;    background-image: url('http://img0.pclady.com.cn/pclady/1611/02/1612285_jyz.jpg');    transform: rotateX(90deg) translateZ(-200px)  }</style><script>  window.onload = function () {    let cube = document.querySelector('.cube')    let timer = null    let x = 0; y = 0;    function rotate() {      cube.style.transform = 'rotateX(' + x + 'deg)' + '' + 'rotateY(' + y + 'deg)';      x += 30      y += 45    }    function stop() {      clearInterval(timer)    }    clearInterval(timer);    timer = setInterval(() => {      rotate();    }, 1000);    // 監聽是否在當前頁,并置為已讀    // document.addEventListener("visibilitychange", function () {    //   if (document.hidden) {  //不處于當前頁面    //     // do something    //     clearInterval(timer)    //   } else {    //     timer;    //   }    // });    var hiddenProperty = 'hidden' in document ? 'hidden' :      'webkitHidden' in document ? 'webkitHidden' :        'mozHidden' in document ? 'mozHidden' :          null;    var visibilityChangeEvent = hiddenProperty.replace(/hidden/i, 'visibilitychange');    var onVisibilityChange = function () {      if (!document[hiddenProperty]) {        timer = setInterval(() => {          rotate();        }, 1000);        console.log(hiddenProperty);      } else {        clearInterval(timer)      }    }    document.addEventListener(visibilityChangeEvent, onVisibilityChange);    // document.addEventListener("visibilitychange", function () {    //   if (!document.hidden) {  //處于當前頁面    //     timer = setInterval(() => {    //       rotate();    //     }, 1000);    //     console.log('active');    //   } else {    //     clearInterval(timer);    //     console.log('hidden');    //   }    // });  }</script></html>


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人黄色激情网| 最近更新的2019中文字幕| 97在线看免费观看视频在线观看| 在线视频一区二区| 亚洲色图在线观看| 91沈先生在线观看| 懂色av中文一区二区三区天美| 热久久美女精品天天吊色| 国产精品视频中文字幕91| 日韩美女激情视频| 亚洲女人天堂色在线7777| 欧美激情视频网址| 国产一区二区三区四区福利| 精品一区二区电影| 久久久欧美一区二区| 亚洲人成毛片在线播放| 日韩免费看的电影电视剧大全| 91九色综合久久| 国产这里只有精品| 97久久久久久| 岛国视频午夜一区免费在线观看| 亚洲人成网站777色婷婷| 亚洲一区制服诱惑| 按摩亚洲人久久| 亚洲精品在线91| 午夜精品一区二区三区在线播放| 成人中文字幕+乱码+中文字幕| 成人精品视频在线| 91精品国产色综合久久不卡98| 一区二区三区精品99久久| 亚洲欧美三级在线| 国产高清视频一区三区| 欧美日韩第一视频| 亚洲天堂成人在线| 久久久久久久色| 亚洲第一精品久久忘忧草社区| 狠狠躁夜夜躁人人爽天天天天97| 国产精品video| 国模吧一区二区| 久久人人爽人人| 国产精品青青在线观看爽香蕉| 午夜精品蜜臀一区二区三区免费| 亚洲2020天天堂在线观看| 91免费视频网站| 91亚洲精品久久久久久久久久久久| 欧美视频裸体精品| 亚洲男人天堂2023| 国产精品扒开腿做爽爽爽的视频| 亚洲香蕉成视频在线观看| 中文字幕免费精品一区| 欧美在线影院在线视频| 国内外成人免费激情在线视频| 日产日韩在线亚洲欧美| 久久久久久久999精品视频| 国内外成人免费激情在线视频网站| 国产乱人伦真实精品视频| 精品网站999www| 日韩美女视频免费看| 91精品久久久久久久久久另类| 97视频免费观看| 麻豆乱码国产一区二区三区| 欧美xxxx18性欧美| 日韩欧美中文在线| 国产精品视频永久免费播放| 欧美综合一区第一页| 久久中文字幕视频| 2019亚洲日韩新视频| 中文字幕日韩欧美精品在线观看| 欧美日韩午夜视频在线观看| 国产精品视频网址| 久久中文精品视频| 亚洲视频视频在线| 成人免费视频97| 日韩国产精品一区| 日韩av中文在线| 1769国产精品| 国产精品久久久久久久久久小说| 中文字幕亚洲一区二区三区| 亚洲人成电影在线播放| 91热精品视频| 亚洲japanese制服美女| 国产精品jvid在线观看蜜臀| 91在线视频成人| 国产999在线| 美女啪啪无遮挡免费久久网站| 亚洲图片欧美午夜| 久热精品在线视频| 成人做爽爽免费视频| 国产精品一区二区三区成人| 日韩美女主播视频| 日本久久久久久久久久久| 亚洲欧美日韩一区二区三区在线| 日韩精品一区二区三区第95| 4p变态网欧美系列| 国产精品视频xxxx| 国产午夜精品免费一区二区三区| 成人福利免费观看| 亚洲国产高清高潮精品美女| 91精品国产网站| 欧美激情在线狂野欧美精品| 最近更新的2019中文字幕| 久久精品视频网站| 日韩美女视频免费在线观看| 日韩福利伦理影院免费| 久久精品国产一区二区电影| 国产精品av电影| 81精品国产乱码久久久久久| 韩曰欧美视频免费观看| 68精品国产免费久久久久久婷婷| 麻豆一区二区在线观看| 成人精品福利视频| 色综合久久精品亚洲国产| 国产日韩专区在线| 在线播放日韩精品| 国产日韩精品一区二区| 91中文字幕在线观看| 欧洲一区二区视频| 欧美日韩国产在线| 不卡av日日日| 亚洲第一级黄色片| 国产精品九九久久久久久久| 91在线观看免费高清| 欧美性黄网官网| 亚洲欧洲在线观看| 按摩亚洲人久久| 亚洲成人黄色网址| 亚洲免费视频一区二区| 亚洲区在线播放| 国产丝袜精品第一页| 欧美电影免费播放| 久久精品电影一区二区| 亚洲深夜福利视频| 福利视频一区二区| 日韩免费看的电影电视剧大全| 欧美最猛性xxxx| 亚洲人av在线影院| 欧美成人精品不卡视频在线观看| 麻豆一区二区在线观看| 国产精品jvid在线观看蜜臀| 国产精品成人观看视频国产奇米| 日韩在线中文视频| 亚洲国产福利在线| 亚洲一区中文字幕| 精品magnet| 情事1991在线| 国产成人精品亚洲精品| 欧美日韩亚洲精品一区二区三区| 欧美性色19p| 欧美国产日韩一区二区在线观看| 亚洲香蕉av在线一区二区三区| 韩日欧美一区二区| 亚洲国内高清视频| 亚洲女人天堂视频| 国产女精品视频网站免费| 亚洲精品国产福利| 91在线无精精品一区二区| 国产精品v日韩精品| 久久综合久久美利坚合众国| 久久综合久久八八| 日韩网站在线观看| 国产欧美一区二区三区久久人妖| 日韩精品电影网| 色先锋久久影院av| 国产精品88a∨|