中文亚洲精品无码_熟女乱子伦免费_人人超碰人人爱国产_亚洲熟妇女综合网

當(dāng)前位置: 首頁 > news >正文

做站群一個(gè)網(wǎng)站多少錢網(wǎng)站建設(shè)的整體流程有哪些

做站群一個(gè)網(wǎng)站多少錢,網(wǎng)站建設(shè)的整體流程有哪些,用帝國軟件做網(wǎng)站的心得,包頭企業(yè)網(wǎng)站建設(shè)Transform:對(duì)元素進(jìn)行變形; Transition:對(duì)元素某個(gè)屬性或多個(gè)屬性的變化,進(jìn)行控制(時(shí)間等),類似flash的補(bǔ)間動(dòng)畫。但只有兩個(gè)關(guān)鍵貞。開始,結(jié)束。 Animation:對(duì)元素某個(gè)屬…

Transform:對(duì)元素進(jìn)行變形;
Transition:對(duì)元素某個(gè)屬性或多個(gè)屬性的變化,進(jìn)行控制(時(shí)間等),類似flash的補(bǔ)間動(dòng)畫。但只有兩個(gè)關(guān)鍵貞。開始,結(jié)束。
Animation:對(duì)元素某個(gè)屬性或多個(gè)屬性的變化,進(jìn)行控制(時(shí)間等),類似flash的補(bǔ)間動(dòng)畫??梢栽O(shè)置多個(gè)關(guān)鍵貞。
?
Transition與Animation:
transition需要觸發(fā)一個(gè)事件 ,而animation在不需要觸發(fā)任何事件的情況下也可以顯式的隨著時(shí)間變化來改變?cè)?素css的屬性值,從而達(dá)到一種動(dòng)畫的效果。

transform 2D/3D 轉(zhuǎn)換屬性向元素應(yīng)用 2D 或 3D 轉(zhuǎn)換。該屬性允許我們對(duì)元素進(jìn)行旋轉(zhuǎn)、縮放、移動(dòng)或傾斜。

一.CSS3 2D 轉(zhuǎn)換

通過 CSS3 轉(zhuǎn)換,我們能夠?qū)υ剡M(jìn)行移動(dòng)、縮放、轉(zhuǎn)動(dòng)、拉長或拉伸。

1.2D Transform轉(zhuǎn)換屬性

屬性

描述

CSS

transform

向元素應(yīng)用 2D 或 3D 轉(zhuǎn)換。

3

transform-origin

允許你改變被轉(zhuǎn)換元素的位置。

3

2.2D Transform 方法

函數(shù)

描述

實(shí)例

試一試

轉(zhuǎn)換

translateX(n)

translateY(n)

沿著 X 或Y 軸移動(dòng)元素。

translate(x,y)

沿著 X 和 Y 軸移動(dòng)元素。

值 translate(50px,100px) 把元素從左側(cè)移動(dòng) 50 像素,從頂端移動(dòng) 100 像素。

div{
transform: translate(50px,100px);
-ms-transform: translate(50px,100px);??????? /* IE 9 */
-webkit-transform: translate(50px,100px); /* Safari and Chrome */
-o-transform: translate(50px,100px);??????? /* Opera */
-moz-transform: translate(50px,100px);???? /* Firefox */
}

??試一試??

縮放

scaleX(n)

scaleY(n)

改變?cè)氐膶捇蚋叨取?/p>

scale(x,y)

改變?cè)氐膶挾群透叨取?/p>

值 scale(2,4) 把寬度轉(zhuǎn)換為原始尺寸的 2 倍,把高度轉(zhuǎn)換為原始高度的 4 倍。

div{
transform: scale(2,4);
-ms-transform: scale(2,4);??? /* IE 9 */
-webkit-transform: scale(2,4);??? /* Safari 和 Chrome */
-o-transform: scale(2,4);??? /* Opera */
-moz-transform: scale(2,4);??? /* Firefox */
}

??試一試??

定義 2D 旋轉(zhuǎn)

rotate(angle)

在參數(shù)中規(guī)定角度。turn是圈,1turn = 360deg;另外還有弧度rad,2πrad = 1turn = 360deg。如,transform:rotate(2turn); //旋轉(zhuǎn)兩圈

值 rotate(30deg) 把元素順時(shí)針旋轉(zhuǎn) 30 度。

div{
transform: rotate(30deg);
-ms-transform: rotate(30deg);??????? /* IE 9 */
-webkit-transform: rotate(30deg);??? /* Safari and Chrome */
-o-transform: rotate(30deg);??????? /* Opera */
-moz-transform: rotate(30deg);??????? /* Firefox */
}

??試一試??

傾斜

skewX(angle)

skewY(angle)

沿著 X 、或Y軸。

skew(x-angle,y-angle)

沿著 X 和 Y 軸。

值 skew(30deg,20deg) 圍繞 X 軸把元素翻轉(zhuǎn) 30 度,圍繞 Y 軸翻轉(zhuǎn) 20 度。

div{
transform: skew(30deg,20deg);
-ms-transform: skew(30deg,20deg);??? /* IE 9 */
-webkit-transform: skew(30deg,20deg);??? /* Safari and Chrome */
-o-transform: skew(30deg,20deg);??? /* Opera */
-moz-transform: skew(30deg,20deg);??? /* Firefox */
}

??試一試??

使用六個(gè)值的矩陣。

matrix(n,n,n,n,n,n)

定義 2D 轉(zhuǎn)換,使用六個(gè)值的矩陣。

matrix() 方法把所有 2D 轉(zhuǎn)換方法組合在一起。
matrix() 方法需要六個(gè)參數(shù),包含數(shù)學(xué)函數(shù),允許您:旋轉(zhuǎn)、縮放、移動(dòng)以及傾斜元素。

使用 matrix 方法將 div 元素旋轉(zhuǎn) 30 度

div{
transform:matrix(0.866,0.5,-0.5,0.866,0,0);
-ms-transform:matrix(0.866,0.5,-0.5,0.866,0,0);??????? /* IE 9 */
-moz-transform:matrix(0.866,0.5,-0.5,0.866,0,0);??? /* Firefox */
-webkit-transform:matrix(0.866,0.5,-0.5,0.866,0,0);??? /* Safari and Chrome */
-o-transform:matrix(0.866,0.5,-0.5,0.866,0,0);??????? /* Opera */
}

??試一試??

二.CSS3 3D 轉(zhuǎn)換

三維變換使用基于二維變換的相同屬性,如果您熟悉二維變換,你們發(fā)現(xiàn)3D變形的功能和2D變換的功能相當(dāng)類似。CSS3中的3D變換主要包括以下幾種功能函數(shù):

3D位移:CSS3中的3D位移主要包括translateZ()和translate3d()兩個(gè)功能函數(shù);
3D旋轉(zhuǎn):CSS3中的3D旋轉(zhuǎn)主要包括rotateX()、rotateY()、rotateZ()和rotate3d()四個(gè)功能函數(shù);
3D縮放:CSS3中的3D縮放主要包括scaleZ()和scale3d()兩個(gè)功能函數(shù);
3D矩陣:CSS3中3D變形中和2D變形一樣也有一個(gè)3D矩陣功能函數(shù)matrix3d()。

1.3D位移

在CSS3中3D位移主要包括兩種函數(shù)translateZ()和translate3d()。translate3d()函數(shù)使一個(gè)元素在三維空間移動(dòng)。這種變形的特點(diǎn)是,使用三維向量的坐標(biāo)定義元素在每個(gè)方向移動(dòng)多少。

隨著px的增加,直觀效果上:

X:從左向右移動(dòng)

Y:從上向下移動(dòng)

Z:以方框中心為原點(diǎn),變大

??

x1

????

y1

????

z1

??

從上圖的效果可以看出,當(dāng)z軸值越大時(shí),元素也離觀看者更近,從視覺上元素就變得更大;反之其值越小時(shí),元素也離觀看者更遠(yuǎn),從視覺上元素就變得更小。

例子:

.stage {width: 300px;height: 300px;float: left;margin: 15px;position: relative;background: url(http://www.w3cplus.com/sites/default/files/blogs/2013/1311/bg.jpg) repeat center center;-webkit-perspective: 1200px;-moz-perspective: 1200px;-ms-perspective: 1200px;-o-perspective: 1200px;perspective: 1200px;
}
.container {position: absolute;top: 50%;left: 50%;-webkit-transform-style: preserve-3d;-moz-transform-style: preserve-3d;-ms-transform-style: preserve-3d;-o-transform-style: preserve-3d;transform-style: preserve-3d;
}
.container img {position: absolute;margin-left: -35px;margin-top: -50px; 
}
.container img:nth-child(1){z-index: 1;opacity: .6;
}
.s1 img:nth-child(2){z-index: 2; -webkit-transform: translate3d(30px,30px,200px);-moz-transform: translate3d(30px,30px,200px);-ms-transform: translate3d(30px,30px,200px);-o-transform: translate3d(30px,30px,200px);transform: translate3d(30px,30px,200px);
}

效果:

??

image

??

2.3D旋轉(zhuǎn)

在三維變形中,我們可以讓元素在任何軸旋轉(zhuǎn)。為此,CSS3新增三個(gè)旋轉(zhuǎn)函數(shù):rotateX()、rotateY()和rotateZ()。

隨著度數(shù)的增加,直觀效果上:

X:以方框X軸,從下向上旋轉(zhuǎn)

Y:以方框y軸,從左向右旋轉(zhuǎn)

Z:以方框中心為原點(diǎn),順時(shí)針旋轉(zhuǎn)

??

x

????

y

????

z

??

rotate3d()中取值說明:

x:是一個(gè)0到1之間的數(shù)值,主要用來描述元素圍繞X軸旋轉(zhuǎn)的矢量值;
y:是一個(gè)0到1之間的數(shù)值,主要用來描述元素圍繞Y軸旋轉(zhuǎn)的矢量值;
z:是一個(gè)0到1之間的數(shù)值,主要用來描述元素圍繞Z軸旋轉(zhuǎn)的矢量值;
a:是一個(gè)角度值,主要用來指定元素在3D空間旋轉(zhuǎn)的角度,如果其值為正值,元素順時(shí)針旋轉(zhuǎn),反之元素逆時(shí)針旋轉(zhuǎn)。

下面介紹的三個(gè)旋轉(zhuǎn)函數(shù)功能等同:

rotateX(a)函數(shù)功能等同于rotate3d(1,0,0,a)
rotateY(a)函數(shù)功能等同于rotate3d(0,1,0,a)
rotateZ(a)函數(shù)功能等同于rotate3d(0,0,1,a)

注:a指的是一個(gè)旋轉(zhuǎn)角度值。turn是圈,1turn = 360deg;另外還有弧度rad,2πrad = 1turn = 360deg。如,transform:rotate(2turn); //旋轉(zhuǎn)兩圈

例子:

.stage {width: 300px;height: 300px;float: left;margin: 15px;position: relative;background: url(http://www.w3cplus.com/sites/default/files/blogs/2013/1311/bg.jpg) repeat center center;-webkit-perspective: 1200px;-moz-perspective: 1200px;-ms-perspective: 1200px;-o-perspective: 1200px;perspective: 1200px;
}
.container {position: absolute;top: 50%;left: 50%;-webkit-transform-style: preserve-3d;-moz-transform-style: preserve-3d;-ms-transform-style: preserve-3d;-o-transform-style: preserve-3d;transform-style: preserve-3d;
}
.container img {position: absolute;margin-left: -70px;margin-top: -100px; 
}
.container img:nth-child(1){z-index: 1;opacity: .6;
}.s4 img{z-index: 2; -webkit-transform:rotate3d(.6,1,.6,45deg);-moz-transform:rotate3d(.6,1,.6,45deg);-ms-transform:rotate3d(.6,1,.6,45deg);-o-transform:rotate3d(.6,1,.6,45deg);transform:rotate3d(.6,1,.6,45deg);
}

效果:

??

image

??

3.3D縮放

通過使用3D縮放函數(shù),可以讓元素在Z軸上按比例縮放。默認(rèn)值為1,當(dāng)值大于1時(shí),元素放大,反之小于1大于0.01時(shí),元素縮小。當(dāng)scale3d()中X軸和Y軸同時(shí)為1,即scale3d(1,1,sz),其效果等同于scaleZ(sz)。

隨著放大倍數(shù)的增加,直觀效果上:

X:以方框Y軸,左右變寬

Y:以方框X軸,上下變高

Z:看不出變換。scaleZ()和scale3d()函數(shù)單獨(dú)使用時(shí)沒有任何效果。

??

x2

????

y2

????

z3

??

scaleZ()和scale3d()函數(shù)單獨(dú)使用時(shí)沒有任何效果,需要配合其他的變形函數(shù)一起使用才會(huì)有效果。下面我們來看一個(gè)實(shí)例,為了能看到scaleZ()函數(shù)的效果,我們添加了一個(gè)rotateX(45deg)功能:

例子:

.s1 img:nth-child(2){z-index: 2; -webkit-transform: scaleZ(5) rotateX(45deg);-moz-transform: scaleZ(5) rotateX(45deg);-ms-transform: scaleZ(5) rotateX(45deg);-o-transform: scaleZ(5) rotateX(45deg);transform: scaleZ(5) rotateX(45deg);
}
.s2 img:nth-child(2){z-index: 2; -webkit-transform: scaleZ(.25) rotateX(45deg);-moz-transform: scaleZ(.25) rotateX(45deg);-ms-transform: scaleZ(.25) rotateX(45deg);-o-transform: scaleZ(.25) rotateX(45deg);transform: scaleZ(.25) rotateX(45deg);
}

效果:

??

image

??

4.3D矩陣

CSS3中的3D矩陣要比2D中的矩陣復(fù)雜的多了,從二維到三維,是從4到9;而在矩陣?yán)镱^是3*3變成4*4,9到16了。話說又說回來,對(duì)于3D矩陣而言,本質(zhì)上很多東西都與2D一致的,只是復(fù)雜程度不一樣而已。

3D矩陣即為透視投影,推算方法與2D矩陣類似:

??

image

??

代碼表示就是:

matrix3d(sx, 0, 0, 0, 0, sy, 0, 0, 0, 0, sz, 0, 0, 0, 0, 1)

5.3D傾斜

傾斜是二維變形,不能在三維空間變形。元素可能會(huì)在X軸和Y軸傾斜,然后轉(zhuǎn)化為三維,但它們不能在Z軸傾斜。

三.多重變形

在CSS3中,不管是2D變形還是3D變形,我們都可以使用多重變形,他們之間使用空格分隔,具體的語法如下:

transform: <transform-function>  <transform-function> *

其中transfrom-function是指CSS3中的任何變形函數(shù)。我們來看一個(gè)使用多重變形制作的立方體。先來看一個(gè)使用2D變形制作的立方體:??演示??

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><style>@-webkit-keyframes spin{0%{-webkit-transform:rotateY(0deg);transform:rotateY(0deg)}100%{-webkit-transform:rotateY(360deg);transform:rotateY(360deg)}}@-moz-keyframes spin{0%{-moz-transform:rotateY(0deg);transform:rotateY(0deg)}100%{-moz-transform:rotateY(360deg);transform:rotateY(360deg)}}@-ms-keyframes spin{        0%{-ms-transform:rotateY(0deg);transform:rotateY(0deg)}     100%{-ms-transform:rotateY(360deg);transform:rotateY(360deg)}}@-o-keyframes spin{     0%{-o-transform:rotateY(0deg);transform:rotateY(0deg)}100%{-o-transform:rotateY(360deg);transform:rotateY(360deg)}}@keyframes spin{0%{transform:rotateY(0deg)}100%{transform:rotateY(360deg)}}.stage {width: 300px;height: 300px;float: left;margin: 15px;position: relative;background: url(http://www.w3cplus.com/sites/default/files/blogs/2013/1311/bg.jpg) repeat center center;-webkit-perspective: 1200px;-moz-perspective: 1200px;-ms-perspective: 1200px;-o-perspective: 1200px;perspective: 1200px;}.container {position: relative;height: 230px;width: 100px;top: 50%;left: 50%;margin: -100px 0 0 -50px;-webkit-transform-style: preserve-3d;-moz-transform-style: preserve-3d;-ms-transform-style: preserve-3d;-o-transform-style: preserve-3d;transform-style: preserve-3d;}.container:hover{-moz-animation:spin 5s linear infinite;-o-animation:spin 5s linear infinite;-webkit-animation:spin 5s linear infinite;animation:spin 5s linear infinite;}.side {font-size: 20px;font-weight: bold;height: 100px;line-height: 100px;color: #fff;position: absolute;text-align: center;text-shadow: 0 -1px 0 rgba(0,0,0,0.2);text-transform: uppercase;width: 100px;}.top {background: #9acc53;-webkit-transform: rotate(-45deg) skew(15deg, 15deg);-moz-transform: rotate(-45deg) skew(15deg, 15deg);-ms-transform: rotate(-45deg) skew(15deg, 15deg);-o-transform: rotate(-45deg) skew(15deg, 15deg);transform: rotate(-45deg) skew(15deg, 15deg);}.left {background: #8ec63f;-webkit-transform: rotate(15deg) skew(15deg, 15deg) translate(-50%, 100%);-moz-transform: rotate(15deg) skew(15deg, 15deg) translate(-50%, 100%);-ms-transform: rotate(15deg) skew(15deg, 15deg) translate(-50%, 100%);-o-transform: rotate(15deg) skew(15deg, 15deg) translate(-50%, 100%);transform: rotate(15deg) skew(15deg, 15deg) translate(-50%, 100%);}.right {background: #80b239;-webkit-transform: rotate(-15deg) skew(-15deg, -15deg) translate(50%, 100%);-moz-transform: rotate(-15deg) skew(-15deg, -15deg) translate(50%, 100%);-ms-transform: rotate(-15deg) skew(-15deg, -15deg) translate(50%, 100%);-o-transform: rotate(-15deg) skew(-15deg, -15deg) translate(50%, 100%);transform: rotate(-15deg) skew(-15deg, -15deg) translate(50%, 100%);}</style>
</head>
<body><div class="stage s1"><div class="container"><div class="side top">1</div><div class="side left">2</div><div class="side right">3</div></div></div>
</body>
</html>

??

jdfw

??

上例通過三個(gè)面,使用多個(gè)2D變形,制作的一個(gè)3D立方體,接著我們?cè)趤硎褂?D多重變形制作一個(gè)3D立方體。??演示??

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><style>@-webkit-keyframes spin{0%{-webkit-transform:rotateY(0deg);transform:rotateY(0deg)}100%{-webkit-transform:rotateY(360deg);transform:rotateY(360deg)}}@-moz-keyframes spin{0%{-moz-transform:rotateY(0deg);transform:rotateY(0deg)}100%{-moz-transform:rotateY(360deg);transform:rotateY(360deg)}}@-ms-keyframes spin{0%{-ms-transform:rotateY(0deg);transform:rotateY(0deg)}100%{-ms-transform:rotateY(360deg);transform:rotateY(360deg)}}@-o-keyframes spin{0%{-o-transform:rotateY(0deg);transform:rotateY(0deg)}100%{-o-transform:rotateY(360deg);transform:rotateY(360deg)}}@keyframes spin{0%{transform:rotateY(0deg)}100%{transform:rotateY(360deg)}}.stage {width: 300px;height: 300px;margin: 15px auto;position: relative;background: url(http://www.w3cplus.com/sites/default/files/blogs/2013/1311/bg.jpg) repeat center center;-webkit-perspective: 300px;-moz-perspective: 300px;-ms-perspective: 300px;-o-perspective: 300px;perspective: 300px;}.container {top: 50%;left: 50%;margin: -100px 0 0 -100px;position: absolute;-webkit-transform: translateZ(-100px);-moz-transform: translateZ(-100px);-ms-transform: translateZ(-100px);-o-transform: translateZ(-100px);transform: translateZ(-100px);-webkit-transform-style: preserve-3d;-moz-transform-style: preserve-3d;-ms-transform-style: preserve-3d;-o-transform-style: preserve-3d;transform-style: preserve-3d;}.container:hover{-moz-animation:spin 5s linear infinite;-o-animation:spin 5s linear infinite;-webkit-animation:spin 5s linear infinite;animation:spin 5s linear infinite;}.side {background: rgba(142,198,63,0.3);border: 2px solid #8ec63f;font-size: 60px;font-weight: bold;color: #fff;height: 196px;line-height: 196px;position: absolute;text-align: center;text-shadow: 0 -1px 0 rgba(0,0,0,0.2);text-transform: uppercase;width: 196px;}.front {-webkit-transform: translateZ(100px);-moz-transform: translateZ(100px);-ms-transform: translateZ(100px);-o-transform: translateZ(100px);transform: translateZ(100px);}.back {-webkit-transform: rotateX(180deg) translateZ(100px);-moz-transform: rotateX(180deg) translateZ(100px);-ms-transform: rotateX(180deg) translateZ(100px);-o-transform: rotateX(180deg) translateZ(100px);transform: rotateX(180deg) translateZ(100px);}.left {-webkit-transform: rotateY(-90deg) translateZ(100px);-moz-transform: rotateY(-90deg) translateZ(100px);-ms-transform: rotateY(-90deg) translateZ(100px);-o-transform: rotateY(-90deg) translateZ(100px);transform: rotateY(-90deg) translateZ(100px);}.right {-webkit-transform: rotateY(90deg) translateZ(100px);-moz-transform: rotateY(90deg) translateZ(100px);-ms-transform: rotateY(90deg) translateZ(100px);-o-transform: rotateY(90deg) translateZ(100px);transform: rotateY(90deg) translateZ(100px);}.top {-webkit-transform: rotateX(90deg) translateZ(100px);-moz-transform: rotateX(90deg) translateZ(100px);-ms-transform: rotateX(90deg) translateZ(100px);-o-transform: rotateX(90deg) translateZ(100px);transform: rotateX(90deg) translateZ(100px);}.bottom {-webkit-transform: rotateX(-90deg) translateZ(100px);-moz-transform: rotateX(-90deg) translateZ(100px);-ms-transform: rotateX(-90deg) translateZ(100px);-o-transform: rotateX(-90deg) translateZ(100px);transform: rotateX(-90deg) translateZ(100px);}</style>
</head>
<body><div class="stage"><div class="container"><div class="side front">1</div><div class="side back">2</div><div class="side left">3</div><div class="side right">4</div><div class="side top">5</div><div class="side bottom">6</div></div></div>
</body>
</html>

??

jdfw

??

四.3D Transform轉(zhuǎn)換屬性

屬性

描述

CSS

transform

向元素應(yīng)用 2D 或 3D 轉(zhuǎn)換。

3

transform-origin

允許你改變被轉(zhuǎn)換元素的位置。

3

transform-style

規(guī)定被嵌套元素如何在 3D 空間中顯示。

3

perspective

規(guī)定 3D 元素的透視效果。

3

perspective-origin

規(guī)定 3D 元素的底部位置。

3

backface-visibility

定義元素在不面對(duì)屏幕時(shí)是否可見。

3

1.transform-origin

transform-origin,變形的原點(diǎn)。默認(rèn)情況,變形的原點(diǎn)在元素的中心點(diǎn),或者是元素X軸和Y軸的50%處,如下圖:

??

image

??

我們沒有使用transform-origin改變?cè)卦c(diǎn)位置的情況下,CSS變形進(jìn)行的旋轉(zhuǎn)、移位、縮放等操作都是以元素自己中心(變形原點(diǎn))位置進(jìn)行變形的。但很多時(shí)候需要在不同的位置對(duì)元素進(jìn)行變形操作,我們就可以使用transform-origin來對(duì)元素進(jìn)行原點(diǎn)位置改變,使元素原點(diǎn)不在元素的中心位置,以達(dá)到需要的原點(diǎn)位置。

如果我們把元素變換原點(diǎn)(transform-origin)設(shè)置0(x) 0(y),這個(gè)時(shí)候元素的變換原點(diǎn)轉(zhuǎn)換到元素的左頂角處,如下圖所示:

??

image

??

正如上圖所示,改變transform-origin屬性的X軸和Y軸的值就可以重置元素變形原點(diǎn)位置,其基本語法如下所示:

transform-origin:[<percentage> | <length> | left | center | right | top | bottom] | [<percentage> | <length> | left | center | right] | [[<percentage> | <length> | left | center | right] && [<percentage> | <length> | top | center | bottom]] <length> ?

上面的語法讓人看得發(fā)暈,其實(shí)可以將語法拆分成:

/*只設(shè)置一個(gè)值的語法*/
transform-origin: x-offset
transform-origin:offset-keyword
/*設(shè)置兩個(gè)值的語法*/
transform-origin:x-offset  y-offset
transform-origin:y-offset  x-offset-keyword
transform-origin:x-offset-keyword  y-offset
transform-origin:x-offset-keyword  y-offset-keyword
transform-origin:y-offset-keyword  x-offset-keyword
/*設(shè)置三個(gè)值的語法*/
transform-origin:x-offset  y-offset  z-offset
transform-origin:y-offset  x-offset-keyword  z-offset
transform-origin:x-offset-keyword  y-offset  z-offset
transform-origin:x-offset-keyword  y-offset-keyword  z-offset
transform-origin:y-offset-keyword  x-offset-keyword  z-offset

2D的變形中的transform-origin屬性可以是一個(gè)參數(shù)值,也可以是兩個(gè)參數(shù)值。如果是兩個(gè)參數(shù)值時(shí),第一值設(shè)置水平方向X軸的位置,第二個(gè)值是用來設(shè)置垂直方向Y軸的位置。

3D的變形中的transform-origin屬性還包括了Z軸的第三個(gè)值。其各個(gè)值的取值簡單說明如下:

-x-offset:用來設(shè)置transform-origin水平方向X軸的偏移量,可以使用<length>和<percentage>值,同時(shí)也可以是正值(從中心點(diǎn)沿水平方向X軸向右偏移量),也可以是負(fù)值(從中心點(diǎn)沿水平方向X軸向左偏移量)。
-offset-keyword:是top、right、bottom、left或center中的一個(gè)關(guān)鍵詞,可以用來設(shè)置transform-origin的偏移量。
-y-offset:用來設(shè)置transform-origin屬性在垂直方向Y軸的偏移量,可以使用<length>和<percentage>值,同時(shí)可以是正值(從中心點(diǎn)沿垂直方向Y軸向下的偏移量),也可以是負(fù)值(從中心點(diǎn)沿垂直方向Y軸向上的偏移量)。
?-x-offset-keyword:是left、right或center中的一個(gè)關(guān)鍵詞,可以用來設(shè)置transform-origin屬性值在水平X軸的偏移量。
-y-offset-keyword:是top、bottom或center中的一個(gè)關(guān)鍵詞,可以用來設(shè)置transform-origin屬性值在垂直方向Y軸的偏移量。
?-z-offset:用來設(shè)置3D變形中transform-origin遠(yuǎn)離用戶眼睛視點(diǎn)的距離,默認(rèn)值z(mì)=0,其取值可以<length>,不過<percentage>在這里將無效。

看上去transform-origin取值與background-position取值類似。為了方便記憶,可以把關(guān)鍵詞和百分比值對(duì)比起來記:

top = top center = center top = 50% 0right = right center = center right = 100%或(100% 50%)bottom = bottom center = center bottom = 50% 100%left = left center = center left = 0或(0 50%)center = center center = 50%或(50% 50%)top left = left top = 0 0right top = top right = 100% 0bottom right = right bottom = 100% 100%bottom left = left bottom = 0 100%
2.transform-style

transform-style屬性是3D空間一個(gè)重要屬性,指定嵌套元素如何在3D空間中呈現(xiàn)。他主要有兩個(gè)屬性值:flat和preserve-3d。

transform-style屬性的使用語法非常簡單:

transform-style: flat | preserve-3d

其中flat值為默認(rèn)值,表示所有子元素在2D平面呈現(xiàn)。preserve-3d表示所有子元素在3D空間中呈現(xiàn)。

也就是說,如果對(duì)一個(gè)元素設(shè)置了transform-style的值為flat,則該元素的所有子元素都將被平展到該元素的2D平面中進(jìn)行呈現(xiàn)。沿著X軸或Y軸方向旋轉(zhuǎn)該元素將導(dǎo)致位于正或負(fù)Z軸位置的子元素顯示在該元素的平面上,而不是它的前面或者后面。如果對(duì)一個(gè)元素設(shè)置了transform-style的值為preserve-3d,它表示不執(zhí)行平展操作,他的所有子元素位于3D空間中。

transform-style屬性需要設(shè)置在父元素中,并且高于任何嵌套的變形元素。

例如:

??

image

??

要在.span里添加

transform-style: preserve-3d;
3.perspective

perspective屬性對(duì)于3D變形來說至關(guān)重要。該屬性會(huì)設(shè)置查看者的位置,并將可視內(nèi)容映射到一個(gè)視錐上,繼而投到一個(gè)2D視平面上。如果不指定透視,則Z軸空間中的所有點(diǎn)將平鋪到同一個(gè)2D視平面中,并且變換結(jié)果中將不存在景深概念。

上面的描述可能讓人難以理解一些,其實(shí)對(duì)于perspective屬性,我們可以簡單的理解為視距,用來設(shè)置用戶和元素3D空間Z平面之間的距離。而其效應(yīng)由他的值來決定,值越小,用戶與3D空間Z平面距離越近,視覺效果更令人印象深刻;反之,值越大,用戶與3D空間Z平面距離越遠(yuǎn),視覺效果就很小。

在3D變形中,對(duì)于某些變形,例如下面的示例演示的沿Z軸的變形,perspective屬性對(duì)于查看變形的效果來說必不可少。

我們先來看一個(gè)簡單的實(shí)例,制作一個(gè)撲克牌3D旋轉(zhuǎn)效果,并且一個(gè)在撲克牌的父元素添加了視距perspective,而另一個(gè)卻沒有設(shè)置:

div {width: 500px;height: 300px;margin: 30px auto;position: relative;background: url(images/bg-grid.jpg) no-repeat center center;background-size: 100% 100%;
}
div img {position: absolute;top: 50%;left: 50%;margin-left: -71px;margin-top: -100px; transform-origin: bottom;
}
div img:nth-child(1){opacity: .5;z-index: 1;
}
div img:nth-child(2){z-index: 2;transform: rotateX(45deg);
}
div:nth-of-type(2){perspective: 500px;
}

效果如下:

??

image

??

上圖的效果完全說明了一切。父節(jié)點(diǎn)沒有設(shè)置perspective的情況下,梅花King的3D旋轉(zhuǎn)效果不明顯,而在父節(jié)點(diǎn)設(shè)置perspective后,梅花King才像個(gè)3D旋轉(zhuǎn)。

上例簡單的演示了perspective的使用方法,我們回過頭來,看看perspective的使用語法:

perspective:none | <length>

perspective屬性包括兩個(gè)屬性:none和具有單位的長度值。其中perspective屬性的默認(rèn)值為none,表示無限的角度來看3D物體,但看上去是平的。另一個(gè)值<length>接受一個(gè)長度單位大于0的值。而且其單位不能為百分比值。<length>值越大,角度出現(xiàn)的越遠(yuǎn),從而創(chuàng)建一個(gè)相當(dāng)?shù)偷膹?qiáng)度和非常小的3D空間變化。反之,此值越小,角度出現(xiàn)的越近,從而創(chuàng)建一個(gè)高強(qiáng)度的角度和一個(gè)大型3D變化。

比如你站在10英尺和1000英尺的地方看一個(gè)10英尺的立方體。在10英尺的地方,你距離立方體是一樣的尺寸。因此視角轉(zhuǎn)變遠(yuǎn)遠(yuǎn)大于站在1000英尺處的,立體尺寸是你距離立方體距離的百分之一。同樣的思維適用于perspective的<length>值。我們一起來看一個(gè)實(shí)例,來加強(qiáng)這方面的理解:??演示??

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><style>.wrapper {width: 50%;float: left;}.cube {font-size: 4em;width: 2em;margin: 1.5em auto;transform-style: preserve-3d;transform: rotateX(-40deg) rotateY(32deg);}.side {position: absolute;width: 2em;height: 2em;background: rgba(255, 99, 71, 0.6);border: 1px solid rgba(0, 0, 0, 0.5);color: white;text-align: center;line-height: 2em;}.front {transform: translateZ(1em);}.top {transform: rotateX(90deg) translateZ(1em);}.right {transform: rotateY(90deg) translateZ(1em);}.left {transform: rotateY(-90deg) translateZ(1em);}.bottom {transform: rotateX(-90deg) translateZ(1em);}.back {transform: rotateY(-180deg) translateZ(1em);}.w1 {perspective: 100px;}.w2{perspective: 1000px;}</style>
</head>
<body><div class="wrapper w2"><div class="cube"><div class="side  front">1</div><div class="side   back">6</div><div class="side  right">4</div><div class="side   left">3</div><div class="side    top">5</div><div class="side bottom">2</div></div></div><div class="wrapper w1"><div class="cube"><div class="side  front">1</div><div class="side   back">6</div><div class="side  right">4</div><div class="side   left">3</div><div class="side    top">5</div><div class="side bottom">2</div></div></div>
</body>
</html>

??

image

??

依據(jù)上面的介紹,我們可對(duì)perspective取值做一個(gè)簡單的結(jié)論:

-perspective取值為none或不設(shè)置,就沒有真3D空間。
-perspective取值越小,3D效果就越明顯,也就是你的眼睛越靠近真3D。
-perspective的值無窮大,或值為0時(shí)與取值為none效果一樣。

4.perspective-origin

perspective-origin屬性是3D變形中另一個(gè)重要屬性,主要用來決定perspective屬性的源點(diǎn)角度。它實(shí)際上設(shè)置了X軸和Y軸位置,在該位置觀看者好像在觀看該元素的子元素。

perspective-origin屬性的使用語法也很簡單:

perspective-origin:[<percentage> | <length> | left | center | right | top | bottom] | [[<percentage> | <length> | left | center | right] && [<percentage> | <length> | top | center | bottom]]

該屬性的默認(rèn)值為“50% 50%”(也就是center),其也可以設(shè)置為一個(gè)值,也可以設(shè)置為兩個(gè)長度值:

第一個(gè)長度值指定相對(duì)于元素的包含框的X軸上的位置。它可以是長度值(以受支持的長度單位表示)、百分比或以下三個(gè)關(guān)鍵詞之一:left(表示在包含框的X軸方向長度的0%),center(表示中間點(diǎn)),或right(表示長度的100%)。
第二個(gè)長度值指定相對(duì)于元素的包含框的Y軸上的位置。它可以是長度值、百分比或以下三個(gè)關(guān)鍵詞之一:top(表示在包含框的Y軸方向長度的0%),center(表示中間點(diǎn)),或bottom(表示長度的100%)。
注意,為了指轉(zhuǎn)換子元素變形的深度,perspective-origin屬性必須定義父元素上。通常perspective-origin屬性本身不做任何事情,它必須被定義在設(shè)置了perspective屬性的元素上。換句話說,perspective-origin屬性需要與perspective屬性結(jié)合起來使用,以便將視點(diǎn)移至元素的中心以外位置

??

image

??

5.backface-visibility

backface-visibility屬性決定元素旋轉(zhuǎn)背面是否可見。對(duì)于未旋轉(zhuǎn)的元素,該元素的正面面向觀看者。當(dāng)其Y軸旋轉(zhuǎn)約180度時(shí)會(huì)導(dǎo)致元素的背面面對(duì)觀眾。

backface-visibility屬性使用語法:

backface-visibility: visible | hidden

該屬性被設(shè)置為以下兩個(gè)關(guān)鍵詞之一:

?visible:為backface-visibility的默認(rèn)值,表示反面可見
hidden:表示反面不可見
一個(gè)元素的可見性與“backface-visibility:hidden”決定如下:

元素在3D環(huán)境下渲染上下文,將根據(jù)3D變形矩陣來計(jì)算,反之元素不在3D環(huán)境下渲染上下文,將根據(jù)2D變形矩陣來計(jì)算。
如果組件的矩陣在第3行、3列是負(fù)值,那么元素反面是隱藏,反之是可見的。
簡單點(diǎn)來說,backface-visibility屬性可用于隱藏內(nèi)容的背面。默認(rèn)情況下,背面可見,這意味著即使在翻轉(zhuǎn)后,旋轉(zhuǎn)的內(nèi)容仍然可見。但當(dāng)backface-visibility設(shè)置為hidden時(shí),旋轉(zhuǎn)后內(nèi)容將隱藏,因?yàn)樾D(zhuǎn)后正面將不再可見。該功能可幫助您模擬多面的對(duì)象,例如下例中使用的紙牌。通過將backface-visibility設(shè)置為hidden,您可以輕松確保只有正面可見。

我們通過3D立方體來做一個(gè)實(shí)例,讓你能從視覺上更能直能的區(qū)分backface-visibility取值為hidden和visible的區(qū)別:??演示??

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><style>.container {width: 500px;height: 300px;float: left;position: relative;margin: 30px;border: 1px solid #CCC;perspective: 1200px;}.cube {width: 100%;height: 100%;position: absolute;animation: spinCube 8s infinite ease-in-out;transform-style: preserve-3d;transform: translateZ( -100px );}@keyframes spinCube {0% { transform: translateZ( -100px ) rotateX(   0deg ) rotateY(   0deg ); }100% {transform: translateZ( -100px ) rotateX( 360deg ) rotateY( 360deg ); }}.side {display: block;position: absolute;width: 196px;height: 196px;border: 2px solid black;line-height: 196px;font-size: 120px;font-weight: bold;color: white;text-align: center;}.cube.backface-visibility-visible .side {backface-visibility: visible;}.cube.backface-visibility-hidden .side {backface-visibility: hidden;}.cube .front  { background: hsla(   0, 100%, 50%, 0.7 ); }.cube .back   { background: hsla(  60, 100%, 50%, 0.7 ); }.cube .right  { background: hsla( 120, 100%, 50%, 0.7 ); }.cube .left   { background: hsla( 180, 100%, 50%, 0.7 ); }.cube .top    { background: hsla( 240, 100%, 50%, 0.7 ); }.cube .bottom { background: hsla( 300, 100%, 50%, 0.7 ); }.cube .front  {transform: translateZ( 100px );}.cube .back {transform: rotateX( -180deg ) translateZ( 100px );}.cube .right {transform: rotateY(   90deg ) translateZ( 100px );}.cube .left {transform: rotateY(  -90deg ) translateZ( 100px );}.cube .top {transform: rotateX(   90deg ) translateZ( 100px );}.cube .bottom {transform: rotateX(  -90deg ) translateZ( 100px );}   </style>
</head>
<body><div class="container"><h1>backface-visibility:visible</h1><div class="cube backface-visibility-visible"><div class="side front">1</div><div class="side back">2</div><div class="side right">3</div><div class="side left">4</div><div class="side top">5</div><div class="side bottom">6</div></div></div>  <div class="container"><h1>backface-visibility:hidden</h1><div class="cube backface-visibility-hidden"><div class="side front">1</div><div class="side back">2</div><div class="side right">3</div><div class="side left">4</div><div class="side top">5</div><div class="side bottom">6</div></div></div>
</body>
</html>

??

jdfw

??

上圖中左邊立方體每個(gè)頁我們都能看得到,而右邊的立方體我們只能看到視力范圍的面。

http://www.risenshineclean.com/news/36610.html

相關(guān)文章:

  • 怎樣克隆別人的網(wǎng)站上海百度推廣優(yōu)化排名
  • 阿里巴巴網(wǎng)站更新怎么做百度競價(jià)優(yōu)化
  • h5商城網(wǎng)站怎么做的河北seo平臺(tái)
  • 網(wǎng)站評(píng)論源碼制作網(wǎng)站的步驟和過程
  • 網(wǎng)站建設(shè)移動(dòng)端是什么意思百青藤廣告聯(lián)盟
  • 東莞網(wǎng)站優(yōu)化方案鄭州seo聯(lián)系搜點(diǎn)網(wǎng)絡(luò)效果好
  • 網(wǎng)站優(yōu)化建設(shè)上海西安網(wǎng)頁設(shè)計(jì)
  • 2023b站免費(fèi)推廣網(wǎng)seo是怎么優(yōu)化上去
  • 網(wǎng)站建設(shè)公司做前端廣告代運(yùn)營
  • 一件代發(fā)幫做網(wǎng)站的騙局百度關(guān)鍵詞搜索量
  • android開發(fā)app西安seo搜推寶
  • 怎么做移動(dòng)網(wǎng)站seo外包公司哪家好
  • 優(yōu)質(zhì)的seo網(wǎng)站排名優(yōu)化軟件下載安裝百度
  • 國際疫情最新消息惠州seo優(yōu)化服務(wù)
  • 愛站seo查詢軟件推廣平臺(tái) 賺傭金
  • 網(wǎng)站開發(fā)還是做數(shù)據(jù)庫開發(fā)代理公司注冊(cè)
  • 網(wǎng)站改標(biāo)題不改版 k網(wǎng)絡(luò)推廣技術(shù)外包
  • 建網(wǎng)站的資料網(wǎng)上營銷推廣
  • 西地那非片能延時(shí)多久seo優(yōu)化服務(wù)商
  • 自己建網(wǎng)站做網(wǎng)店如何優(yōu)化搜索引擎的搜索功能
  • 本地的佛山網(wǎng)站建設(shè)南寧網(wǎng)絡(luò)推廣服務(wù)商
  • 網(wǎng)站建設(shè)方案可以亂寫嗎企業(yè)推廣的網(wǎng)站
  • 網(wǎng)站跳出率高的原因掃描圖片找原圖
  • 沈陽市網(wǎng)站設(shè)計(jì)制作公司自己怎么做網(wǎng)站推廣
  • 汽車工廠視頻網(wǎng)站建設(shè)怎么樣把廣告做在百度上
  • 山西建設(shè)廳網(wǎng)站密鑰二十條疫情優(yōu)化措施
  • h5商城網(wǎng)站建設(shè)是什么電腦系統(tǒng)優(yōu)化工具
  • 濰坊網(wǎng)站建設(shè)費(fèi)用seo sem是啥
  • 家鄉(xiāng)網(wǎng)站怎么做無人區(qū)在線觀看高清1080
  • 從零開始做電影網(wǎng)站快手刷粉網(wǎng)站推廣