精通css3-transform(上)


  先上圖純css3時鍾請思考,css3如何實現,今天就來跟大家分享下制作一個css時鍾的技巧。

 第一步:先了解transform基礎,熟悉的跳過。

            transform,因為還沒有成為w3c的標准,所有使用中,各瀏覽器版本定義樣式名稱如下:

             1.google chrome: -webkit-transform  2.mozilla firefox: -moz-transform:  3.opera: -o-transform: 4.IE filter

                  例如:

1 -o-transform: rotate(40deg); /* opera*/
2 -webkit-transform: rotate(40deg);/* chrome*/
3 -moz-transform: rotate(40deg);/* firefox*/
4 filter: progid:DXImageTransform.Microsoft.Matrix(sizingMethod='auto expand', M11=0.7660444431189777,
5 M12=-0.6427876096865394, M21=0.6427876096865398, M22=0.7660444431189779)";/*IE*/

              關於濾鏡的說明:只要把你需要旋轉的角度roation值用相應函數計算出來就可以了

1 filter:progid:DXImageTransform.Microsoft.Matrix(M11=cos(roation),M12=-sin(roation),M21=sin(roation),M22=cos(roation),SizingMethod='auto expand');

            transform的屬性包括:rotate() / skew() / scale() / translate() /matrix,分別還有x、y之分,比如:rotatex() 和rotatey() ,以此類推。

                      1.rotate:水平旋轉,屬性值格式為Xdeg。(deg是“度”的意思)rotate(Xdeg)。X為正數時,順時針旋轉;為負數時,逆時針旋轉

                      2.translate:定位元素,基於XY軸重新定位元素。translate(Xpx,Ypx)。屬性值為一個時,x、y軸參數相同;為兩個時,x、y軸分別定位。

                               特別注意:x,y 為正 表示右,下移,否則相反。   

                      3.scale:縮放,1為原始大小。scale(x)。正數放大,負數縮小。屬性值為一個時,x/y軸同時縮放;屬性值為兩個值時,分別控制x、y軸的縮放。

                      4.skew:將元素沿水平方向傾斜變形。skew(Xdeg,Ydeg)。這個比較難表述,想象一下平行四邊形吧。屬性值為一個時,x、y軸參數相同;為兩個時,x、y軸          各自傾斜matrix:矩陣,六個值。

 第二步:我們來學會定位12個時刻位置。

           大家熟悉基本用法后,我們開始進階后,這里實現思路有很多種,可以用層,我們使用列表來實現。先定下基本樣式。 

 1 /*樣式*/
 2 <style>
 3      ul { margin: 0; padding: 0px; }
 4      #container li {
 5         display: inline-block;
 6         font-size: 18px;
 7         font-weight: bold;
 8         font-family: "Segoe UI";
 9         text-shadow: #E8E8E8 2px 2px 1px;
10         }
11 </style>
12 /*容器*/
13 <div id="container">
14         <ul>
15             <li>12</li>
16             <li>1</li>
17             <li>2</li>
18             <li>3</li>
19             <li>4</li>
20             <li>5</li>
21             <li>6</li>
22             <li>7</li>
23             <li>8</li>
24             <li>9</li>
25             <li>10</li>
26             <li>11</li>
27         </ul>
28 </div>

   效果應該是很整齊的隊列:12 1 2 3...11 ,到目前為止,還沒有一點旋轉跡象啊,現在要亮劍了,使用transform,因為喜歡谷歌,現在就先用谷歌瀏覽器做試驗,我們編寫3個時刻的樣式

1      #container li:nth-child(1){-webkit-transform:translate(87px,23px);}
2      #container li:nth-child(2){-webkit-transform:rotate(30deg) translate(104px,-23px);}
3      #container li:nth-child(3){-webkit-transform:rotate(60deg) translate(104px,-56px);}

 在運行看下效果,是不是很神奇,開始轉了,細心的人注意到上面3個樣式,有兩個使用了2個屬性rotate() 和translate() ,而且使用了一個偽類選擇器nth-child(an+n),這里先簡單理解為索引到第幾個li。更詳盡的理解可以閱讀這篇文章http://www.cnblogs.com/kiracn/archive/2009/12/17/1626742.html ,繼續我們的主題,這兩個函數混合起來使用在計算時刻點位置的時候,我們需要去理解,為什么往下偏移,translate 值為負值,這里有一個優先級的問題,先渲染rotate(),然后在定位。所以就不難理解,當渲染以后,x,y軸也跟着旋轉了,所以在這個層面理解,他是往上移動定位。理解了這點,后面的點也就都好定位了。

1      #container li:nth-child(4){-webkit-transform:rotate(90deg) translate(97px,-95px);}
2      #container li:nth-child(5){-webkit-transform:rotate(120deg) translate(78px,-120px);}
3      #container li:nth-child(6){-webkit-transform:rotate(150deg) translate(50px,-142px);}
4      #container li:nth-child(7){-webkit-transform:rotate(180deg) translate(23px,-160px);}
5      #container li:nth-child(8){-webkit-transform:rotate(210deg) translate(-10px,-168px);}
6      #container li:nth-child(9){-webkit-transform:rotate(240deg) translate(-55px,-168px);}
7      #container li:nth-child(10){-webkit-transform:rotate(270deg) translate(-100px,-148px);}
8      #container li:nth-child(11){-webkit-transform:rotate(300deg) translate(-140px,-110px);}
9      #container li:nth-child(12){-webkit-transform:rotate(330deg) translate(-165px,-55px);}

   效果看起來,字體斜着的,如果不是為了熟練rotate和translate的混合使用,一般使用translate 就夠了。限於篇幅,我們在下篇中繼續講解。

    


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM