校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > HTML5 transform三維立方體實現360無死角三維旋轉效果

HTML5 transform三維立方體實現360無死角三維旋轉效果

熱門標簽:邢臺縣地圖標注app 申請400電話流程簡介 外呼系統電話怎么投訴 呼和浩特外呼電銷系統排名 外呼線穩定線路 地圖標注位置能賺錢嗎 阜陽企業外呼系統 pageadm實現地圖標注 南通數據外呼系統推廣
為了更好得掌握transform的精髓,所以決定完成三維立方體的模型,可以實現360無死角的三維旋轉效果。

但是旋轉時判斷每個面的視圖順序比較困難,仍未完美解決,希望有人能解答!

源碼直接貢獻啦:

復制代碼
代碼如下:

<style>
.cuboid_side_div{
position:absolute;
border:1px solid #333;
-webkit-transition:ease all 1s;
}
</style>
<script>
/**
* 本版本存在以下問題:
* 三維旋轉的zIndex計算有問題
* 還欠缺多種模型,常見的包括:線、面、椎體、球體、橢球體等。
*/
function cuboidModel(left_init,top_init,long_init,width_init,height_init)
{
////////////////////////////////////////
//初始化私有變量
///////////////////////////////////////
//初始化長方體位置、大小
var left = left_init;
var top = top_init;
var long = long_init;
var width = width_init;
var height = height_init;
//初始化變換角度,默認為0
var rotateX = 0;
var rotateY = 0;
var rotateZ = 0;
var zIndex = 0;
//定義長方體六個面的div對象
var div_front;
var div_behind;
var div_left;
var div_right;
var div_top;
var div_bottom;

////////////////////////////////////////
//初始化長方體
///////////////////////////////////////
//根據初始位置構造六個面。
this.init = function() {
//創建front div
div_front = document.createElement("div");
div_front.className = "cuboid_side_div";
div_front.innerHTML = "div front";
div_front.style.backgroundColor="#f1b2b2";
document.body.appendChild(div_front);
//創建behind div
div_behind = document.createElement("div");
div_behind.className = "cuboid_side_div";
div_behind.innerHTML = "div behind";
div_behind.style.backgroundColor="#bd91eb";
document.body.appendChild(div_behind);
//創建left div
div_left = document.createElement("div");
div_left.className = "cuboid_side_div";
div_left.innerHTML = "div left";
div_left.style.backgroundColor="#64a3c3";
document.body.appendChild(div_left);
//創建right div
div_right = document.createElement("div");
div_right.className = "cuboid_side_div";
div_right.innerHTML = "div right";
div_right.style.backgroundColor="#78e797";
document.body.appendChild(div_right);
//創建top div
div_top = document.createElement("div");
div_top.className = "cuboid_side_div";
div_top.innerHTML = "div top";
div_top.style.backgroundColor="#e7db78";
document.body.appendChild(div_top);
//創建bottom div
div_bottom = document.createElement("div");
div_bottom.className = "cuboid_side_div";
div_bottom.innerHTML = "div bottom";
div_bottom.style.backgroundColor="#e79c78";
document.body.appendChild(div_bottom);
this.refresh();
};
//重繪
this.refresh = function()
{
//定義div_front樣式
div_front.style.left = left+"px";
div_front.style.top = top+"px";
div_front.style.width = long +"px";
div_front.style.height = height +"px";
div_front.style.webkitTransformOrigin = "50% 50% "+((-1)*width / 2)+"px";
//定義div_behind樣式
div_behind.style.left = left+"px";
div_behind.style.top = top+"px";
div_behind.style.width = div_front.style.width;
div_behind.style.height = div_front.style.height;
div_behind.style.webkitTransformOrigin = "50% 50% "+((-1)*width / 2)+"px";
//定義div_left樣式
div_left.style.left = left+((long - height) / 2)+"px";
div_left.style.top = top + ((height - width) / 2)+"px";
div_left.style.width = height +"px";
div_left.style.height = width +"px";
div_left.style.webkitTransformOrigin = "50% 50% "+((-1) * long /2 )+"px";
//定義div_right樣式
div_right.style.left = div_left.style.left;
div_right.style.top = div_left.style.top;
div_right.style.width = div_left.style.width;
div_right.style.height = div_left.style.height;
div_right.style.webkitTransformOrigin = "50% 50% "+((-1) * long /2 )+"px";
//定義div_top樣式
div_top.style.left = left+"px";
div_top.style.top = top+((height - width)/ 2)+"px";
div_top.style.width = long +"px";
div_top.style.height = width +"px";
div_top.style.webkitTransformOrigin = "50% 50% "+((-1) * height /2 )+"px";
//定義div_bottom樣式
div_bottom.style.left = div_top.style.left;
div_bottom.style.top = div_top.style.top;
div_bottom.style.width = div_top.style.width;
div_bottom.style.height = div_top.style.height;
div_bottom.style.webkitTransformOrigin = "50% 50% "+((-1) * height /2 )+"px";
this.rotate(rotateX,rotateY,rotateZ);
};
//旋轉立方體
this.rotate = function(x,y,z) {
rotateX = x;
rotateY = y;
rotateZ = z;
var rotateX_front = rotateX;
var rotateY_front = rotateY;
var rotateZ_front = rotateZ;
//判斷各個面旋轉角度
var rotateX_behind = rotateX_front+180;
var rotateY_behind = rotateY_front * (-1);
var rotateZ_behind = rotateZ_front * (-1);
var rotateX_top = rotateX_front+90;
var rotateY_top = rotateZ_front;
var rotateZ_top = rotateY_front * (-1);
var rotateX_bottom = rotateX_front-90;
var rotateY_bottom = rotateZ_front * (-1);
var rotateZ_bottom = rotateY_front;
var rotateX_left = rotateX_front + 90;
var rotateY_left = rotateZ_front - 90;
var rotateZ_left = rotateY_front * (-1);
var rotateX_right = rotateX_front + 90;
var rotateY_right = rotateZ_front + 90;
var rotateZ_right = rotateY_front * (-1);
//判斷各個面的z軸顯示順序
var zIndex_front_default = -1;
var zIndex_behind_default = -6;
var zIndex_top_default = -5;
var zIndex_bottom_default = -2;
var zIndex_left_default = -4;
var zIndex_right_default = -3;
var xI = (rotateX_front / 90) % 4;
var yI = (rotateY_front / 90) % 4;
var zI = (rotateZ_front / 90) % 4;
var zIndex_matrix = new Array();
for(var i = 0; i < 3;i++) {
zIndex_matrix.push(new Array());
}
zIndex_matrix = [["","zIndex_top",""],
["zIndex_left","zIndex_front","zIndex_right"],
["","zIndex_bottom",""]];
var zIndex_matrix_behind = "zIndex_behind";
//計算zIndex
if((xI >= 0 && xI < 1) ||(xI >= -4 && xI < -3)) {
} else if((xI >= 1 && xI < 2) ||(xI >= -3 && xI < -2)) {
var zIndex_matrix_tmp = zIndex_matrix[0][1];
zIndex_matrix[0][1] = zIndex_matrix[1][1];
zIndex_matrix[1][1] = zIndex_matrix[1][2];
zIndex_matrix[1][2] = zIndex_matrix_behind;
zIndex_matrix_behind = zIndex_matrix_tmp;
} else if((xI >= 2 && xI < 3) ||(xI >= -2 && xI < -1)) {
var zIndex_matrix_tmp = zIndex_matrix[0][1];
zIndex_matrix[0][1] = zIndex_matrix[2][1];
zIndex_matrix[2][1] = zIndex_matrix_tmp;
zIndex_matrix_tmp = zIndex_matrix[1][1];
zIndex_matrix[1][1] = zIndex_matrix_behind;
zIndex_matrix_behind = zIndex_matrix_tmp;
} else if((xI >= 3 && xI < 4) ||(xI >= -1 && xI < 0)) {
var zIndex_matrix_tmp = zIndex_matrix[0][1];
zIndex_matrix[0][1] = zIndex_matrix_behind;
zIndex_matrix_behind = zIndex_matrix[2][1];
zIndex_matrix[2][1] = zIndex_matrix[1][1];
zIndex_matrix[1][1] = zIndex_matrix_tmp;
}
if((yI > 0 && yI <= 1) ||(yI > -4 && yI <= -3)) {
var zIndex_matrix_tmp = zIndex_matrix[1][0];
zIndex_matrix[1][0] = zIndex_matrix_behind;
zIndex_matrix_behind = zIndex_matrix[1][2];
zIndex_matrix[1][2] = zIndex_matrix[1][1];
zIndex_matrix[1][1] = zIndex_matrix_tmp;
} else if((yI > 1 && yI <= 2) ||(yI > -3 && yI <= -2)) {
var zIndex_matrix_tmp = zIndex_matrix[1][0];
zIndex_matrix[1][0] = zIndex_matrix[1][2];
zIndex_matrix[1][2] = zIndex_matrix_tmp;
zIndex_matrix_tmp = zIndex_matrix[1][1];
zIndex_matrix[1][1] = zIndex_matrix_behind;
zIndex_matrix_behind = zIndex_matrix_tmp;
} else if((yI > 2 && yI <= 3) ||(yI > -2 && yI <= -1)) {
var zIndex_matrix_tmp = zIndex_matrix[1][0];
zIndex_matrix[1][0] = zIndex_matrix[1][1];
zIndex_matrix[1][1] = zIndex_matrix[1][2];
zIndex_matrix[1][2] = zIndex_matrix_behind;
zIndex_matrix_behind = zIndex_matrix_tmp;
} else if((yI > 3 && yI <= 4) ||(yI > -1 && yI <= 0)) {
}

if((zI > 0 && zI <= 1) ||(zI > -4 && zI <= -3)) {
var zIndex_matrix_tmp = zIndex_matrix[0][1];
zIndex_matrix[0][1] = zIndex_matrix[1][0];
zIndex_matrix[1][0] = zIndex_matrix[2][1];
zIndex_matrix[2][1] = zIndex_matrix[1][2];
zIndex_matrix[1][2] = zIndex_matrix_tmp;
} else if((zI > 1 && zI <= 2) ||(zI > -3 && zI <= -2)) {
var zIndex_matrix_tmp = zIndex_matrix[0][1];
zIndex_matrix[0][1] = zIndex_matrix[2][1];
zIndex_matrix[2][1] = zIndex_matrix_tmp;
zIndex_matrix_tmp = zIndex_matrix[1][0];
zIndex_matrix[1][0] = zIndex_matrix[1][2];
zIndex_matrix[1][2] = zIndex_matrix_tmp;
} else if((zI > 2 && zI <= 3) ||(zI > -2 && zI <= -1)) {
var zIndex_matrix_tmp = zIndex_matrix[0][1];
zIndex_matrix[0][1] = zIndex_matrix[1][2];
zIndex_matrix[1][2] = zIndex_matrix[2][1];
zIndex_matrix[2][1] = zIndex_matrix[1][0];
zIndex_matrix[1][0] = zIndex_matrix_tmp;
} else if((zI > 3 && zI <= 4) ||(zI > -1 && zI <= 0)) {
}
//賦值zIndex
eval(zIndex_matrix[0][1]+"="+zIndex_top_default);
eval(zIndex_matrix[1][0]+"="+zIndex_left_default);
eval(zIndex_matrix[1][1]+"="+zIndex_front_default);
eval(zIndex_matrix[1][2]+"="+zIndex_right_default);
eval(zIndex_matrix[2][1]+"="+zIndex_bottom_default);
eval(zIndex_matrix_behind+"="+zIndex_behind_default);
//front
var transform_rotate_front = "perspective(500px) rotateX("+rotateX_front+
"deg) rotateY("+rotateY_front+
"deg) rotateZ("+rotateZ_front+"deg)";
div_front.style.webkitTransform = transform_rotate_front;
div_front.style.zIndex = zIndex_front;
//behind
var transform_rotate_behind = "perspective(500px) rotateX("+rotateX_behind+
"deg) rotateY("+rotateY_behind+
"deg) rotateZ("+rotateZ_behind+"deg)";
div_behind.style.webkitTransform = transform_rotate_behind;
div_behind.style.zIndex = zIndex_behind;
//left
var transform_rotate_left = "perspective(500px) rotateX("+rotateX_left+
"deg) rotateZ("+rotateZ_left+
"deg) rotateY("+rotateY_left+"deg)";
div_left.style.webkitTransform = transform_rotate_left;
div_left.style.zIndex = zIndex_left;
//right
var transform_rotate_right = "perspective(500px) rotateX("+rotateX_right+
"deg) rotateZ("+rotateZ_right+
"deg) rotateY("+rotateY_right+"deg)";
div_right.style.webkitTransform = transform_rotate_right;
div_right.style.zIndex = zIndex_right;
//top
var transform_rotate_top = "perspective(500px) rotateX("+rotateX_top+
"deg) rotateZ("+rotateZ_top+
"deg) rotateY("+rotateY_top+"deg)";
div_top.style.webkitTransform = transform_rotate_top;
div_top.style.zIndex = zIndex_top;
//bottom
var transform_rotate_bottom = "perspective(500px) rotateX("+rotateX_bottom+
"deg) rotateZ("+rotateZ_bottom+
"deg) rotateY("+rotateY_bottom+"deg)";
div_bottom.style.webkitTransform = transform_rotate_bottom;
div_bottom.style.zIndex = zIndex_bottom;
};
//重置長方體的長、寬、高
this.resize = function(new_long, new_width, new_height)
{
long = new_long;
width = new_width;
height = new_height;
this.refresh();
};
//重置長方體的位置
this.move = function(new_left,new_top) {
top = new_top;
left = new_left;
this.refresh();
};
}

function transform() {
cuboid.resize(parseInt(document.getElementById("long").value),
parseInt(document.getElementById("width").value),
parseInt(document.getElementById("height").value));
cuboid.move(parseInt(document.getElementById("left").value),
parseInt(document.getElementById("top").value));
cuboid.rotate(parseInt(document.getElementById("rotatex").value),
parseInt(document.getElementById("rotatey").value),
parseInt(document.getElementById("rotatez").value));
//cuboid.refresh();
}
</script>
<div style="position:absolute;border:1px solid #333;top:240px;left:100px;width:1000px;height: 360px;">
left:<input id="left" value="100"></input>px

top:<input id="top" value="50"></input>px

long:<input id="long" value="100"></input>px

width:<input id="width" value="60"></input>px

height:<input id="height" value="80"></input>px

rotateX: <input id="rotatex" value="0"></input>deg

rotateY: <input id="rotatey" value="0"></input>deg

rotateZ: <input id="rotatez" value="0"></input>deg

<input type="button" value="確定" onclick="transform()"></input>

<label id="status"></label>
</div>
<script>
var cuboid = new cuboidModel(parseInt(document.getElementById("left").value),
parseInt(document.getElementById("top").value),
parseInt(document.getElementById("long").value),
parseInt(document.getElementById("width").value),
parseInt(document.getElementById("height").value));
cuboid.init();
</script>

標簽:辛集 楊凌 撫順 鶴崗 蚌埠 黃山 德州 內蒙古

巨人網絡通訊聲明:本文標題《HTML5 transform三維立方體實現360無死角三維旋轉效果》,本文關鍵詞  HTML5,transform,三維,立方體,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《HTML5 transform三維立方體實現360無死角三維旋轉效果》相關的同類信息!
  • 本頁收集關于HTML5 transform三維立方體實現360無死角三維旋轉效果的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    免费成人在线视频观看| 五月天一区二区三区| 99精品视频一区| 日本不卡一区二区| 国内一区二区视频| 色94色欧美sute亚洲线路一久| 一本色道**综合亚洲精品蜜桃冫| 欧美一区二区在线看| 国产亚洲精品中文字幕| 丁香亚洲综合激情啪啪综合| 欧美最猛黑人xxxxx猛交| 丁香婷婷综合五月| 麻豆精品一区二区| 91蝌蚪国产九色| 成人国产精品免费观看视频| 日韩欧美一级二级三级| 在线播放欧美女士性生活| 中文字幕制服丝袜一区二区三区| 日韩在线一区二区三区| 亚洲午夜在线视频| 午夜精品久久久久久久久久久| 综合精品久久久| 日韩影院在线观看| 欧美羞羞免费网站| 国产精品久久久久永久免费观看| 国产一区啦啦啦在线观看| 欧美三级一区二区| 午夜一区二区三区视频| 99在线精品观看| 99久久婷婷国产综合精品电影 | 午夜精品久久久久久久久| 国产制服丝袜一区| 制服丝袜日韩国产| 久久精品人人做人人爽97| 亚洲电影欧美电影有声小说| 亚洲大片精品永久免费| 99精品在线观看视频| 国产三级一区二区| 国产成人午夜99999| 国产精品一线二线三线| 欧美酷刑日本凌虐凌虐| 9191成人精品久久| 白白色亚洲国产精品| 日本乱码高清不卡字幕| 国产精品国产精品国产专区不蜜| 天天色图综合网| 欧美精品电影在线播放| 蜜桃视频在线一区| 日韩一区二区在线观看视频 | 亚洲国产精品精华液2区45| 国产精品久久看| 色婷婷av一区二区三区gif| 中文字幕一区二区三| 亚洲自拍都市欧美小说| 日韩国产欧美在线播放| 欧美一区二区三区日韩视频| 日韩av中文在线观看| 久久色成人在线| 国产日产欧美精品一区二区三区| 中文字幕在线观看一区| 婷婷一区二区三区| 日韩午夜三级在线| 伊人婷婷欧美激情| 久久99国产精品免费| 欧美一级淫片007| 国产高清不卡二三区| 欧美激情一区二区三区不卡| 日韩国产欧美视频| 91丝袜美腿高跟国产极品老师| 久久精品这里都是精品| 色狠狠一区二区三区香蕉| 26uuu国产一区二区三区| 成人午夜免费av| 亚洲三级电影网站| 精品日本一线二线三线不卡| 国产精品亚洲人在线观看| 91精品国产一区二区三区香蕉| 五月天亚洲婷婷| 97精品久久久午夜一区二区三区| 久久久久久久av麻豆果冻| 亚洲国产精品一区二区久久恐怖片| 激情久久久久久久久久久久久久久久| 精品视频免费看| 欧美激情一区三区| 高清日韩电视剧大全免费| 日韩精品一区二区三区在线播放| 精东粉嫩av免费一区二区三区| 亚洲色图都市小说| 成人一区二区三区视频在线观看| 久久蜜臀精品av| 美女一区二区视频| 欧美亚洲尤物久久| 免费在线观看精品| 91精品国产综合久久久久久久久久| 亚洲国产视频网站| 国产欧美日产一区| 激情深爱一区二区| 天堂久久久久va久久久久| 欧美吻胸吃奶大尺度电影| 亚洲国产日韩av| 日韩欧美视频一区| 色偷偷久久一区二区三区| 亚洲欧美另类小说视频| 91麻豆精品国产91久久久久久久久 | 欧美久久免费观看| 国产精品1区2区3区在线观看| 亚洲自拍偷拍av| 欧美日韩一区视频| 成人黄色综合网站| 久久国产尿小便嘘嘘尿| 亚洲激情av在线| 欧美一区二区啪啪| 精品一区二区久久| 精品日本一线二线三线不卡| 久久99久久精品欧美| 精品国产欧美一区二区| 日韩一级精品视频在线观看| 欧美色区777第一页| 国产精品456| 国产一区二区不卡在线| 三级久久三级久久| 亚洲午夜精品一区二区三区他趣| 亚洲精品中文在线影院| 色呦呦网站一区| 亚洲精品ww久久久久久p站| 欧美日韩午夜在线| 久久99国产精品免费网站| 国产日韩欧美麻豆| 精品电影一区二区| 精品区一区二区| 欧美日本一道本在线视频| 亚洲国产精品久久不卡毛片| **欧美大码日韩| 成人欧美一区二区三区视频网页| 成人av动漫在线| 成人a级免费电影| 成人爱爱电影网址| 亚洲精品国产无天堂网2021| wwwwww.欧美系列| 色狠狠色狠狠综合| 97精品国产露脸对白| 中文字幕av资源一区| 欧美成人a视频| 久久久三级国产网站| www久久精品| 99精品视频免费在线观看| 亚洲久草在线视频| 亚洲欧美激情插| 亚洲国产精品嫩草影院| 欧美成人aa大片| 欧美韩日一区二区三区四区| 亚洲少妇30p| 丝袜诱惑亚洲看片| 日本一区二区不卡视频| 亚洲人成7777| 午夜久久久影院| 免费成人结看片| 亚洲欧美日韩国产另类专区| 亚洲欧洲综合另类| 欧美成人一级视频| 精品一区二区三区蜜桃| 青青草原综合久久大伊人精品优势| 国产无遮挡一区二区三区毛片日本 | 色噜噜久久综合| 欧美人与性动xxxx| 欧美精品成人一区二区三区四区| 欧美mv日韩mv亚洲| 国产欧美日韩中文久久| 欧美国产激情一区二区三区蜜月 | 91国偷自产一区二区三区观看| 天堂va蜜桃一区二区三区漫画版| 国产精品美女久久久久久2018 | 欧美变态tickle挠乳网站| 久久精品国产澳门| 国产精品美女久久久久久久| 一区二区三区不卡视频在线观看| 精品不卡在线视频| 亚洲色图第一区| 国产呦精品一区二区三区网站| ㊣最新国产の精品bt伙计久久| 五月婷婷综合激情| 成人在线综合网站| 久久99深爱久久99精品| 99在线精品免费| 国产成人夜色高潮福利影视| 丝袜美腿亚洲色图| 成人激情开心网| 国产精品亚洲一区二区三区在线 | 综合av第一页| 亚洲欧洲精品一区二区三区不卡| 一区二区三区高清在线| 亚洲免费高清视频在线| 久久99精品一区二区三区| 国产精品福利影院| 亚洲一本大道在线| 色综合久久久久综合体| 欧美va天堂va视频va在线| 亚洲精品在线三区| 欧美日韩中文精品| 欧美日本在线播放|