HTML5 transform三维立方体实现360无死角三维旋转效果_html5教程技巧
2015-01-04 13:08:39
[小 大]
已经帮助:人解决问题
使用HTML5 transform完成三维立方体的模型,可以实现360无死角的三维旋转效果,美中不足的是无法判断旋转时判断每个面的视图顺序,喜欢的朋友可以了解下
为了更好得掌握transform的精髓,所以决定完成三维立方体的模型,可以实现360无死角的三维旋转效果。
SRLHTML5中文学习网 - HTML5先行者学习网SRLHTML5中文学习网 - HTML5先行者学习网但是旋转时判断每个面的视图顺序比较困难,仍未完美解决,希望有人能解答!
SRLHTML5中文学习网 - HTML5先行者学习网SRLHTML5中文学习网 - HTML5先行者学习网源码直接贡献啦:
SRLHTML5中文学习网 - HTML5先行者学习网 SRLHTML5中文学习网 - HTML5先行者学习网
<style> SRLHTML5中文学习网 - HTML5先行者学习网
.cuboid_side_div{ SRLHTML5中文学习网 - HTML5先行者学习网
position:absolute; SRLHTML5中文学习网 - HTML5先行者学习网
border:1px solid #333; SRLHTML5中文学习网 - HTML5先行者学习网
-webkit-transition:ease all 1s; SRLHTML5中文学习网 - HTML5先行者学习网
} SRLHTML5中文学习网 - HTML5先行者学习网
</style> SRLHTML5中文学习网 - HTML5先行者学习网
<script> SRLHTML5中文学习网 - HTML5先行者学习网
/** SRLHTML5中文学习网 - HTML5先行者学习网
* 本版本存在以下问题: SRLHTML5中文学习网 - HTML5先行者学习网
* 三维旋转的zIndex计算有问题 SRLHTML5中文学习网 - HTML5先行者学习网
* 还欠缺多种模型,常见的包括:线、面、椎体、球体、椭球体等。 SRLHTML5中文学习网 - HTML5先行者学习网
*/ SRLHTML5中文学习网 - HTML5先行者学习网
function cuboidModel(left_init,top_init,long_init,width_init,height_init) SRLHTML5中文学习网 - HTML5先行者学习网
{ SRLHTML5中文学习网 - HTML5先行者学习网
//////////////////////////////////////// SRLHTML5中文学习网 - HTML5先行者学习网
//初始化私有变量 SRLHTML5中文学习网 - HTML5先行者学习网
/////////////////////////////////////// SRLHTML5中文学习网 - HTML5先行者学习网
//初始化长方体位置、大小 SRLHTML5中文学习网 - HTML5先行者学习网
var left = left_init; SRLHTML5中文学习网 - HTML5先行者学习网
var top = top_init; SRLHTML5中文学习网 - HTML5先行者学习网
var long = long_init; SRLHTML5中文学习网 - HTML5先行者学习网
var width = width_init; SRLHTML5中文学习网 - HTML5先行者学习网
var height = height_init; SRLHTML5中文学习网 - HTML5先行者学习网
//初始化变换角度,默认为0 SRLHTML5中文学习网 - HTML5先行者学习网
var rotateX = 0; SRLHTML5中文学习网 - HTML5先行者学习网
var rotateY = 0; SRLHTML5中文学习网 - HTML5先行者学习网
var rotateZ = 0; SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex = 0; SRLHTML5中文学习网 - HTML5先行者学习网
//定义长方体六个面的div对象 SRLHTML5中文学习网 - HTML5先行者学习网
var div_front; SRLHTML5中文学习网 - HTML5先行者学习网
var div_behind; SRLHTML5中文学习网 - HTML5先行者学习网
var div_left; SRLHTML5中文学习网 - HTML5先行者学习网
var div_right; SRLHTML5中文学习网 - HTML5先行者学习网
var div_top; SRLHTML5中文学习网 - HTML5先行者学习网
var div_bottom; SRLHTML5中文学习网 - HTML5先行者学习网
SRLHTML5中文学习网 - HTML5先行者学习网
//////////////////////////////////////// SRLHTML5中文学习网 - HTML5先行者学习网
//初始化长方体 SRLHTML5中文学习网 - HTML5先行者学习网
/////////////////////////////////////// SRLHTML5中文学习网 - HTML5先行者学习网
//根据初始位置构造六个面。 SRLHTML5中文学习网 - HTML5先行者学习网
this.init = function() { SRLHTML5中文学习网 - HTML5先行者学习网
//创建front div SRLHTML5中文学习网 - HTML5先行者学习网
div_front = document.createElement("div"); SRLHTML5中文学习网 - HTML5先行者学习网
div_front.className = "cuboid_side_div"; SRLHTML5中文学习网 - HTML5先行者学习网
div_front.innerHTML = "div front"; SRLHTML5中文学习网 - HTML5先行者学习网
div_front.style.backgroundColor="#f1b2b2"; SRLHTML5中文学习网 - HTML5先行者学习网
document.body.appendChild(div_front); SRLHTML5中文学习网 - HTML5先行者学习网
//创建behind div SRLHTML5中文学习网 - HTML5先行者学习网
div_behind = document.createElement("div"); SRLHTML5中文学习网 - HTML5先行者学习网
div_behind.className = "cuboid_side_div"; SRLHTML5中文学习网 - HTML5先行者学习网
div_behind.innerHTML = "div behind"; SRLHTML5中文学习网 - HTML5先行者学习网
div_behind.style.backgroundColor="#bd91eb"; SRLHTML5中文学习网 - HTML5先行者学习网
document.body.appendChild(div_behind); SRLHTML5中文学习网 - HTML5先行者学习网
//创建left div SRLHTML5中文学习网 - HTML5先行者学习网
div_left = document.createElement("div"); SRLHTML5中文学习网 - HTML5先行者学习网
div_left.className = "cuboid_side_div"; SRLHTML5中文学习网 - HTML5先行者学习网
div_left.innerHTML = "div left"; SRLHTML5中文学习网 - HTML5先行者学习网
div_left.style.backgroundColor="#64a3c3"; SRLHTML5中文学习网 - HTML5先行者学习网
document.body.appendChild(div_left); SRLHTML5中文学习网 - HTML5先行者学习网
//创建right div SRLHTML5中文学习网 - HTML5先行者学习网
div_right = document.createElement("div"); SRLHTML5中文学习网 - HTML5先行者学习网
div_right.className = "cuboid_side_div"; SRLHTML5中文学习网 - HTML5先行者学习网
div_right.innerHTML = "div right"; SRLHTML5中文学习网 - HTML5先行者学习网
div_right.style.backgroundColor="#78e797"; SRLHTML5中文学习网 - HTML5先行者学习网
document.body.appendChild(div_right); SRLHTML5中文学习网 - HTML5先行者学习网
//创建top div SRLHTML5中文学习网 - HTML5先行者学习网
div_top = document.createElement("div"); SRLHTML5中文学习网 - HTML5先行者学习网
div_top.className = "cuboid_side_div"; SRLHTML5中文学习网 - HTML5先行者学习网
div_top.innerHTML = "div top"; SRLHTML5中文学习网 - HTML5先行者学习网
div_top.style.backgroundColor="#e7db78"; SRLHTML5中文学习网 - HTML5先行者学习网
document.body.appendChild(div_top); SRLHTML5中文学习网 - HTML5先行者学习网
//创建bottom div SRLHTML5中文学习网 - HTML5先行者学习网
div_bottom = document.createElement("div"); SRLHTML5中文学习网 - HTML5先行者学习网
div_bottom.className = "cuboid_side_div"; SRLHTML5中文学习网 - HTML5先行者学习网
div_bottom.innerHTML = "div bottom"; SRLHTML5中文学习网 - HTML5先行者学习网
div_bottom.style.backgroundColor="#e79c78"; SRLHTML5中文学习网 - HTML5先行者学习网
document.body.appendChild(div_bottom); SRLHTML5中文学习网 - HTML5先行者学习网
this.refresh(); SRLHTML5中文学习网 - HTML5先行者学习网
}; SRLHTML5中文学习网 - HTML5先行者学习网
//重绘 SRLHTML5中文学习网 - HTML5先行者学习网
this.refresh = function() SRLHTML5中文学习网 - HTML5先行者学习网
{ SRLHTML5中文学习网 - HTML5先行者学习网
//定义div_front样式 SRLHTML5中文学习网 - HTML5先行者学习网
div_front.style.left = left+"px"; SRLHTML5中文学习网 - HTML5先行者学习网
div_front.style.top = top+"px"; SRLHTML5中文学习网 - HTML5先行者学习网
div_front.style.width = long +"px"; SRLHTML5中文学习网 - HTML5先行者学习网
div_front.style.height = height +"px"; SRLHTML5中文学习网 - HTML5先行者学习网
div_front.style.webkitTransformOrigin = "50% 50% "+((-1)*width / 2)+"px"; SRLHTML5中文学习网 - HTML5先行者学习网
//定义div_behind样式 SRLHTML5中文学习网 - HTML5先行者学习网
div_behind.style.left = left+"px"; SRLHTML5中文学习网 - HTML5先行者学习网
div_behind.style.top = top+"px"; SRLHTML5中文学习网 - HTML5先行者学习网
div_behind.style.width = div_front.style.width; SRLHTML5中文学习网 - HTML5先行者学习网
div_behind.style.height = div_front.style.height; SRLHTML5中文学习网 - HTML5先行者学习网
div_behind.style.webkitTransformOrigin = "50% 50% "+((-1)*width / 2)+"px"; SRLHTML5中文学习网 - HTML5先行者学习网
//定义div_left样式 SRLHTML5中文学习网 - HTML5先行者学习网
div_left.style.left = left+((long - height) / 2)+"px"; SRLHTML5中文学习网 - HTML5先行者学习网
div_left.style.top = top + ((height - width) / 2)+"px"; SRLHTML5中文学习网 - HTML5先行者学习网
div_left.style.width = height +"px"; SRLHTML5中文学习网 - HTML5先行者学习网
div_left.style.height = width +"px"; SRLHTML5中文学习网 - HTML5先行者学习网
div_left.style.webkitTransformOrigin = "50% 50% "+((-1) * long /2 )+"px"; SRLHTML5中文学习网 - HTML5先行者学习网
//定义div_right样式 SRLHTML5中文学习网 - HTML5先行者学习网
div_right.style.left = div_left.style.left; SRLHTML5中文学习网 - HTML5先行者学习网
div_right.style.top = div_left.style.top; SRLHTML5中文学习网 - HTML5先行者学习网
div_right.style.width = div_left.style.width; SRLHTML5中文学习网 - HTML5先行者学习网
div_right.style.height = div_left.style.height; SRLHTML5中文学习网 - HTML5先行者学习网
div_right.style.webkitTransformOrigin = "50% 50% "+((-1) * long /2 )+"px"; SRLHTML5中文学习网 - HTML5先行者学习网
//定义div_top样式 SRLHTML5中文学习网 - HTML5先行者学习网
div_top.style.left = left+"px"; SRLHTML5中文学习网 - HTML5先行者学习网
div_top.style.top = top+((height - width)/ 2)+"px"; SRLHTML5中文学习网 - HTML5先行者学习网
div_top.style.width = long +"px"; SRLHTML5中文学习网 - HTML5先行者学习网
div_top.style.height = width +"px"; SRLHTML5中文学习网 - HTML5先行者学习网
div_top.style.webkitTransformOrigin = "50% 50% "+((-1) * height /2 )+"px"; SRLHTML5中文学习网 - HTML5先行者学习网
//定义div_bottom样式 SRLHTML5中文学习网 - HTML5先行者学习网
div_bottom.style.left = div_top.style.left; SRLHTML5中文学习网 - HTML5先行者学习网
div_bottom.style.top = div_top.style.top; SRLHTML5中文学习网 - HTML5先行者学习网
div_bottom.style.width = div_top.style.width; SRLHTML5中文学习网 - HTML5先行者学习网
div_bottom.style.height = div_top.style.height; SRLHTML5中文学习网 - HTML5先行者学习网
div_bottom.style.webkitTransformOrigin = "50% 50% "+((-1) * height /2 )+"px"; SRLHTML5中文学习网 - HTML5先行者学习网
this.rotate(rotateX,rotateY,rotateZ); SRLHTML5中文学习网 - HTML5先行者学习网
}; SRLHTML5中文学习网 - HTML5先行者学习网
//旋转立方体 SRLHTML5中文学习网 - HTML5先行者学习网
this.rotate = function(x,y,z) { SRLHTML5中文学习网 - HTML5先行者学习网
rotateX = x; SRLHTML5中文学习网 - HTML5先行者学习网
rotateY = y; SRLHTML5中文学习网 - HTML5先行者学习网
rotateZ = z; SRLHTML5中文学习网 - HTML5先行者学习网
var rotateX_front = rotateX; SRLHTML5中文学习网 - HTML5先行者学习网
var rotateY_front = rotateY; SRLHTML5中文学习网 - HTML5先行者学习网
var rotateZ_front = rotateZ; SRLHTML5中文学习网 - HTML5先行者学习网
//判断各个面旋转角度 SRLHTML5中文学习网 - HTML5先行者学习网
var rotateX_behind = rotateX_front+180; SRLHTML5中文学习网 - HTML5先行者学习网
var rotateY_behind = rotateY_front * (-1); SRLHTML5中文学习网 - HTML5先行者学习网
var rotateZ_behind = rotateZ_front * (-1); SRLHTML5中文学习网 - HTML5先行者学习网
var rotateX_top = rotateX_front+90; SRLHTML5中文学习网 - HTML5先行者学习网
var rotateY_top = rotateZ_front; SRLHTML5中文学习网 - HTML5先行者学习网
var rotateZ_top = rotateY_front * (-1); SRLHTML5中文学习网 - HTML5先行者学习网
var rotateX_bottom = rotateX_front-90; SRLHTML5中文学习网 - HTML5先行者学习网
var rotateY_bottom = rotateZ_front * (-1); SRLHTML5中文学习网 - HTML5先行者学习网
var rotateZ_bottom = rotateY_front; SRLHTML5中文学习网 - HTML5先行者学习网
var rotateX_left = rotateX_front + 90; SRLHTML5中文学习网 - HTML5先行者学习网
var rotateY_left = rotateZ_front - 90; SRLHTML5中文学习网 - HTML5先行者学习网
var rotateZ_left = rotateY_front * (-1); SRLHTML5中文学习网 - HTML5先行者学习网
var rotateX_right = rotateX_front + 90; SRLHTML5中文学习网 - HTML5先行者学习网
var rotateY_right = rotateZ_front + 90; SRLHTML5中文学习网 - HTML5先行者学习网
var rotateZ_right = rotateY_front * (-1); SRLHTML5中文学习网 - HTML5先行者学习网
//判断各个面的z轴显示顺序 SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_front_default = -1; SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_behind_default = -6; SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_top_default = -5; SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_bottom_default = -2; SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_left_default = -4; SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_right_default = -3; SRLHTML5中文学习网 - HTML5先行者学习网
var xI = (rotateX_front / 90) % 4; SRLHTML5中文学习网 - HTML5先行者学习网
var yI = (rotateY_front / 90) % 4; SRLHTML5中文学习网 - HTML5先行者学习网
var zI = (rotateZ_front / 90) % 4; SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_matrix = new Array(); SRLHTML5中文学习网 - HTML5先行者学习网
for(var i = 0; i < 3;i++) { SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix.push(new Array()); SRLHTML5中文学习网 - HTML5先行者学习网
} SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix = [["","zIndex_top",""], SRLHTML5中文学习网 - HTML5先行者学习网
["zIndex_left","zIndex_front","zIndex_right"], SRLHTML5中文学习网 - HTML5先行者学习网
["","zIndex_bottom",""]]; SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_matrix_behind = "zIndex_behind"; SRLHTML5中文学习网 - HTML5先行者学习网
//计算zIndex SRLHTML5中文学习网 - HTML5先行者学习网
if((xI >= 0 && xI < 1) ||(xI >= -4 && xI < -3)) { SRLHTML5中文学习网 - HTML5先行者学习网
} else if((xI >= 1 && xI < 2) ||(xI >= -3 && xI < -2)) { SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_matrix_tmp = zIndex_matrix[0][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[0][1] = zIndex_matrix[1][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][1] = zIndex_matrix[1][2]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][2] = zIndex_matrix_behind; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix_behind = zIndex_matrix_tmp; SRLHTML5中文学习网 - HTML5先行者学习网
} else if((xI >= 2 && xI < 3) ||(xI >= -2 && xI < -1)) { SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_matrix_tmp = zIndex_matrix[0][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[0][1] = zIndex_matrix[2][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[2][1] = zIndex_matrix_tmp; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix_tmp = zIndex_matrix[1][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][1] = zIndex_matrix_behind; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix_behind = zIndex_matrix_tmp; SRLHTML5中文学习网 - HTML5先行者学习网
} else if((xI >= 3 && xI < 4) ||(xI >= -1 && xI < 0)) { SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_matrix_tmp = zIndex_matrix[0][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[0][1] = zIndex_matrix_behind; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix_behind = zIndex_matrix[2][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[2][1] = zIndex_matrix[1][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][1] = zIndex_matrix_tmp; SRLHTML5中文学习网 - HTML5先行者学习网
} SRLHTML5中文学习网 - HTML5先行者学习网
if((yI > 0 && yI <= 1) ||(yI > -4 && yI <= -3)) { SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_matrix_tmp = zIndex_matrix[1][0]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][0] = zIndex_matrix_behind; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix_behind = zIndex_matrix[1][2]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][2] = zIndex_matrix[1][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][1] = zIndex_matrix_tmp; SRLHTML5中文学习网 - HTML5先行者学习网
} else if((yI > 1 && yI <= 2) ||(yI > -3 && yI <= -2)) { SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_matrix_tmp = zIndex_matrix[1][0]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][0] = zIndex_matrix[1][2]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][2] = zIndex_matrix_tmp; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix_tmp = zIndex_matrix[1][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][1] = zIndex_matrix_behind; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix_behind = zIndex_matrix_tmp; SRLHTML5中文学习网 - HTML5先行者学习网
} else if((yI > 2 && yI <= 3) ||(yI > -2 && yI <= -1)) { SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_matrix_tmp = zIndex_matrix[1][0]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][0] = zIndex_matrix[1][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][1] = zIndex_matrix[1][2]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][2] = zIndex_matrix_behind; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix_behind = zIndex_matrix_tmp; SRLHTML5中文学习网 - HTML5先行者学习网
} else if((yI > 3 && yI <= 4) ||(yI > -1 && yI <= 0)) { SRLHTML5中文学习网 - HTML5先行者学习网
} SRLHTML5中文学习网 - HTML5先行者学习网
SRLHTML5中文学习网 - HTML5先行者学习网
if((zI > 0 && zI <= 1) ||(zI > -4 && zI <= -3)) { SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_matrix_tmp = zIndex_matrix[0][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[0][1] = zIndex_matrix[1][0]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][0] = zIndex_matrix[2][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[2][1] = zIndex_matrix[1][2]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][2] = zIndex_matrix_tmp; SRLHTML5中文学习网 - HTML5先行者学习网
} else if((zI > 1 && zI <= 2) ||(zI > -3 && zI <= -2)) { SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_matrix_tmp = zIndex_matrix[0][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[0][1] = zIndex_matrix[2][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[2][1] = zIndex_matrix_tmp; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix_tmp = zIndex_matrix[1][0]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][0] = zIndex_matrix[1][2]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][2] = zIndex_matrix_tmp; SRLHTML5中文学习网 - HTML5先行者学习网
} else if((zI > 2 && zI <= 3) ||(zI > -2 && zI <= -1)) { SRLHTML5中文学习网 - HTML5先行者学习网
var zIndex_matrix_tmp = zIndex_matrix[0][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[0][1] = zIndex_matrix[1][2]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][2] = zIndex_matrix[2][1]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[2][1] = zIndex_matrix[1][0]; SRLHTML5中文学习网 - HTML5先行者学习网
zIndex_matrix[1][0] = zIndex_matrix_tmp; SRLHTML5中文学习网 - HTML5先行者学习网
} else if((zI > 3 && zI <= 4) ||(zI > -1 && zI <= 0)) { SRLHTML5中文学习网 - HTML5先行者学习网
} SRLHTML5中文学习网 - HTML5先行者学习网
//赋值zIndex SRLHTML5中文学习网 - HTML5先行者学习网
eval(zIndex_matrix[0][1]+"="+zIndex_top_default); SRLHTML5中文学习网 - HTML5先行者学习网
eval(zIndex_matrix[1][0]+"="+zIndex_left_default); SRLHTML5中文学习网 - HTML5先行者学习网
eval(zIndex_matrix[1][1]+"="+zIndex_front_default); SRLHTML5中文学习网 - HTML5先行者学习网
eval(zIndex_matrix[1][2]+"="+zIndex_right_default); SRLHTML5中文学习网 - HTML5先行者学习网
eval(zIndex_matrix[2][1]+"="+zIndex_bottom_default); SRLHTML5中文学习网 - HTML5先行者学习网
eval(zIndex_matrix_behind+"="+zIndex_behind_default); SRLHTML5中文学习网 - HTML5先行者学习网
//front SRLHTML5中文学习网 - HTML5先行者学习网
var transform_rotate_front = "perspective(500px) rotateX("+rotateX_front+ SRLHTML5中文学习网 - HTML5先行者学习网
"deg) rotateY("+rotateY_front+ SRLHTML5中文学习网 - HTML5先行者学习网
"deg) rotateZ("+rotateZ_front+"deg)"; SRLHTML5中文学习网 - HTML5先行者学习网
div_front.style.webkitTransform = transform_rotate_front; SRLHTML5中文学习网 - HTML5先行者学习网
div_front.style.zIndex = zIndex_front; SRLHTML5中文学习网 - HTML5先行者学习网
//behind SRLHTML5中文学习网 - HTML5先行者学习网
var transform_rotate_behind = "perspective(500px) rotateX("+rotateX_behind+ SRLHTML5中文学习网 - HTML5先行者学习网
"deg) rotateY("+rotateY_behind+ SRLHTML5中文学习网 - HTML5先行者学习网
"deg) rotateZ("+rotateZ_behind+"deg)"; SRLHTML5中文学习网 - HTML5先行者学习网
div_behind.style.webkitTransform = transform_rotate_behind; SRLHTML5中文学习网 - HTML5先行者学习网
div_behind.style.zIndex = zIndex_behind; SRLHTML5中文学习网 - HTML5先行者学习网
//left SRLHTML5中文学习网 - HTML5先行者学习网
var transform_rotate_left = "perspective(500px) rotateX("+rotateX_left+ SRLHTML5中文学习网 - HTML5先行者学习网
"deg) rotateZ("+rotateZ_left+ SRLHTML5中文学习网 - HTML5先行者学习网
"deg) rotateY("+rotateY_left+"deg)"; SRLHTML5中文学习网 - HTML5先行者学习网
div_left.style.webkitTransform = transform_rotate_left; SRLHTML5中文学习网 - HTML5先行者学习网
div_left.style.zIndex = zIndex_left; SRLHTML5中文学习网 - HTML5先行者学习网
//right SRLHTML5中文学习网 - HTML5先行者学习网
var transform_rotate_right = "perspective(500px) rotateX("+rotateX_right+ SRLHTML5中文学习网 - HTML5先行者学习网
"deg) rotateZ("+rotateZ_right+ SRLHTML5中文学习网 - HTML5先行者学习网
"deg) rotateY("+rotateY_right+"deg)"; SRLHTML5中文学习网 - HTML5先行者学习网
div_right.style.webkitTransform = transform_rotate_right; SRLHTML5中文学习网 - HTML5先行者学习网
div_right.style.zIndex = zIndex_right; SRLHTML5中文学习网 - HTML5先行者学习网
//top SRLHTML5中文学习网 - HTML5先行者学习网
var transform_rotate_top = "perspective(500px) rotateX("+rotateX_top+ SRLHTML5中文学习网 - HTML5先行者学习网
"deg) rotateZ("+rotateZ_top+ SRLHTML5中文学习网 - HTML5先行者学习网
"deg) rotateY("+rotateY_top+"deg)"; SRLHTML5中文学习网 - HTML5先行者学习网
div_top.style.webkitTransform = transform_rotate_top; SRLHTML5中文学习网 - HTML5先行者学习网
div_top.style.zIndex = zIndex_top; SRLHTML5中文学习网 - HTML5先行者学习网
//bottom SRLHTML5中文学习网 - HTML5先行者学习网
var transform_rotate_bottom = "perspective(500px) rotateX("+rotateX_bottom+ SRLHTML5中文学习网 - HTML5先行者学习网
"deg) rotateZ("+rotateZ_bottom+ SRLHTML5中文学习网 - HTML5先行者学习网
"deg) rotateY("+rotateY_bottom+"deg)"; SRLHTML5中文学习网 - HTML5先行者学习网
div_bottom.style.webkitTransform = transform_rotate_bottom; SRLHTML5中文学习网 - HTML5先行者学习网
div_bottom.style.zIndex = zIndex_bottom; SRLHTML5中文学习网 - HTML5先行者学习网
}; SRLHTML5中文学习网 - HTML5先行者学习网
//重置长方体的长、宽、高 SRLHTML5中文学习网 - HTML5先行者学习网
this.resize = function(new_long, new_width, new_height) SRLHTML5中文学习网 - HTML5先行者学习网
{ SRLHTML5中文学习网 - HTML5先行者学习网
long = new_long; SRLHTML5中文学习网 - HTML5先行者学习网
width = new_width; SRLHTML5中文学习网 - HTML5先行者学习网
height = new_height; SRLHTML5中文学习网 - HTML5先行者学习网
this.refresh(); SRLHTML5中文学习网 - HTML5先行者学习网
}; SRLHTML5中文学习网 - HTML5先行者学习网
//重置长方体的位置 SRLHTML5中文学习网 - HTML5先行者学习网
this.move = function(new_left,new_top) { SRLHTML5中文学习网 - HTML5先行者学习网
top = new_top; SRLHTML5中文学习网 - HTML5先行者学习网
left = new_left; SRLHTML5中文学习网 - HTML5先行者学习网
this.refresh(); SRLHTML5中文学习网 - HTML5先行者学习网
}; SRLHTML5中文学习网 - HTML5先行者学习网
} SRLHTML5中文学习网 - HTML5先行者学习网
SRLHTML5中文学习网 - HTML5先行者学习网
function transform() { SRLHTML5中文学习网 - HTML5先行者学习网
cuboid.resize(parseInt(document.getElementById("long").value), SRLHTML5中文学习网 - HTML5先行者学习网
parseInt(document.getElementById("width").value), SRLHTML5中文学习网 - HTML5先行者学习网
parseInt(document.getElementById("height").value)); SRLHTML5中文学习网 - HTML5先行者学习网
cuboid.move(parseInt(document.getElementById("left").value), SRLHTML5中文学习网 - HTML5先行者学习网
parseInt(document.getElementById("top").value)); SRLHTML5中文学习网 - HTML5先行者学习网
cuboid.rotate(parseInt(document.getElementById("rotatex").value), SRLHTML5中文学习网 - HTML5先行者学习网
parseInt(document.getElementById("rotatey").value), SRLHTML5中文学习网 - HTML5先行者学习网
parseInt(document.getElementById("rotatez").value)); SRLHTML5中文学习网 - HTML5先行者学习网
//cuboid.refresh(); SRLHTML5中文学习网 - HTML5先行者学习网
} SRLHTML5中文学习网 - HTML5先行者学习网
</script> SRLHTML5中文学习网 - HTML5先行者学习网
<div style="position:absolute;border:1px solid #333;top:240px;left:100px;width:1000px;height: 360px;"> SRLHTML5中文学习网 - HTML5先行者学习网
left:<input id="left" value="100"></input>pxSRLHTML5中文学习网 - HTML5先行者学习网
SRLHTML5中文学习网 - HTML5先行者学习网
top:<input id="top" value="50"></input>pxSRLHTML5中文学习网 - HTML5先行者学习网
SRLHTML5中文学习网 - HTML5先行者学习网
long:<input id="long" value="100"></input>pxSRLHTML5中文学习网 - HTML5先行者学习网
SRLHTML5中文学习网 - HTML5先行者学习网
width:<input id="width" value="60"></input>pxSRLHTML5中文学习网 - HTML5先行者学习网
SRLHTML5中文学习网 - HTML5先行者学习网
height:<input id="height" value="80"></input>pxSRLHTML5中文学习网 - HTML5先行者学习网
SRLHTML5中文学习网 - HTML5先行者学习网
rotateX: <input id="rotatex" value="0"></input>degSRLHTML5中文学习网 - HTML5先行者学习网
SRLHTML5中文学习网 - HTML5先行者学习网
rotateY: <input id="rotatey" value="0"></input>degSRLHTML5中文学习网 - HTML5先行者学习网
SRLHTML5中文学习网 - HTML5先行者学习网
rotateZ: <input id="rotatez" value="0"></input>degSRLHTML5中文学习网 - HTML5先行者学习网
SRLHTML5中文学习网 - HTML5先行者学习网
<input type="button" value="确定" onclick="transform()"></input>SRLHTML5中文学习网 - HTML5先行者学习网
SRLHTML5中文学习网 - HTML5先行者学习网
<label id="status"></label> SRLHTML5中文学习网 - HTML5先行者学习网
</div> SRLHTML5中文学习网 - HTML5先行者学习网
<script> SRLHTML5中文学习网 - HTML5先行者学习网
var cuboid = new cuboidModel(parseInt(document.getElementById("left").value), SRLHTML5中文学习网 - HTML5先行者学习网
parseInt(document.getElementById("top").value), SRLHTML5中文学习网 - HTML5先行者学习网
parseInt(document.getElementById("long").value), SRLHTML5中文学习网 - HTML5先行者学习网
parseInt(document.getElementById("width").value), SRLHTML5中文学习网 - HTML5先行者学习网
parseInt(document.getElementById("height").value)); SRLHTML5中文学习网 - HTML5先行者学习网
cuboid.init(); SRLHTML5中文学习网 - HTML5先行者学习网
</script> SRLHTML5中文学习网 - HTML5先行者学习网