首頁 web前端 css教學 CSS3如何實現流星雨效果? (程式碼範例)

CSS3如何實現流星雨效果? (程式碼範例)

Mar 18, 2021 am 10:47 AM
css3

本篇文章給大家透過程式碼範例介紹一下使用CSS3如何實現流星雨效果。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。

CSS3如何實現流星雨效果? (程式碼範例)

【推薦教學:CSS影片教學

說明:正文只講述單一流星雨的實現方式,多個的效果只需要對單一的動畫起始點、寬度稍加修改即可,具體範例請見文末 github 位址。

難度係數

##☆☆☆☆☆

效果圖

CSS3如何實現流星雨效果? (程式碼範例)

  • 想法

流星雨的實現分為三個部分:   

(1)用 border 屬性實現直角三角形。三角形的實作可以參考
    CSS繪製三角形
  • (2)為直角三角形加上圓形效果,弱化直角形狀的稜角
  • (3)加入動畫效果,讓直角三角形動起來
  • HTML
  • <span class="shooting-star animation"></span>
    登入後複製
    解析:
  • html 新增一個動畫容器即可

CSS

.shooting-star {
    margin: 30px;
    display: block;
    width: 0;
    border-radius: 2px;
    border-top-width: 1px;
    border-top-style: solid;
    border-top-color: transparent;
    border-left-width: 230px;
    border-left-style: solid;
    border-left-color: white;
    border-right-width: 230px;
    border-right-style: solid;
    border-right-color: transparent;
    border-bottom-width: 1px;
    border-bottom-style: solid;
    border-bottom-color: white;
}
.animation {
    animation: fly 3s infinite;
}
@keyframes fly {
    from {
        margin-left: 900px;
        border-left-width: 130px;
        border-right-width: 130px;
    }
    to {
        margin-left: -900px;
        border-left-width: 360px;
        border-right-width: 360px;
    }
}
登入後複製
解析:

直角三角形

直角三角形的實現,首先確定直角的方位,本例直角方位為左下角,因此設定左邊框和下邊框為有顏色的,右邊框和上邊框為透明色流星類似一條線的形狀,所以直角三角形高度很小,寬度很大。因此此處設定左右邊框寬度值很大,上下邊框寬度值很小

###類似 span 這樣 display 預設屬性值不為 block 的元素,需要設定 display 屬性為 block######## ####圓形效果######透過 border-radius 設定圓形 border 即可,border-radius 的值與直角三角形高度相同即可(注意高度值應為 border-top-width 與 border- bottom-width 數值總和)############動畫效果######透過 margin-left 設定動畫初始和結束位置######透過改變 border-*-width的值達到流星長度變化的效果######動畫時長決定流星通過介面的時間######動畫次數設定為無限次################ ##知識點###############CSS 實作三角形#############圓角 border############animation新增動畫效果############@keyframes 自訂動畫###############Gitbub 原始碼:############ https://github.com/nanzhangren/CSS_skills/blob/master/shooting_star/shooting_star.html#########更多程式相關知識,請造訪:###程式設計入門###! ! ###

以上是CSS3如何實現流星雨效果? (程式碼範例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1677
14
CakePHP 教程
1431
52
Laravel 教程
1334
25
PHP教程
1280
29
C# 教程
1257
24
純CSS3怎麼實現波浪效果? (程式碼範例) 純CSS3怎麼實現波浪效果? (程式碼範例) Jun 28, 2022 pm 01:39 PM

純CSS3怎麼實現波浪效果?這篇文章就來跟大家介紹一下使用 SVG 和 CSS 動畫來製作波浪效果的方法,希望對大家有幫助!

巧用CSS實現各種奇形怪狀按鈕(附代碼) 巧用CSS實現各種奇形怪狀按鈕(附代碼) Jul 19, 2022 am 11:28 AM

這篇文章帶大家看看怎麼使用 CSS 輕鬆實現高頻出現的各類奇形怪狀按鈕,希望對大家有幫助!

css怎麼隱藏元素但不佔空間 css怎麼隱藏元素但不佔空間 Jun 01, 2022 pm 07:15 PM

兩種方法:1、利用display屬性,只要為元素加上「display:none;」樣式即可。 2.利用position和top屬性設定元素絕對定位來隱藏元素,只需為元素加上「position:absolute;top:-9999px;」樣式。

原來利用純CSS也能實現文字輪播與圖片輪播! 原來利用純CSS也能實現文字輪播與圖片輪播! Jun 10, 2022 pm 01:00 PM

怎麼製作文字輪播與圖片輪播?大家第一想到的是利用js,其實利用純CSS也能實現文字輪播與圖片輪播,下面來看看實作方法,希望對大家有幫助!

css3怎麼實現花邊邊框 css3怎麼實現花邊邊框 Sep 16, 2022 pm 07:11 PM

在css中,可以利用border-image屬性來實作花邊邊框。 border-image屬性可以使用圖片來建立邊框,即給邊框加上背景圖片,只需要將背景圖片指定為花邊樣式即可;語法「border-image: url(圖片路徑) 向內偏移值圖像邊界寬度outset 是否重複;」。

css3如何實現滑鼠點擊圖片放大 css3如何實現滑鼠點擊圖片放大 Apr 25, 2022 pm 04:52 PM

實作方法:1、使用「:active」選擇器選取滑鼠點擊圖片的狀態;2、使用transform屬性和scale()函數實現圖片放大效果,語法「img:active {transform: scale(x軸放大倍率,y軸放大倍率);}」。

css3怎麼設定動畫旋轉速度 css3怎麼設定動畫旋轉速度 Apr 28, 2022 pm 04:32 PM

在css3中,可以利用「animation-timing-function」屬性來設定動畫旋轉速度,該屬性用於指定動畫將如何完成一個週期,設定動畫的速度曲線,語法為「元素{animation-timing-function:速度屬性值;}」。

css3線性漸層可以實現三角形嗎 css3線性漸層可以實現三角形嗎 Apr 25, 2022 pm 02:47 PM

css3線性漸變可以實現三角形;只需創建一個45度的線性漸變,設定漸變色為兩種固定顏色,一個是三角形的顏色,另一個為透明色即可,語法「linear-gradient(45deg,顏色值,顏色值50%,透明色50%,透明色100%)」。

See all articles