首頁 web前端 H5教程 HTML5 transform三維立方體實現360無死角三維旋轉效果_html5教學技巧

HTML5 transform三維立方體實現360無死角三維旋轉效果_html5教學技巧

May 16, 2016 pm 03:47 PM
transform 三維 立方體

為了更好得掌握transform的精髓,所以決定完成三維立方體的模型,可以達到360無死角的立體旋轉效果。

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

原始碼直接貢獻啦:

複製程式碼
程式碼如下:


<script> <br />/**<br />* 本版本有下列問題: <br />* 三維旋轉的zIndex計算有問題 <br />* 仍欠缺多種模型,常見的包括:線、面、椎體、球體、橢球體等。 <br />*/ <br />function cuboidModel(left_init,top_init,long_init,width_init,height_init) <br />{ <br />{ <br />////// /////////////////////////////////// <br />//初始化私有變數<br />//// /////////////////////////////////// <br />//初始化長方體位置、大小<br />var left = left_init; <br />var top = top_init; <br />var long = long_init; <br />var width = width_init; <br />var height = height_init; <br />//初始化變換角度,認為var rotateX = 0; <br />var rotateY = 0; <br />var rotateZ = 0; <br />var zIndex = 0; <br />//定義長方體六個面的div對象<br />var div_front; >var div_behind; <br />var div_left; <br />var div_right; <br />var div_top; <br />var div_bottom; <br /><br />//////////////////////// //////////////////////// <br />//初始化長方體<br />///////////////// /////////////////////// <br />//依照初始位置建構六個面。 <br />this.init = function() { <br />//建立front div <br />div_front = document.createElement("div"); <br />div_front.className = "cuboid_side_div"; <br />divdiv_RML. = "div front"; <br />div_front.style.backgroundColor="#f1b2b2"; <br />document.body.appendChild(div_front); <br />//建立behind div <br />div_behind = document.createElement(" div"); <br />div_behind.className = "cuboid_side_div"; <br />div_behind.innerHTML = "div behind"; <br />div_behind.style.backgroundor="#bd91eb"; <br />div_behind.style.backgroundor="#bd91eb"; <br />> div_behind); <br />//建立left div <br />div_left = document.createElement("div"); <br />div_left.className = "cuboid_side_div"; <br />div_left.innerHTML = "divleftinnerHTML"; >div_left.style.backgroundColor="#64a3c3"; <br />document.body.appendChild(div_left); <br />//建立right div <br />div_right = document.createElement("div"); <br />div_right .className = "cuboid_side_div"; <br />div_right.innerHTML = "div right"; <br />div_right.style.backgroundColor="#78e797"; <br />document.body.appendChild(div_right);建立top div <br />div_top = document.createElement("div"); <br />div_top.className = "cuboid_side_div"; <br />div_top.innerHTML = "Col top"; <br />div_top.style.backgroundor="style. #e7db78"; <br />document.body.appendChild(div_top); <br />//建立bottom div <br />div_bottom = document.createElement("div"); <br />div_bottom.className = "cuboid_side_divcuboid <Ddiv""; 🎜>div_bottom.innerHTML = "div bottom"; <br />div_bottom.style.backgroundColor="#e79c78"; <br />document.body.appendChild(div_bottom); <br />this.refresh(); ; <br />//重繪<br />this.refresh = function() <br />{ <br />//定義div_front樣式<br />div_front.style.left = left "px"; <br />div_front.stylestyle .top = top "px"; <br />div_front.style.width = long "px"; <br />div_front.style.height = height "px"; <br />div_front.style.webkitTransformOrigin = "50% 50% " ((-1)*width / 2) "px"; <br />//定義div_behind樣式<br />div_behind.style.left = left "px"; <br />div_behind.style.top = top "px" ; <br />div_behind.style.width = div_front.style.width; <br />div_behind.style.height = div_front.style.height; <br />div_behind.style.webkitTransformOrigin = "50%; <br />div_behind.style.webkitTransformOrigin = "50% 50% "(-1150% "(-1 )*width / 2) "px"; <br />//定義div_left樣式<br />div_left.style.left = left ((long - height) / 2) "px"; <br />div_left.style.top = top ((height - width) / 2) "px"; <br />div_left.style.width = height "px"; <br />div_left.style.height = width "px"; <br />divkit_left.style.webkitTransformOinrigin = "50% 50% " ((-1) * long /2 ) "px"; <br />//定義div_right樣式<br />div_right.style.left = div_left.style.left; <br />div_right.style .top = div_left.style.top; <br />div_right.style.width = div_left.style.width; <br />div_right.style.height = div_left.style.height; <br />div_right.style.webkitTransformOrigin = "50>div_right.style.webkitTransformOrigin = "50 % 50% " ((-1) * long /2 ) "px"; <br />//定義div_top樣式<br />div_top.style.left = left "px"; <br />div_top.style.top = top ((height - width)/ 2) "px"; <br />div_top.style.width = long "px"; <br />div_top.style.height = width "px"; <br />div_top.style.webkitTransformOrigin = "50% 50% " ((-1) * height /2 ) "px"; <br />//定義div_bottom樣式<br />div_bottom.style.left = div_top.style.left; <br />div_bottom.style. top = div_top.style.top; <br />div_bottom.style.width = div_top.style.width; <br />div_bottom.style.height = div_top.style.height; <br />div_bottom.style.webkitTransformOrigin = "50% 50% " ((-1) * height /2 ) "px"; <br />this.rotate(rotateX,rotateY,rotateZ); <br />}; <br />//旋轉立方體<br />this.rotate = function(x,y,z) { <br />rotateX = x; <br />rotateY = y; <br />rotateZ = z; <br />var rotateX_front = rotateX; <br />varrotateY_front = 電影Y; <br />varrotateZ_front=rotateZ; <br />//可以這個面手機最地 <br />varrotateX_behind =rotateX_front 180; <br />varrotateY_behind=rotateY_front*(-1); <br />varrotateZ_behind=rotateZ_front*(-1); <br />varrotateX_top=rotateX_front 90; <br />varrotateY_top=rotateZ_front; <br />varrotateZ_top=rotateY_front*(-1); <br />varrotateX_bottom=rotateX_front-90; <br />varrotateY_bottom=rotateZ_front*(-1); <br />varrotateZ_bottom=rotateY_front; <br />varrotateX_left=rotateX_front 90; <br />varrotateY_left=rotateZ_front - 90; <br />varrotateZ_left=rotateY_front*(-1); <br />varrotateX_right=rotateX_front 90; <br />varrotateY_right=rotateZ_front 90; <br />varrotateZ_right=rotateY_front*(-1); <br />// 可以下載面的z長電視劇<br />var zIndex_front_default = -1; <br />var zIndex_behind_default = -6; <br />var zIndex_top_default = -5; <br />var zIndex_bottom_default = -2; <br />var zIndex_left_default = -4; <br />var zIndex_right_default = -3; <br />var xI = (rotateX_front / 90) % 4; <br />var yI = (rotateY_front / 90) % 4; <br />var zI = (rotateZ_front / 90) % 4; <br />var zIndex_matrix = new Array(); <br />for(var i = 0; i < 3;i ) { <br />zIndex_matrix.push(new Array()); <br />} <br />zIndex_matrix = [["","zIndex_top",""], <br />["zIndex_left","zIndex_front","zIndex_right"], <br />["zIndex_front","zIndex_right"], <br />[" “”]]; <br />var zIndex_matrix_behind = "zIndex_behind"; <br />//計算zIndex <br />if((xI >= 0 && xI < 1) ||(xI >= -4 && xI < -3)) { <br />} else if(( xI >= 1 && xI < 2) ||(xI >= -3 && xI < -2)) { <br />var zIndex_matrix_tmp = zIndex_matrix[0][1]; <br />zIndex_matrix[0][1] = zIndex_matrix[1][1]; <br />zIndex_matrix[1][1] = zIndex_matrix[1][2]; <br />zIndex_matrix[1][2] = zIndex_matrix_behind; <br />zIndex_matrix_behind = zIndex_matrix_tmp; <br />} else if((xI >= 2 && xI < 3) ||(xI >= -2 && xI < -1)) { <br />var zIndex_matrix_tmp = zIndex_matrix[0][1] ; <br />zIndex_matrix[0][1] = zIndex_matrix[2][1]; <br />zIndex_matrix[2][1] = zIndex_matrix_tmp; <br />zIndex_matrix_tmp = zIndex_matrix[1][1]; <br />zIndex_matrix[1][1] = zIndex_matrix_behind; <br />zIndex_matrix_behind = zIndex_matrix_tmp; <br />} else if((xI >= 3 && xI < 4) ||(xI >= -1 && xI < 0)) { <br />var zIndex_matrix_tmp = zIndex_matrix[0][1]; <br />zIndex_matrix[0][1] = zIndex_matrix_behind; <br />zIndex_matrix_behind = zIndex_matrix[2][1]; <br />zIndex_matrix[2][1] = zIndex_matrix[1][1]; <br />zIndex_matrix[1][1] = zIndex_matrix_tmp; <br />} <br />if((yI > 0 && yI <= 1) ||(yI > -4 && yI <= -3)) { <br />var zIndex_matrix_tmp = zIndex_matrix[1][ 0]; <br />zIndex_matrix[1][0] = zIndex_matrix_behind; <br />zIndex_matrix_behind = zIndex_matrix[1][2]; <br />zIndex_matrix[1][2] = zIndex_matrix[1][1]; <br />zIndex_matrix[1][1] = zIndex_matrix_tmp; <br />} else if((yI > 1 && yI <= 2) ||(yI > -3 && yI <= -2)) { <br />var zIndex_matrix_tmp = zIndex_matrix[1][0] ; <br />zIndex_matrix[1][0] = zIndex_matrix[1][2]; <br />zIndex_matrix[1][2] = zIndex_matrix_tmp; <br />zIndex_matrix_tmp = zIndex_matrix[1][1]; <br />zIndex_matrix[1][1] = zIndex_matrix_behind; <br />zIndex_matrix_behind = zIndex_matrix_tmp; <br />} else if((yI > 2 && yI <= 3) ||(yI > -2 && yI <= -1)) { <br />var zIndex_matrix_tmp = zIndex_matrix[1][0] ; <br />zIndex_matrix[1][0] = zIndex_matrix[1][1]; <br />zIndex_matrix[1][1] = zIndex_matrix[1][2]; <br />zIndex_matrix[1][2] = zIndex_matrix_behind; <br />zIndex_matrix_behind = zIndex_matrix_tmp; <br />} else if((yI > 3 && yI <= 4) ||(yI > -1 && yI <= 0)) { <br />} <br /><br />if((zI > 0 && zI <= 1) ||(zI > -4 && zI <= -3)) { <br />var zIndex_matrix_tmp = zIndex_matrix[0][1]; <br />zIndex_matrix[0][1] = zIndex_matrix[1][0]; <br />zIndex_matrix[1][0] = zIndex_matrix[2][1]; <br />zIndex_matrix[2][1] = zIndex_matrix[1][2]; <br />zIndex_matrix[1][2] = zIndex_matrix_tmp; <br />} else if((zI > 1 && zI <= 2) ||(zI > -3 && zI <= -2)) { <br />var zIndex_matrix_tmp = zIndex_matrix[0][1] ; <br />zIndex_matrix[0][1] = zIndex_matrix[2][1]; <br />zIndex_matrix[2][1] = zIndex_matrix_tmp; <br />zIndex_matrix_tmp = zIndex_matrix[1][0]; <br />zIndex_matrix[1][0] = zIndex_matrix[1][2]; <br />zIndex_matrix[1][2] = zIndex_matrix_tmp; <br />} else if((zI > 2 && zI <= 3) ||(zI > -2 && zI <= -1)) { <br />var zIndex_matrix_tmp = zIndex_matrix[0][1] ; <br />zIndex_matrix[0][1] = zIndex_matrix[1][2]; <br />zIndex_matrix[1][2] = zIndex_matrix[2][1]; <br />zIndex_matrix[2][1] = zIndex_matrix[1][0]; <🎜>zIndex_matrix[1][0] = zIndex_matrix_tmp; <br />} else if((zI > 3 && zI <= 4) ||(zI > -1 && zI <= 0)) { <br />} <br />//赋值zIndex <br /> eval(zIndex_matrix[0][1] "= zIndex_top_default); <br />eval(zIndex_matrix[1][0] "= zIndex_left_default); <br />eval(zIndex_matrix[1][1] "= zIndex_front_default); <br />eval(zIndex_matrix[1][2] "= zIndex_right_default); <br />eval(zIndex_matrix[2][1] "= zIndex_bottom_default); <br />eval(zIndex_matrix_behind "= zIndex_behind_default); <br />//front <br />vartransform_rotate_front = "perspective(500px) 回転X(" 回転X_フロント <br />"度) 回転Y(" 回転Y_フロント <br />"度) 回転Z(" 回転Z_フロント "度)"; <br />div_front.style.webkitTransform =transform_rotate_front; <br />div_front.style.zIndex = zIndex_front; <br />//behind <br />vartransform_rotate_behind = "perspective(500px)rotateX("rotateX_behind<br />"度)rotateY("rotateY_behind <br />"度)rotateZ("rotateZ_behind "度)"; <br />div_behind.style.webkitTransform =transform_rotate_behind; <br />div_behind.style.zIndex = zIndex_behind; <br />//left <br />vartransform_rotate_left = "perspective(500px)rotateX("rotateX_left <br />"度)rotateZ("rotateZ_left <br />"度)rotateY("rotateY_left "度)"; <br />div_left.style.webkitTransform =transform_rotate_left; <br />div_left.style.zIndex = zIndex_left; <br />//right <br />vartransform_rotate_right = "perspective(500px)rotateX("rotateX_right <br />"度)rotateZ("rotateZ_right <br />"度)rotateY("rotateY_right "度)"; <br />div_right.style.webkitTransform =transform_rotate_right; <br />div_right.style.zIndex = zIndex_right; <br />//top <br />vartransform_rotate_top = "perspective(500px) 回転X(" 回転X_トップ <br />"度) 回転Z(" 回転Z_トップ <br />"度) 回転Y(" 回転Y_トップ "度)"; <br />div_top.style.webkitTransform =transform_rotate_top; <br />div_top.style.zIndex = zIndex_top; <br />//bottom <br />vartransform_rotate_bottom = "perspective(500px)rotateX("rotateX_bottom <br />"度)rotateZ("rotateZ_bottom <br />"度)rotateY("rotateY_bottom "度)"; <br />div_bottom.style.webkitTransform =transform_rotate_bottom; <br />div_bottom.style.zIndex = zIndex_bottom; <br />}; <br />//长方体の长、宽、高 <br />this.resize = function(new_long, new_width, new_height) <br />{ <br />long = new_long; <br />幅 = 新しい幅; <br />高さ = 新しい高さ; <br />this.refresh(); <br />}; <br />//长方体の位置を重ね置きします <br />this.move = function(new_left,new_top) { <br />top = new_top; <br />left = new_left; <br />this.refresh(); <br />}; <br />} <br /><br />function transform() { <br />cuboid.resize(parseInt(document.getElementById("long").value), <br />parseInt(document.getElementById("width"). value)、<br />parseInt(document.getElementById("height").value)); <br />cuboid.move(parseInt(document.getElementById("left").value), <br />parseInt(document.getElementById("top").value)); <br />cuboid.rotate(parseInt(document.getElementById("rotatex").value), <br />parseInt(document.getElementById("rotatey").value), <br />parseInt(document.getElementById("rotatez" )。価値)); <br />//cuboid.refresh(); <br />} <br /></script>

左:px

上:< ;/input>px

long:px

width:px

高さ:px

rotateX: deg

rotateY: deg

rotateZ: deg






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();

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何使用CSS實現元素的旋轉背景圖動畫效果 如何使用CSS實現元素的旋轉背景圖動畫效果 Nov 21, 2023 am 09:05 AM

如何使用CSS實現元素的旋轉背景圖動畫效果背景圖動畫效果可以增加網頁的視覺吸引力和使用者體驗。本文將介紹如何使用CSS實現元素的旋轉背景圖動畫效果,並提供具體的程式碼範例。首先,我們需要準備一張背景圖,可以是任何你喜歡的圖片,例如一張太陽或電風扇的圖片。將該圖片儲存並命名為“bg.png”。接下來,建立一個HTML文件,並在文件中新增一個div元素,將其設定為

Vue中如何對圖片進行壓縮和格式轉換? Vue中如何對圖片進行壓縮和格式轉換? Aug 25, 2023 pm 11:06 PM

Vue中如何對圖片進行壓縮和格式轉換?在前端開發中,經常會遇到需要對圖片進行壓縮和格式轉換的需求。特別是在行動端的開發中,為了提高頁面載入速度和節省使用者流量,對圖片進行壓縮和格式轉換是很關鍵的。而在Vue框架中,我們可以透過一些工具庫來實現圖片的壓縮和格式轉換。使用compressor.js庫進行壓縮compressor.js是一款用於壓縮圖片的JavaS

CSS 3D 視圖屬性解讀:transform 和 perspective CSS 3D 視圖屬性解讀:transform 和 perspective Oct 24, 2023 am 08:11 AM

CSS3D視圖屬性解讀:transform和perspective,需要具體程式碼範例引言:在現代網頁設計中,3D效果已經成為了一個非常流行的元素。透過CSS的transform和perspective屬性,我們可以輕鬆地為網頁添加3D視覺效果,使頁面更加生動和吸引人。本文將對這兩個屬性進行解讀,並提供具體的程式碼範例。一、transform屬性:transf

Vue中如何實現圖片的動畫和漸層效果? Vue中如何實現圖片的動畫和漸層效果? Aug 18, 2023 pm 06:00 PM

Vue中如何實現圖片的動畫和漸層效果? Vue是一種用於建立使用者介面的漸進式框架,它可以輕鬆實現動畫和漸進效果。在本文中,將介紹如何使用Vue來實現圖片的動畫和漸變效果,並提供一些程式碼範例。一、使用Vue的過渡效果實現圖片動畫Vue提供了過渡效果的內建指令,可以輕鬆地在HTML元素上添加動畫效果。使用過渡效果時,可以包裝圖片元素,並在元素上新增過渡指令。範例

CSS 旋轉屬性探索:transform 和 rotate CSS 旋轉屬性探索:transform 和 rotate Oct 21, 2023 am 09:46 AM

CSS旋轉屬性探索:transform和rotate引言:在現代網頁設計中,我們經常需要為元素添加一些特殊的效果,以增加頁面的吸引力和使用者體驗。其中,元素的旋轉是一種常見的效果,可以幫助我們創造出獨特的視覺效果。在CSS中,我們可以使用transform屬性以及其旋轉屬性rotate來實現元素的旋轉。本文將探討這兩個屬性的使用方法,並提供代

CSS 環形佈局屬性詳解:border-radius 與 transform CSS 環形佈局屬性詳解:border-radius 與 transform Oct 21, 2023 am 11:46 AM

CSS環形佈局屬性詳解:border-radius和transform一、簡介在網頁設計中,環形佈局常用於建立圓形的元素,如按鈕、頭像等。實作環形佈局的兩個關鍵CSS屬性是border-radius和transform。本文將詳細介紹如何使用border-radius和transform屬性來建立環形佈局,並提供具體的程式碼範例。二、border-ra

如何透過純CSS實現圖片的立方體轉動效果的方法和技巧 如何透過純CSS實現圖片的立方體轉動效果的方法和技巧 Oct 21, 2023 am 09:36 AM

如何透過純CSS實現圖片的立方體轉動效果的方法和技巧在現代網頁設計中,添加一些酷炫的效果是非常重要的,而利用CSS實現立方體轉動效果是一個非常有趣而具有挑戰性的任務。本文將介紹一種透過純CSS實現圖片的立方體轉動效果的方法和技巧,並提供一些具體的程式碼範例。首先,我們需要一個基本的HTML結構,包含一個容器元素和六個面元素,每個面元素都包含一張圖片。 &lt;d

三維動態人臉辨識是辨識什麼 三維動態人臉辨識是辨識什麼 Dec 11, 2020 am 11:19 AM

三維動態人臉辨識是辨識人的骨骼輪廓;三維動態人臉辨識實現三維人臉建模,人臉建模即是根據輸入的人臉影像,如眼睛、鼻尖、嘴角點、眉毛以及人臉各部件輪廓點等,自動定位出臉部關鍵特徵點。

See all articles