成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

純CSS如何實現(xiàn)一個沙漏的動畫效果

今天就跟大家聊聊有關(guān)純CSS如何實現(xiàn)一個沙漏的動畫效果,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

創(chuàng)新互聯(lián)公司是一家專業(yè)提供泗洪企業(yè)網(wǎng)站建設(shè),專注與做網(wǎng)站、成都做網(wǎng)站、H5網(wǎng)站設(shè)計、小程序制作等業(yè)務(wù)。10年已為泗洪眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進(jìn)行中。

效果預(yù)覽

純CSS如何實現(xiàn)一個沙漏的動畫效果

源代碼下載

https://github.com/comehope/front-end-daily-challenges

代碼解讀

定義 dom,容器中包含 2 個元素,分別代表沙漏的上半部和下半部:

<div class="loader">
    <span class="top"></span>
    <span class="bottom"></span>
</div>

居中顯示:

body {
    margin: 0;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: gainsboro;
}

定義容器尺寸,并設(shè)置子元素整體布局:

.loader {
    width: 4.3em;
    height: 9.8em;
    font-size: 10px;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
}

畫出 2 個正方形:

.top,
.bottom {
    width: 3.5em;
    height: 3.5em;
    border-style: solid;
    border-color: saddlebrown;
}

通過邊框、圓角和旋轉(zhuǎn),把 2 個正方形變成沙漏形狀:

.top,
.bottom {
    border-width: 0.2em 0.2em 0.6em 0.6em;
    border-radius: 50% 100% 50% 30%;
}

.top {
    transform: rotate(-45deg);
}

.bottom {
    transform: rotate(135deg);
}

用偽元素畫出沙子,上部的沙子的頂部是大圓弧,下部的沙子的頂部是小圓?。?/p>

.top::before,
.bottom::before {
    content: '';
    position: absolute;
    width: inherit;
    height: inherit;
    background-color: deepskyblue;
}

.top::before {
    border-radius: 0 100% 0 0;
}

.bottom::before {
    border-radius: 0 0 0 35%;
}

定義沙子的動畫屬性:

.top::before,
.bottom::before {
    animation: 2s linear infinite;
}

增加沙子從沙漏的上半部落下的動畫效果:

.top::before {
    animation-name: drop-sand;
}

@keyframes drop-sand {
    to {
        transform: translate(-2.5em, 2.5em);
    }
}

增加沙子的沙漏在下半部堆積的動畫效果:

.bottom::before {
    transform: translate(2.5em, -2.5em);
    animation-name: fill-sand;
}

@keyframes fill-sand {
    to {
        transform: translate(0, 0);
    }
}

隱藏沙漏上半部和下半部容器外的部分,此時上面 2 個動畫的疊加效果是沙子從上半部漏下,慢慢在下半部堆積:

.top,
.bottom {
    overflow: hidden;
}

用外層容器的偽元素制作一個窄長條,模擬流動的沙子:

.loader::after {
    content: '';
    position: absolute;
    width: 0.2em;
    height: 4.8em;
    background-color: deepskyblue;
    top: 1em;
}

增加沙子流動的動畫效果:

.loader::after {
    animation: flow 2s linear infinite;
}

@keyframes flow {
    10%, 100% {
        transform: translateY(3.2em);
    }
}

最后,增加沙漏的翻轉(zhuǎn)動畫:

.loader {
    animation: rotating 2s linear infinite;
}

@keyframes rotating {
    0%, 90% {
        transform: rotate(0);
    }
    
    100% {
        transform: rotate(0.5turn);
    }
}

大功告成!

看完上述內(nèi)容,你們對純CSS如何實現(xiàn)一個沙漏的動畫效果有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。

當(dāng)前名稱:純CSS如何實現(xiàn)一個沙漏的動畫效果
本文地址:http://jinyejixie.com/article0/pddhoo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動網(wǎng)站建設(shè)、網(wǎng)站設(shè)計公司、ChatGPT定制網(wǎng)站、網(wǎng)站設(shè)計、微信小程序

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管
盐亭县| 博白县| 昭苏县| 宁津县| 军事| 临汾市| 通榆县| 青冈县| 宁安市| 鄄城县| 城固县| 安徽省| 长子县| 凭祥市| 滦南县| 清涧县| 广灵县| 万宁市| 西青区| 庆云县| 万宁市| 萨嘎县| 九台市| 泰和县| 郑州市| 万安县| 临武县| 江陵县| 即墨市| 通化县| 晋宁县| 上林县| 格尔木市| 安康市| 洛隆县| 沈丘县| 烟台市| 翼城县| 东安县| 建湖县| 宜川县|