【動畫消消樂 】一個小清新類型的全局網(wǎng)頁過渡動畫 075

前言

Hello!小伙伴扭粱!

非常感謝您閱讀海轟的文章舵鳞,倘若文中有錯誤的地方,歡迎您指出~

?

自我介紹 ?(?ˊ?ˋ)?

昵稱:海轟

標簽:程序猿|C++選手|學生

簡介:因C語言結(jié)識編程琢蛤,隨后轉(zhuǎn)入計算機專業(yè)蜓堕,有幸拿過國獎、省獎等博其,已保研套才。目前正在學習C++/Linux(真的真的太難了~)

學習經(jīng)驗:扎實基礎(chǔ) + 多做筆記 + 多敲代碼 + 多思考 + 學好英語!

?
<font color="red" font-wight="800">【動畫消消樂】</font> 平時學習生活比較枯燥慕淡,無意之間對一些網(wǎng)頁背伴、應(yīng)用程序的過渡/加載動畫產(chǎn)生了濃厚的興趣,想知道具體是如何實現(xiàn)的? 便在空閑的時候?qū)W習下如何使用css實現(xiàn)一些簡單的動畫效果傻寂,文章僅供作為自己的學習筆記息尺,記錄學習生活,爭取理解動畫的原理疾掰,多多“消滅”動畫搂誉!

效果展示

在這里插入圖片描述

Demo代碼

HTML

<!DOCTYPE html>
<html lang="en">

    <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <link rel="stylesheet" href="style.css">
        <title>Document</title>
    </head>

    <body>
        <section>
            <div class="box">
                <div></div>
                <div></div>
                <div></div>
                <div></div>
            </div>
        </section>
    </body>

</html>

CSS

html, body {
    margin: 0;
    height: 100%;
}

body {
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #5e825a;
    animation: backColor 4s infinite;
}

section {
    width: 650px;
    height: 300px;
    padding: 10px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid white;
}

.box {
    width: 100px;
    height: 100px;
    display: flex;
    flex-wrap: wrap;
}

.box>div:nth-child(1) {
    width: 50px;
    height: 50px;
    background-color: #c0f0b9;
    animation: load1 4s infinite;
}

.box>div:nth-child(2) {
    width: 50px;
    height: 50px;
    background-color: #f0d8ad;
    animation: load2 4s infinite;
}

.box>div:nth-child(3) {
    width: 50px;
    height: 50px;
    background-color: #f0addb;
    animation: load3 4s infinite;
}

.box>div:nth-child(4) {
    width: 50px;
    height: 50px;
    background-color: #c4d8f0;
    animation: load4 4s infinite;
}

@keyframes load1 {
    from {
        transform: translate(0);
    }
    25% {
        transform: translate(100%);
    }
    50% {
        transform: translate(100%, 100%);
    }
    75% {
        transform: translate(0, 100%);
    }
}

@keyframes load2 {
    from {
        transform: translate(0);
    }
    25% {
        transform: translate(0, 100%);
    }
    50% {
        transform: translate(-100%, 100%);
    }
    75% {
        transform: translate(-100%, 0);
    }
}

@keyframes load3 {
    from {
        transform: translate(0);
    }
    25% {
        transform: translate(0, -100%);
    }
    50% {
        transform: translate(100%, -100%);
    }
    75% {
        transform: translate(100%);
    }
}

@keyframes load4 {
    from {
        transform: translate(0);
    }
    25% {
        transform: translate(-100%, 0);
    }
    50% {
        transform: translate(-100%, -100%);
    }
    75% {
        transform: translate(0, -100%);
    }
}

@keyframes backColor {
    from {
        background-color: #5e825a;
    }
    25% {
        background-color: #82466e;
    }
    50% {
        background-color: #425e82;
    }
    75% {
        background-color: #423827;
    }
}

原理詳解

步驟1

使用一個div作為包含四個小方塊的大容器

其中每個小方塊也是用一個div表示

            <div class="box">
                <div></div>
                <div></div>
                <div></div>
                <div></div>
            </div>

設(shè)置為

  • 寬度、高度均為100px
  • flex布局
  • 背景色:藍色
.box {
    width: 100px;
    height: 100px;
    display: flex;
    flex-wrap: wrap;// 換行
    background-color: blue;
}

效果圖如下

在這里插入圖片描述

步驟2

分別設(shè)置四個小方塊 均勻分布

  • 寬度静檬、高度均為50px
  • 顏色為四種(自定義)

.box>div:nth-child(1) {
    width: 50px;
    height: 50px;
    background-color: #c0f0b9;
}

.box>div:nth-child(2) {
    width: 50px;
    height: 50px;
    background-color: #f0d8ad;
}

.box>div:nth-child(3) {
    width: 50px;
    height: 50px;
    background-color: #f0addb;
}

.box>div:nth-child(4) {
    width: 50px;
    height: 50px;
    background-color: #c4d8f0;
}

效果圖如下

在這里插入圖片描述

步驟3

為每個小方塊添加動畫

這里以一個方塊為例

在這里插入圖片描述

動畫簡化為關(guān)鍵四個步驟

  • 右移
  • 再下移
  • 再左移
  • 最后上移

右移說明:


在這里插入圖片描述

下移說明:


在這里插入圖片描述

左移說明:
在這里插入圖片描述

上移說明:


在這里插入圖片描述

主要借助transform屬性進行方塊的移動
.box>div:nth-child(1) {
    animation: load1 4s infinite;
}

@keyframes load1 {
    from {
        transform: translate(0);
    }
    25% {
        transform: translate(100%);
    }
    50% {
        transform: translate(100%, 100%);
    }
    75% {
        transform: translate(0, 100%);
    }
}

方塊的移動效果如下

在這里插入圖片描述

注意:translate(x, y)是以最開始的位置作為參考點的

在這里插入圖片描述

步驟4

其他方塊的動畫原理也是一樣的

不同的就是起始位置不同

編寫動畫效果的時候注意下需要移動方向的順序即可(一共就4個移動方向 順序可以組合)


.box>div:nth-child(1) {
    animation: load1 4s infinite;
}

.box>div:nth-child(2) {
    animation: load2 4s infinite;
}

.box>div:nth-child(3) {
    animation: load3 4s infinite;
}

.box>div:nth-child(4) {
    animation: load4 4s infinite;
} 

@keyframes load1 {
    from {
        transform: translate(0);
    }
    25% {
        transform: translate(100%);
    }
    50% {
        transform: translate(100%, 100%);
    }
    75% {
        transform: translate(0, 100%);
    }
}

@keyframes load2 {
    from {
        transform: translate(0);
    }
    25% {
        transform: translate(0, 100%);
    }
    50% {
        transform: translate(-100%, 100%);
    }
    75% {
        transform: translate(-100%, 0);
    }
}

@keyframes load3 {
    from {
        transform: translate(0);
    }
    25% {
        transform: translate(0, -100%);
    }
    50% {
        transform: translate(100%, -100%);
    }
    75% {
        transform: translate(100%);
    }
}

@keyframes load4 {
    from {
        transform: translate(0);
    }
    25% {
        transform: translate(-100%, 0);
    }
    50% {
        transform: translate(-100%, -100%);
    }
    75% {
        transform: translate(0, -100%);
    }
}

效果圖如下

在這里插入圖片描述

步驟5

注釋掉box的背景色

.box {
    width: 100px;
    height: 100px;
    display: flex;
    flex-wrap: wrap;
    /* background-color: blue; */
}

步驟6

在全局背景設(shè)置中添加動畫

使得全局背景顏色隨著方塊的移動而隨著變色

body {
    animation: backColor 4s infinite;
}

@keyframes backColor {
    from {
        background-color: #5e825a;
    }
    25% {
        background-color: #82466e;
    }
    50% {
        background-color: #425e82;
    }
    75% {
        background-color: #423827;
    }
} 

得到最終效果圖

在這里插入圖片描述

結(jié)語

文章僅作為學習筆記炭懊,記錄從0到1的一個過程。

希望對您有所幫助巴柿,如有錯誤歡迎小伙伴指正~

我是海轟?(?ˊ?ˋ)?凛虽,如果您覺得寫得可以的話,請點個贊吧

寫作不易 「點贊」+「收藏」+「轉(zhuǎn)發(fā)」

謝謝支持??

在這里插入圖片描述
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末广恢,一起剝皮案震驚了整個濱河市凯旋,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌钉迷,老刑警劉巖至非,帶你破解...
    沈念sama閱讀 212,816評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異糠聪,居然都是意外死亡荒椭,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評論 3 385
  • 文/潘曉璐 我一進店門舰蟆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來趣惠,“玉大人,你說我怎么就攤上這事身害∥肚模” “怎么了?”我有些...
    開封第一講書人閱讀 158,300評論 0 348
  • 文/不壞的土叔 我叫張陵塌鸯,是天一觀的道長侍瑟。 經(jīng)常有香客問我,道長丙猬,這世上最難降的妖魔是什么涨颜? 我笑而不...
    開封第一講書人閱讀 56,780評論 1 285
  • 正文 為了忘掉前任,我火速辦了婚禮茧球,結(jié)果婚禮上庭瑰,老公的妹妹穿的比我還像新娘。我一直安慰自己袜腥,他們只是感情好见擦,可當我...
    茶點故事閱讀 65,890評論 6 385
  • 文/花漫 我一把揭開白布钉汗。 她就那樣靜靜地躺著羹令,像睡著了一般鲤屡。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上福侈,一...
    開封第一講書人閱讀 50,084評論 1 291
  • 那天酒来,我揣著相機與錄音,去河邊找鬼肪凛。 笑死堰汉,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的伟墙。 我是一名探鬼主播翘鸭,決...
    沈念sama閱讀 39,151評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼戳葵!你這毒婦竟也來了就乓?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,912評論 0 268
  • 序言:老撾萬榮一對情侶失蹤拱烁,失蹤者是張志新(化名)和其女友劉穎生蚁,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體戏自,經(jīng)...
    沈念sama閱讀 44,355評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡邦投,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,666評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了擅笔。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片志衣。...
    茶點故事閱讀 38,809評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖猛们,靈堂內(nèi)的尸體忽然破棺而出念脯,到底是詐尸還是另有隱情,我是刑警寧澤阅懦,帶...
    沈念sama閱讀 34,504評論 4 334
  • 正文 年R本政府宣布和二,位于F島的核電站,受9級特大地震影響耳胎,放射性物質(zhì)發(fā)生泄漏惯吕。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,150評論 3 317
  • 文/蒙蒙 一怕午、第九天 我趴在偏房一處隱蔽的房頂上張望废登。 院中可真熱鬧,春花似錦郁惜、人聲如沸堡距。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春悼泌,著一層夾襖步出監(jiān)牢的瞬間见转,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 46,628評論 2 362
  • 正文 我出身青樓企量,卻偏偏與公主長得像,于是被迫代替她去往敵國和親亡电。 傳聞我的和親對象是個殘疾皇子届巩,可洞房花燭夜當晚...
    茶點故事閱讀 43,724評論 2 351

推薦閱讀更多精彩內(nèi)容