
本文翻自 [週四寫程式系列] 來做SVG動畫讓蔥油餅翻滾吧!,若是對文章內容有疑問,或是想要老闆手把手帶你飛,都可以觀看影片詳細內容。
在上一篇中,老闆帶大家從發想素材、將素材引入網頁,到製作場景進出的動畫。接下來我們將要賦予場景中的每個元件生命。
目標
本篇文章中,老闆會帶大家完成蔥油餅小島中角色與物件的動畫,也會提示大家每個部份需要注意的地方,以下動畫的設定數值都都只是參考,開發時大家都能試試看不同的數值。
- 實際應用﹔讓場景中的元件動起來
讓素材動起來吧
驚嘆號
首先我們從驚嘆號下手,老闆讓驚嘆號分布在場景的各處,用意是要提示使用者這邊有驚喜,引導使用者靠近這個區塊。為了增加提示效果,我們利用左右晃動的動畫效果,固定時間後會再撥放。
這邊使用了新的 css 屬性 animation ,需要搭配 @keyframes 使用,在 keyframes 用百分比去註記不同時間該顯示的樣式,透過 animation 定義動畫總時間,這也代表這個 keyframes 可以提供給不同元件使用,使用的元件賦予不同的時間等屬性,就是一個全新的樣貌。
要注意元件會以左上角為旋轉中心點,適時加上 transform-origin, transform-box 讓動畫更加合理。
[data-name="sign"]{
// 引用動畫名稱 時間 延遲播放時間 次數
animation: drag 2s infinite;
transform-origin: center center;
transform-box: fill-box;
}
@keyframes drag {
0%{transform: rotate(0deg);}
80%{transform: rotate(0deg);}
85%{transform: rotate(10deg);}
90%{transform: rotate(-6deg);}
95%{transform: rotate(3deg);}
100%{transform: rotate(0deg);}
}
路人 trigger_door_man
利用前面寫過的 keyframes drag 與 data-name 的概念,我們可以快速完成這個部分的動畫。當滑鼠進入感應區塊,路人能夠開始搖擺。
[data-name="trigger_door_man"]{
&:hover{
animation: drag 2s infinite;
transform-origin: center bottom;
transform-box: fill-box;
}
}

阿伯與跳起來的蔥油餅 trigger_cookie
要讓蔥油餅動起來之前,先從阿伯的手開始,結合蔥油餅動畫之後,讓蔥油餅宛如真的被阿伯翻了起來。撰寫這邊的動畫時,要注意調整 transform-origin ,決定動畫旋轉的參考點,阿伯的上半身也是用相同的方式處理,若是動畫沒調好,很有可能瞬間變成凶殺案,阿伯被腰斬的畫面。
透過 animation 內延遲時間設為負值,讓動畫預先開跑到其他時間點,也是讓動畫更加順暢的小訣竅。
[data-name="trigger_cookie"]{
&:hover {
[data-name="man_upper"]{
animation: bake_cookies 2s infinite ;
transform-origin: center bottom;
transform-box: fill-box;
}
[data-name="hand"]{
// 動畫名稱 動畫時間 次數 延遲時間
animation: drag 2s infinite -0.8s;
transform-origin: left center;
transform-box: fill-box;
}
}
}
@keyframes bake_cookies {
40%{
transform: rotate(5deg);
}
50%{
transform: rotate(-6deg);
}
70%{
transform: rotate(-10deg);
}
90%{
transform: rotate(-6deg);
}
100%{
transform: rotate(5deg);
}
}
接著我們要來處理跳起來的蔥油餅了,蔥油餅的思維比較不同,我們要讓蔥油餅分段顯示。 keyframe 的動畫內容改為使用透明度,讓透明度跟著時間改變,營造出分段顯示的效果,利用 animation-delay 來讓四個位置的蔥油餅,在不同的時間點顯示。這邊起始為置的蔥油餅會出現大部分的時間,所以要特別為它寫一個 keyframe。大家也可以試試看,調出順暢有趣的效果。
[data-name="trigger_cookie"] {
&:hover {
...
[data-name="cookie1"] {
animation: bake_cookies_locus 2s infinite -1s;
}
[data-name="cookie2"] {
animation: bake_cookies_locus 2s infinite -0.8s;
}
[data-name="cookie3"] {
animation: bake_cookies_locus 2s infinite -0.6s;
}
[data-name="cookie4"] {
animation: bake_cookies_locus 2s infinite -0.4s;
}
[data-name="now_cookie"] {
animation: now_cookie 2s infinite;
}
}
}
@keyframes bake_cookies {
40% {
transform: rotate(5deg);
}
50% {
transform: rotate(-6deg);
}
70% {
transform: rotate(-10deg);
}
90% {
transform: rotate(-6deg);
}
100% {
transform: rotate(5deg);
}
}
@keyframes now_cookie {
0% {
opacity: 1;
}
49% {
opacity: 1;
}
50% {
opacity: 0;
}
90% {
opacity: 0;
}
91% {
opacity: 1;
}
}
小孩與媽媽 trigger_cookie
不可能整個畫面都使用同樣的搖擺動態吧?所以我們為小孩換一個動態效果,讓他原地跳躍,要達成這個效果,可以改變 y 的值來達成,媽媽則是繼續搖擺效果。
[data-name="trigger_cookie"] {
&:hover {
[data-name="child"] {
animation: jump 2s infinite -1s;
}
[data-name="mother"] {
animation: drag 5s infinite;
transform-origin: left bottom;
transform-box: fill-box;
}
}
}
@keyframes jump {
0%{
transform: translateY(0px);
}
50%{
transform: translateY(0px);
}
51%{
transform: translateY(0px);
}
75%{
transform: translateY(-10px);
}
100%{
transform: translateY(0px);
}
}

結語
跟著操作之後,應該有 svg + css 製作動畫的概念,這時不妨動手試試看,讓其他小島的元件動起來。也可以畫些素材,加上動畫賦予他們生命力。動畫沒有什麼對或錯,可以按照自己喜好,去改變動畫效果或是調整時間,但要注意撰寫動畫時的連續繼承問題,像是阿伯的手(子層)會跟隨著身體(父層)擺動。下面老闆也提供三個議題,供大家在開發時參考。
引用 animate.css
每次都要重新寫 keyframe,若是寫 keyframe 寫累了或是遇到急案,為了加速開發,老闆這邊準備了一些補品,讓你可以快速套用現成的動畫效果。例如:想要實現當滑鼠進入感應區塊時,讓驚嘆號動畫改為閃爍動畫,在這邊我們結合 animate.css 製作閃爍動畫。引用 ainmate.css 後,當 data-name=”trigger ” hover 時,裡面 data-name=”sign”的動畫都改為 animation: flash 2s infinite。( flash 為 animate.css 的動畫名稱)
電腦與手機
由於手機等行動裝置不會有 hover 的行為,記得補上 focus,讓整個網頁能夠更完善。
了解你的使用者
把作品完成後,如果能夠知道自己這些得意之作是不是真的有被使用,可以做 GA 追蹤,老闆也因為 GA 的關係,發現其實使用者不太常使用換頁,導致這些動畫做了卻沒人看,參考數據後做了相對應的處理,增加作品露面的機會。
課程推薦
動畫互動網頁程式入門(HTML/CSS/JS)以簡單例子帶你入門網站的基礎架構及開發,用素材刻出簡單有趣又美觀的網頁和動畫,享受做出獨一無二的網頁所帶來的成就感,在職場上與設計師和工程師合作無間。
打好基本的互動網頁基礎之後,可以進階動畫互動網頁特效入門(JS/CANVAS),紮實掌握JavaScript 程式與動畫基礎以及進階互動,整合應用掌控資料與顯示的Vue.js前端框架,完成具有設計感的互動網站。




