上一篇,
juejin.im/post/5993d9…
把立方體的盒子搭出來以後,由於怕文章又臭又長(嗯,就是沒有想好玩什麼效果,偏不告訴你)關於動效沒有作更多的處理,只作了一個繞Y軸旋轉,這篇試着作幾個效果,CSS3 3D變形的坑太大,一時半會的也填不滿,先探探路。
燃鵝,這種跑死瀏覽器的3D動效實際用處很少,各位看看就好,我也僅僅是有興趣鵝已。瀏覽器
爲了讓3D動效發揮最大程度的頭暈眼花,我在搭立方體的時候特地用了<SVG>
做爲組成各個面的圖形元素,若是用<div>
的話,誠然,能夠利用CSS3的一些屬性來實現一些漸變、描邊、方格等等效果,但靈活性與<SVG>
不能比。好比,我先來個立體框的效果。爲了讓舞臺更大一些,我從新作了定義,因此依舊放上dom結構。
具體的各個面組成元素就再也不一一解釋了,能夠看上篇。總之就是6個<SVG>
組成了6個面,如今這個案例裏,我用的是最基礎的,六個矩形<rect>
。bash
<div class="stage">
<div class="content">
<svg id="cubic1" xmlns="http://www.w3.org/2000/svg" >
<rect height="200" width="200" />
</svg>
<svg id="cubic2" xmlns="http://www.w3.org/2000/svg" >
<rect height="200" width="200" />
</svg>
<svg id="cubic3" xmlns="http://www.w3.org/2000/svg" >
<rect height="200" width="200" />
</svg>
<svg id="cubic4" xmlns="http://www.w3.org/2000/svg" >
<rect height="200" width="200" />
</svg>
<svg id="cubic5" xmlns="http://www.w3.org/2000/svg" >
<rect height="200" width="200" />
</svg>
<svg id="cubic6" xmlns="http://www.w3.org/2000/svg" >
<rect height="200" width="200" />
</svg>
</div>
</div>複製代碼
CSS部分以下,我從新優化了一下,便於動效的設定。網絡
.stage {
width: 1000px; height: 1000px;
/*更大的舞臺*/
background:#e5fffb;
perspective:1000px;
/*透視原點定義的比較大是讓立方體儘量不變形*/
}
@keyframes content{
to {transform:rotateX(360deg) rotateY(360deg);}
}
/*定義一個繞X軸和Y軸同時360度旋轉的動畫*/
.content{
transform-style: preserve-3d;
animation:content 3s linear both infinite ;
position: absolute;top:400px; left:400px;
width:200px; height:200px
}
#cubic1{transform:translateZ(100px);}
#cubic2{transform:translateZ(-100px);}
#cubic3{transform:rotateX(90deg) translateZ(-100px)}
#cubic4{transform:rotateY(-90deg) translateZ(100px)}
#cubic5{transform:rotateX(-90deg)translateZ(-100px);}
#cubic6{transform: rotateY(90deg) translateZ(100px);}
rect{fill:none; stroke-width:3; stroke:#f29a76}
SVG {opacity:1;position: absolute;width:200px; height:200px}複製代碼
如今動畫效果是下面這種:dom
而改變透視原點的效果則是下面這種:svg
好了,拿那個繞着本身的中心點旋轉的規規矩矩的立方體做爲基礎模板,玩一些疊加的動效。首先弄清楚一點,目前進行3D旋轉的是咱們定義爲content,也就是包含了六個<SVG>
的<div>
,而<SVG>
自己,尚未發揮本身的特長呢。之前作過不少<SVG>
的動效,如今疊加幾個試試,看能不能讓系統崩潰(o(╥﹏╥)o)。post
嚴格來講,這只是個效果,並無發揮上面囉囉嗦嗦半天強調的<SVG>
的靈活性。但這也是靈光一現的想法,因此感受效果還好。先說思路,想作一個立方框裏套的一個立方體。原本呢,我是很想把CSS部分簡化,看能不能只用一套立方體的定義來實現,後來呢,嘗試了一下就放棄了,因此任勞任怨的又造了一個小的立方體出來。CSS部分就不重複了,無非改了一下寬度、高度、位移值的定義。這裏想說的是關於旋轉角度的定義。
關於立方體旋轉角度,咱們是這樣定義的:優化
@keyframes content{
to{transform:rotateX(360deg) rotateY(360deg);}
}複製代碼
這裏我要作的小立方體,容器命名爲content2,爲了讓效果更出彩,我但願做爲內核的小立方體與外面的大立方體旋轉方向相反,若是這麼定義transform:rotateX(-360deg) rotateY(-360deg),那就很無語了,由於這樣會獲得下面這種神同步的兩個立方體。動畫
@keyframes content2{
0%{transform:rotateX(-180deg) rotateY(-180deg);}
100%{transform:rotateX(180deg) rotateY(180deg);}
}複製代碼
DuangDuangDuang,看下效果如何(順手改了一把透明度):spa
先把小立方體刪了。關於描邊動畫能夠看看我之前的文章,有詳解,這裏只放CSS部分和效果。我但願獲得一個在旋轉的過程當中進行描邊的動畫。每一個<SVG>
只須要增長一個描邊動畫就能夠了。DOM部分不用處理,CSS須要增長一個描邊動畫的設置:3d
@keyframes dash {
to {
stroke-dashoffset: 0;
}
}複製代碼
而後每一個<SVG>
去調用這個描邊動畫,作好延遲時間的定義。由於每一個矩形的周長相同,都是800,因此我進行了統一的定義。
#cubic1{transform:translateZ(100px); animation: dash 1s linear forwards;}
#cubic3{transform:rotateX(90deg) translateZ(-100px);animation: dash 1s linear 1s forwards}
#cubic2{transform:translateZ(-100px); animation: dash 1s linear 2s forwards}
#cubic4{transform:rotateY(-90deg) translateZ(100px);animation: dash 1s linear 3s forwards }
#cubic5{transform:rotateX(-90deg)translateZ(-100px);animation: dash 1s linear 4s forwards }
#cubic6{transform: rotateY(90deg) translateZ(100px); }
.content SVG {opacity:1;position: absolute;width:200px; height:200px;stroke-dasharray: 800; stroke-dashoffset: 800;} /*每一個矩形的周長是800*/複製代碼
看一下效果如何:
這裏這個動畫效果並非很完美,主要是由於每一個矩形都有重合的邊,這也是最後一個矩形沒有給任何描邊動畫的緣由,由於輪到這last one,本身的邊都被四鄰完成了。要想作的盡善盡美,須要把矩形的定義用<polyline points=""/>
這種定義多邊形的方法去改寫,並嚴格定義起點終點的位置以及描邊參數。包括作不一樣顏色描邊,這裏我就再也不費時間去修改了,總之要得出的結論是,結合每一個<SVG>
的動畫進行疊加可以獲得歎爲觀止的效果。
作完描邊動畫,仍然來個基礎的,和位移動畫疊加。位移動畫比描邊動畫略爲複雜的緣由在於描邊動畫不用考慮6個<SVG>
座標系的變化,而位移動畫則受到各自座標系的影響,不過這裏用分離的思想來理解,咱們把位移動畫附加給<SVG>
裏面的元素,各自<SVG>
包含獨立的位移動畫,而後<SVG>
進行組合立方體的3D旋轉及Z軸位移,最後包含<SVG>
的<div>
再進行3D旋轉動畫。後面的兩步是使用的模板,那隻剩下第一步要完成,就是各自<SVG>
包含的獨立的位移動畫。
先看下拆解的立方體的示意圖:
爲了偷懶,我把位移動畫分紅了兩類,立方體1和2共用垂直方向的位移動畫,三、四、五、6共用水平方向的位移動畫。組合後的立方體以下所示:
@keyframes move1 {
to {transform:translateY(160px);} /*矩形寬40,移動160*/
}
@keyframes move2 {
to {transform:translateX(160px);}
}
.move1{animation: move1 2s ease alternate infinite }
.move2{animation: move2 2s ease alternate infinite }複製代碼
DOM部分,只須要按咱們的分類, 把定義了垂直位移動畫的矩形
<rect class="move1" height="40" width="200" x="0" y="0"/>複製代碼
塞到cubic1和cubic2的<SVG>
中。
把定義了水平位移動畫的矩形
<rect class="move2" height="200" width="40" x="0" y="0"/>複製代碼
塞到cubic3、cubic4、cubic5和cubic6的<SVG>
中。
就能夠獲得下面這種疊加位移動畫效果的旋轉立方體了。(爲了效果炫酷,把背景色改爲了暗黑系,改改顏色、透明度什麼的)
<SVG>
來搭創建方體,真的比
<div>
好不少。尤爲在這種實現疊加動畫動效上。
基礎的動畫除了上面的描邊、位移,定然是少不了旋轉動畫咯。不過有了上面的基礎,相信旋轉動畫很輕鬆就能夠完成。這裏,咱們前面用的矩形<rect>
要暫時退出歷史舞臺了,如今要用個更適合作旋轉動畫的二次元元素,充滿魔力的六芒星!六芒星的繪製能夠直接用多邊形<polygon>
完成,不過我說過由於我懶,因此我是直接AI畫完導出的。
CSS裏定義旋轉動畫以下:
@keyframes magic{
to {transform:rotate(360deg);}
}
.magic{animation:magic 2s linear infinite;
transform-origin:50% 50%}複製代碼
DOM結構中,須要修改的,僅僅是把組成六芒星的路徑塞進每一個<SVG>
裏。只拿其中一個爲例,其餘都是粘貼複製的體力活。
<svg id="cubic1" xmlns="http://www.w3.org/2000/svg" >
<rect class="base" height="200" width="200" x="0" y="0"/>
<g class="magic"><!--如下爲組成六芒星的路徑-->
<path d="M100,20l70.645,122.36H29.355L100,20 M100,18L27.623,143.36h144.753L100,18L100,18z"/>
<path d="M170.645,57.64L100,180L29.355,57.64L170.645,57.64 M172.377,56.64l-144.753,0L100,182L172.377,56.64L172.377,56.64z"/>
</g>
</svg>複製代碼
再看一下六個面都疊加的動畫效果
效果好壞先不說,你就說暈不暈!暈不暈!反正我作的時候,看了一眼效果,嚇得趕忙關閉窗口,轉的太噁心了。反正噁心的受不鳥了,索性再噁心點,改了不一樣的顏色,又疊加了個半透明的圓形,調整了一下轉速。再看看效果:
前面的幾個動效,無論怎麼說,都是用了相同的動畫疊加,要麼一塊兒轉(暈啊,吐啊),要麼一塊兒移動,要麼一塊兒描邊,那麼若是是每一個<SVG>
進行不一樣的動效再疊加行不行啊?固然能夠啊。這是咱們選擇<SVG>
作立方體的初衷,就是要把它的做用發揮最大化。下面就來一個每一個<SVG>
都不一樣,動效也不一樣的效果。下面先修改<SVG>
。(圖片來源於網絡,不想作不想作,W( ̄_ ̄)W)
<SVG>
修改以後,承諾的六種不一樣的效果我不想作了。手累到抽筋,下次再說。88。最後一個動畫算是沒結尾,下次給動物分別作上動態表情~