CSS3 3D立方體效果示例-transform也不過如此
CSS3系列已經(jīng)學(xué)習(xí)了一段時間了,還獲得了較多網(wǎng)友的支持,在此謝過各位,你們的支持是我寫文章最大的動力^_^。
那么這一篇文章呢,主要是通過一個3D立方體的效果實例來深入了解css3的transform屬性,下面是這個實例的截圖,加上動畫還能旋轉(zhuǎn)起來喲,是不是很酷炫?換上你喜歡的女生的照片,就可以大膽的撩妹了,哈哈!

初識transform
顧名思義:變換。就可以想到它可以做很多很多的事情了,這個屬性有很多的值,在這里簡單列舉一下:
- translate(x,y)、translateX(x)、translateY(y)、translateZ(z)、translate3d(x,y,z):定義位置的移動距離。
- scale(x,y)、scaleX(x)、scaleY(y)、scaleZ(z)、scale3d(x,y,z):定義元素的縮放比例。
- rotate(angle)、rotateX(a)、rotateY(a)、rotateZ(a)、rotate3d(x,y,z,angle):定義元素的旋轉(zhuǎn)角度。
- skew(x-angle,y-angle)、skewX(angle)、skewY(angle):定義元素的傾斜角度。
3D效果的認知

我們可以看到這是一個三維的空間圖,不要被第一眼的復(fù)雜感嚇到,仔細分解一下其實還是很清晰的:反正就X軸、Y軸、Z軸三個方向嘛。
想象一下,假如你現(xiàn)在坐在電腦面前,電腦屏幕中心是原點,原點往右就是X軸正方向,往下就是Y軸正方向,往屏幕前方(也就是往人臉)的方向就是Z軸的正方向了。把坐標軸的方向搞清楚了,上面的方法就能正確的使用了。
如果你覺得上面的解釋仍然太過于枯燥抽象,那就來舉個生活中的例子來對應(yīng)一下三個rotate屬性(rotateX、rotateY、rotateZ)吧:
如下圖:體操表演-繞著X軸旋轉(zhuǎn)就是rotateX(單杠就是X軸)

如下圖:鋼管舞表演-繞著Y軸旋轉(zhuǎn)就是rotateY(鋼管就是Y軸)

如下圖:轉(zhuǎn)盤旋轉(zhuǎn)-繞著Z軸在旋轉(zhuǎn)就是rotateZ(想象有一根繩子從轉(zhuǎn)盤的中心穿過,圖不好找==)

perspective屬性
perspective的中文意思是:透視,視角!該屬性用來激活一個3D空間。
當為元素定義perspective屬性時,其子元素都會獲得透視效果(使用了3D變換的元素)。所以一般來說perspective屬性都應(yīng)用在父元素上,我們可以把這個父元素稱為舞臺元素。
只看解釋可能還是難以理解,我們還是用實例說話吧:

從上圖可以看出,div1是div2的父元素,開始我們給div2元素增加旋轉(zhuǎn)transform:rotateX(50deg)的時候,只感覺div2在平面上被’壓縮’了,沒有3D的效果,然后當我們給父元素div1增加perspective: 150px;的時候,立馬就能看到3D的效果了,感受到他的神奇之處了吧。
另外,perspective的取值也一直是個謎,經(jīng)過我的多次查閱和測試,得出了一下幾個結(jié)論:
- 取值為none或不設(shè)置,就沒有3D空間。
- 取值越小,3D效果就越明顯,也就是你的眼睛越靠近真3D。
- 貌似當取值為元素的寬度時,視覺效果比較好。
transform-style
transform-style指定嵌套元素如何在3D空間中呈現(xiàn)。
transform-style: flat | preserve-3d
flat是默認值,表示所有子元素在2D平面呈現(xiàn);preserve-3d表示所有子元素在3D空間中呈現(xiàn)。因此,我們想要實現(xiàn)一些3D效果的時候,transform-style: preserve-3d是少不了的。一般而言,該聲明應(yīng)用在3D變換的兄弟元素們的父元素上,我們可以叫它容器。
transform-origin
transform-origin用來改變元素的原點位置。
它的取值方式有很多種,下面我們通過實例(把背景為黃色的div順時針旋轉(zhuǎn)45deg)來介紹一下它的常用取值方式:
transform-origin:center(默認值,等價于:center center/ 50% 50%)

transform-origin:top(等價于:top center/center top)

transform-origin:bottom(等價于:bottom center/center bottom)

transform-origin:right(等價于:right center/center right)

transform-origin:left(等價于:left center/center left)

transform-origin:top left(等價于:left top)

同理,還可以設(shè)置為:transform-origin:top right(右上角為原點)、transform-origin:bottom right(右下角為原點)、transform-origin:bottom left(左下角為原點)
繪制立方體效果
各位看官等不及了吧,講了那么多’廢話’,本篇文章的重頭戲終于來了!
dom結(jié)構(gòu)
<div class="rect-wrap"> //舞臺元素,設(shè)置perspective,讓其子元素獲得透視效果。
<div class="container"> //容器,設(shè)置transform-style: preserve-3d,讓其子元素在3D空間呈現(xiàn)
<div class="top slide"></div> //立方體的六個面
<div class="bottom slide"></div>
<div class="left slide"></div>
<div class="right slide"></div>
<div class="front slide"></div>
<div class="back slide"></div>
</div>
</div>
css代碼
對于舞臺元素
.rect-wrap {
position: relative;
perspective: 1600px;
}
對于容器
.container {
width: 800px;
height: 800px;
transform-style: preserve-3d;
transform-origin: 50% 50% 200px; //設(shè)置3d空間的原點在平面中心再向Z軸移動200px的位置
}
立方體的每個面
.slide {
width: 400px;
height: 400px;
position: absolute; //定位
}
立方體頂面
.top {
left: 200px;
top: -200px;
transform: rotateX(-90deg);
transform-origin: bottom;
}
立方體底面
.bottom {
left: 200px;
bottom: -200px;
transform: rotateX(90deg);
transform-origin: top;
}
立方體左面
.left {
left: -200px;
top: 200px;
transform: rotateY(90deg);
transform-origin: right;
}
立方體右面
.right {
left: 600px;
top: 200px;
transform: rotateY(-90deg);
transform-origin: left;
}
立方體前面
.front {
left: 200px;
top: 200px;
transform: translateZ(400px); //立方體前面正對著屏幕,所以不用旋轉(zhuǎn),只需向Z軸前移動距離
}
立方體后面
.back {
left: 200px;
top: 200px;
transform: translateZ(0); //立方體后面正對著屏幕,所以不用旋轉(zhuǎn),只需向Z軸后移動距離
}
最后別忘了給每個不同面加上圖片,位置什么的再稍微調(diào)一下,這個酷炫的立方體就大功告成了。
加動畫
最后我們還想要這個立方體自己動起來,我定義了一個動畫,看官們可以試試。
@keyframes rotate-frame {
0% {
transform: rotateX(0deg) rotateY(0deg);
}
10% {
transform: rotateX(0deg) rotateY(180deg);
}
20% {
transform: rotateX(-180deg) rotateY(180deg);
}
30% {
transform: rotateX(-360deg) rotateY(180deg);
}
40% {
transform: rotateX(-360deg) rotateY(360deg);
}
50% {
transform: rotateX(-180deg) rotateY(360deg);
}
60% {
transform: rotateX(90deg) rotateY(180deg);
}
70% {
transform: rotateX(0) rotateY(180deg);
}
80% {
transform: rotateX(90deg) rotateY(90deg);
}
90% {
transform: rotateX(90deg) rotateY(0);
}
100% {
transform: rotateX(0) rotateY(0);
}
}
最后把這個動畫用到這個立方體的容器元素上,就OK了:
.container{
animation: rotate-frame 30s linear infinite;
}
需要代碼的同學(xué)可以點擊此處下載:demo
總結(jié)
總而言之,在我學(xué)習(xí)CSS3的過程中,見到了不少的新特性,也學(xué)會了如何使用,但是我想說的是我們不管要學(xué)會怎么使用,更要去理解每一行代碼為什么產(chǎn)生對應(yīng)的效果,特別是對于3D transform,我們要從根本去理解了3D空間,才能更好的去掌握它的每一個屬性值能夠帶來的效果。
這篇文章內(nèi)容稍微有點多,自己記錄這篇文章的同時又對這個效果學(xué)習(xí)鞏固了一篇,還是蠻開心噠。同時也希望能對各位看官在以后學(xué)習(xí)3D transform的道路上起到一點點作用!
相關(guān)文章

純css3基于transform實現(xiàn)的彈簧動畫特效源碼
這是一款純css3基于transform實現(xiàn)的彈簧動畫特效源碼,界面呈現(xiàn)出層疊圓環(huán)上下浮動的動畫效果,類似于彈簧上下運動或者水面波紋上下抖動的視覺效果2016-12-02CSS3中動畫屬性transform、transition和animation屬性的區(qū)別
最近在項目中用到了CSS3中的動畫屬性。無奈對于css3幾個新加的屬性不太熟悉,常常容易搞混。所以從網(wǎng)站研究了點資料,總結(jié)一下,方便有需要的朋友們可以參考學(xué)習(xí)。2016-09-25- 這篇文章主要為大家詳細介紹了CSS3中Transform動畫屬性用法,教大家如何實現(xiàn)2D transform變換、3D transform變換,感興趣的小伙伴們可以參考一下2016-07-04
css3 transform及原生js實現(xiàn)鼠標拖動3D立方體旋轉(zhuǎn)
這篇文章主要為大家詳細介紹了css3 transform及原生js實現(xiàn)鼠標拖動3D立方體旋轉(zhuǎn)的相關(guān)資料,感興趣的小伙伴們可以參考一下2016-06-20CSS3 transform(變形)和transform-origin(變形原點)調(diào)試工具
這是一款可在線調(diào)試CSS3 transform(變形)和transform-origin(變形原點)的工具.可根據(jù)左側(cè)的滑塊改變參數(shù)同時右側(cè)實時顯示預(yù)覽效果,且預(yù)覽效果的下方能夠同時生成對應(yīng)的css32016-05-31- transform通過一組函數(shù)實現(xiàn)了對盒子大小、位置、角度的2D或者3D變換,這里我們主要來深入解讀CSS3中transform變換模型的渲染,尤其是關(guān)注web端3D渲染動畫的朋友千萬不要錯過2016-05-27
CSS3中設(shè)置3D變形的transform-style屬性詳解
transform-style經(jīng)常被用來做三維空間坐標系中的圖形變換,下面我們就來看看CSS3中設(shè)置3D變形的transform-style屬性詳解,需要的朋友可以參考下2016-05-23CSS3的常見transformation圖形變化用法小結(jié)
這篇文章主要介紹了CSS3的常見transformation圖形變化用法小結(jié),共整理了旋轉(zhuǎn)、縮放、平移、傾斜以及矩陣的使用方法,需要的朋友可以參考下2016-05-13CSS3中的transform屬性進行2D和3D變換的基本用法
這篇文章主要介紹了使用CSS3中的transform屬性進行2D和3D變換的基本用法,文中同時介紹了使用perspective-origin定義初始位置的方法,需要的朋友可以參考下2016-05-12實例講解CSS3中Transform的perspective屬性的用法
這篇文章主要介紹了CSS3中Transform的perspective屬性的用法,文中詳細講解了使用perspective屬性對圖片進行3D變換的操作,需要的朋友可以參考下2016-04-22


