中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

HTML5 transform三維立方體實現(xiàn)360無死角三維旋轉(zhuǎn)效果
來源:易賢網(wǎng) 閱讀:1652 次 日期:2014-11-20 15:12:19
溫馨提示:易賢網(wǎng)小編為您整理了“HTML5 transform三維立方體實現(xiàn)360無死角三維旋轉(zhuǎn)效果”,方便廣大網(wǎng)友查閱!

為了更好得掌握transform的精髓,所以決定完成三維立方體的模型,可以實現(xiàn)360無死角的三維旋轉(zhuǎn)效果。

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

源碼直接貢獻啦:

代碼如下:

<style>

.cuboid_side_div{

position:absolute;

border:1px solid #333;

-webkit-transition:ease all 1s;

}

</style>

<script>

/**

* 本版本存在以下問題:

* 三維旋轉(zhuǎn)的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;

////////////////////////////////////////

//初始化長方體

///////////////////////////////////////

//根據(jù)初始位置構(gòu)造六個面。

this.init = function() {

//創(chuàng)建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);

//創(chuàng)建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);

//創(chuàng)建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);

//創(chuàng)建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);

//創(chuàng)建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);

//創(chuàng)建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);

};

//旋轉(zhuǎn)立方體

this.rotate = function(x,y,z) {

rotateX = x;

rotateY = y;

rotateZ = z;

var rotateX_front = rotateX;

var rotateY_front = rotateY;

var rotateZ_front = rotateZ;

//判斷各個面旋轉(zhuǎn)角度

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>

更多信息請查看IT技術專欄

更多信息請查看網(wǎng)頁制作
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇剩?/div>

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
免费不卡在线视频| 欧美日韩第一页| av不卡在线看| 欧美另类99xxxxx| 日韩视频在线免费| 免费成人黄色| 欧美亚洲尤物久久| 亚洲一区精品在线| 亚洲午夜影视影院在线观看| 欧美一区二区三区日韩视频| 久久欧美肥婆一二区| 在线看片一区| 在线免费观看日韩欧美| 又紧又大又爽精品一区二区| 黄色成人小视频| 久久一区激情| 国产一区二区三区精品欧美日韩一区二区三区 | 另类尿喷潮videofree| 亚洲欧美日韩综合aⅴ视频| 欧美三级午夜理伦三级中视频| 欧美一区二区三区久久精品 | 久久五月激情| 亚洲国产你懂的| 国产欧美一区二区三区视频| 久久精品人人做人人爽| 中国成人亚色综合网站| 国产精品亚洲成人| 欧美日本亚洲韩国国产| 欧美大胆人体视频| 1204国产成人精品视频| 99re亚洲国产精品| 亚洲人成网站精品片在线观看| 国产精品乱码久久久久久| 国产乱人伦精品一区二区| 日韩视频在线观看免费| 欧美1区免费| 亚洲国产裸拍裸体视频在线观看乱了| 亚洲午夜一区| 欧美日韩另类字幕中文| 亚洲国产成人不卡| 欧美激情第一页xxx| av成人免费在线观看| 国产精品亚洲一区| 巨乳诱惑日韩免费av| 亚洲六月丁香色婷婷综合久久| 欧美成人亚洲成人| 亚洲夜间福利| 亚洲国产日韩美| 国产日本欧美视频| 欧美电影免费网站| 欧美有码在线观看视频| 亚洲狼人综合| 国内精品福利| 久久一二三区| 亚洲欧美成人| 亚洲在线视频免费观看| 精东粉嫩av免费一区二区三区| 欧美视频免费看| 国产精品日韩欧美大师| 在线精品亚洲| 亚洲欧美日韩一区二区三区在线观看 | 在线成人h网| 亚洲黄色一区| 一区二区免费在线视频| 欧美激情精品久久久久久黑人| 国产一区av在线| 久久久久久久欧美精品| 亚洲激情在线激情| 国内久久精品| 国产精品都在这里| 亚洲视频精品| 美国三级日本三级久久99| 免费久久99精品国产自在现线| 国产精品v欧美精品∨日韩| 国产亚洲精品v| 欧美日韩日韩| 国产精品麻豆va在线播放| 韩国精品久久久999| 亚洲一区二区欧美日韩| 久久尤物电影视频在线观看| 一区二区三区精品| 国产一区av在线| 亚洲视频免费看| 黄网站免费久久| 亚洲成人在线免费| 91久久久亚洲精品| 亚洲欧美日韩一区二区三区在线| 午夜精品久久久久久| 久久影院午夜片一区| 欧美激情欧美激情在线五月| 久久久综合精品| 国产精品久久久久一区| 国产色产综合产在线视频| 在线不卡中文字幕| 亚洲人成在线观看| 亚洲一区国产| 欧美激情一区二区三区不卡| 欧美日韩视频第一区| 亚洲电影免费在线观看| 亚洲午夜精品久久| 欧美激情导航| 国产女主播一区二区三区| 99视频有精品| 久久精品国产一区二区三区免费看| 欧美国产精品久久| 国产精品久久久久一区二区三区共 | 欧美精品日韩www.p站| 亚洲影院在线| 欧美福利视频一区| 黄色精品一二区| 亚洲一区影院| 欧美日韩另类国产亚洲欧美一级| 国产一区在线看| 午夜伦欧美伦电影理论片| 国产精品久久一级| 激情欧美一区二区三区| 亚洲女同同性videoxma| 欧美性猛片xxxx免费看久爱 | 国产精品亚洲网站| 在线性视频日韩欧美| 欧美国产日韩一二三区| 最新69国产成人精品视频免费| 久久久噜噜噜久久中文字幕色伊伊| 国产农村妇女精品一二区| 亚洲视频在线观看三级| 欧美精品1区2区| 午夜在线a亚洲v天堂网2018| 国产精品久久午夜| 日韩亚洲欧美高清| 91久久黄色| 欧美二区不卡| 亚洲欧美春色| 一本色道久久综合亚洲精品小说| 欧美成人免费视频| 午夜精品视频网站| 在线精品一区二区| 欧美日韩亚洲另类| 欧美尤物一区| 亚洲一区二区三区色| 亚洲国产成人久久综合| 欧美色网一区二区| 久热成人在线视频| 午夜久久tv| 夜夜嗨av一区二区三区四季av| 国产亚洲精品福利| 国产精品福利网站| 欧美激情一区二区三区全黄| 欧美中文字幕视频| 香蕉av777xxx色综合一区| 亚洲久色影视| 最新日韩在线视频| 亚洲激情一区二区三区| 亚洲精品国精品久久99热| 国产精品精品视频| 欧美日韩精品一区| 欧美另类综合| 欧美日韩免费看| 欧美日韩国产综合新一区| 久久人人九九| 免费不卡在线视频| 欧美好骚综合网| 欧美日韩国产一级片| 欧美日韩成人| 欧美视频一区二区三区| 午夜精彩国产免费不卡不顿大片| 亚洲午夜免费视频| 亚洲欧美在线x视频| 欧美在线观看视频在线| 久久综合久久综合九色| 免费视频久久| 欧美四级在线| 国产在线日韩| 在线观看视频亚洲| 一区二区三区免费网站| 香蕉av777xxx色综合一区| 久久久久久久成人| 欧美日韩中文在线观看| 国产午夜精品全部视频播放| 亚洲电影第三页| 亚洲免费小视频| 欧美国产日韩二区| 国产精品永久免费视频| 亚洲国产成人在线| 亚洲欧美久久久久一区二区三区| 久久aⅴ国产欧美74aaa| 欧美激情一区二区三区四区| 亚洲第一黄网| 亚洲欧美欧美一区二区三区| 久热成人在线视频| 国产精品人人做人人爽人人添| 在线精品视频免费观看| 欧美在线视频网站| 国产精品毛片高清在线完整版| 国产在线精品自拍| 午夜精品美女自拍福到在线| 欧美日韩小视频| 日韩亚洲精品视频| 久久资源在线| 在线电影国产精品| 女同性一区二区三区人了人一|