首頁 web前端 H5教程 h5canvas實現雪花飄落的特效程式碼

h5canvas實現雪花飄落的特效程式碼

May 17, 2017 pm 02:23 PM
canvas h5

這篇文章主要為大家詳細介紹了HTML5 canvas實現雪花飄落特效,效果實現引人入勝,很逼真的動畫效果,感興趣的小伙伴們可以參考一下

看到網路上很多展示html5雪花飛行的效果,確實非常引人入勝,我相信大家也跟我一樣看著心動的同時,也很好奇,想研究下程式碼如何實現;雖然很多地方也能下載這些原始碼,不過也不知道別人製作這類動畫時的想法及難點分析。

我這幾天剛好學習了一下,也趁著此刻有時間從需求分析、知識點、程序編寫一步步給大家解剖下,要是在各位關公面前耍大刀了,可別見笑喲。

最終效果圖如下:

 

圖1

一、需求分析

# 1.圓形雪花

本範例中雪花形狀使用圓形

2、雪花數量固定

根據圖1仔細觀察白色雪花數量,飄落過程中,整張圖的雪花數量應該是固定的,這個需求是需要透過我們觀察分析所得。這與我們現實生活中看到一幅雪花滿天飛的場景是一致的。

3、雪花大小不一致

每朵雪花它們大小各有不同,也就表示雪花的半徑是隨機的。這與我們現實生活中看到一幅雪花滿天飛的場景也是一致的。

4、雪花位置在移動

雪花飄落,自然它們的位置也在移動。

二、知識點

1、使用Html5 Canvas+JavaScript畫圓-構成圓形雪花

在Html5中,需要使用Canvas同時藉助JavaScript畫圓,以構成圓形雪花-arc(x,y,r,start,stop);

2、隨機數—產生不同半徑、座標的圓形雪花

本範例中,網頁第一次載入時,需要產生一定數量的不同半徑及位置的雪花,故半徑、座標為隨機數;雪花在飄落過程中,其半徑不變,座標在一定幅度內變化,故此時座標也為隨機數-Math.random() 

#三、程式寫

1、準備工作

放一個畫布canvas,並且將整個body背景色為黑色

HTML程式碼:

XML/HTML Code複製內容到剪貼簿

<canvas id="mycanvas">
    您的浏览器不支持canvas画布   
</canvas>
登入後複製

CSS程式碼:

CSS Code複製內容到剪貼簿

#
* {   
    margin: 0;   
    padding: 0;   
}   
#mycanvas {   
    background: black;   
}
登入後複製

此時效果如下:

 

注意:canvas預設是有一個初始化高度和寬度的,所以不用去糾結

2、畫佈滿螢幕顯示

JavaScript程式碼如下:

#JavaScript Code複製內容到剪貼簿

//获取mycanvas画布   
    var can = document.getElementById("mycanvas");   
    var ctx = can.getContext("2d");   
    //画布宽度   
    var wid = window.innerWidth;   
    //画布高度   
    var hei = window.innerHeight;   
    can.width=wid;   
    can.height=hei;
登入後複製

此時效果如如下:

3、初始化產生固定數量的雪花

根據我們上述需求分析及知識點解讀,首先雪花的數量是固定的,所以我們需要定義一個變數var snow = 100;這裡假設雪花數量為100,;

生成雪花的時候,每個雪花半徑、位置都不同,我們把每個雪花當做一個對象,那麼這個對象的屬性就包含:半徑、座標(X、Y),那麼一個雪花對象可以寫成var snowOject={x:1,y: 10,r:5},這裡就代表一個座標為(1,10)半徑為5的圓形雪花;本範例中由於半徑和座標都為隨機數,故使用Math.random()分別為100個雪花生成半徑、座標(X、Y);

那我們這裡是100個雪花,所以為了方便後面操作,就用一個陣列保存這100個雪花物件。

JavaScript程式碼如下:

JavaScript Code複製內容到剪貼簿

//雪花数目   
var snow = 100;   
//雪花坐标、半径   
var arr = []; //保存各圆坐标及半径   
for (var i = 0; i < snow; i++) {   
arr.push({   
x: Math.random() * wid,   
y: Math.random() * hei,   
r: Math.random() * 10 + 1   
})   
}
登入後複製

4、繪製雪花

上面我们已经将100个雪花半径、坐标(X、Y)生成,下面就是循环使用canvas画出雪花了(这里就是画圆),这里定义一个函数

JavaScript代码如下:

JavaScript Code复制内容到剪贴板

//画雪花   
function DrawSnow() {   
    ctx.fillStyle="white";   
    ctx.beginPath();   
    for (var i = 0; i < snow; i++) {   
        var p = arr[i];   
        ctx.moveTo(p.x,p.y);   
        ctx.arc(p.x,p.y,p.r,0,2*Math.PI,false);   
    }   
    ctx.fill();   
  
    ctx.closePath();
登入後複製

然后调用 DrawSnow()函数,效果如下:

可以尝试多次刷新网页看是否会生成不同大小、位置的雪花(正常情况下是可以的),做到这里就已经接近最终效果了

注意:由于这里需要绘制100个圆,所以每当画一个圆时重新定义绘制开始坐标即:ctx.moveTo(p.x,p.y);否则会出现异样效果,不信可以试试呀

5、雪花飘动

上面我们已经画出100个雪花,可惜只能依靠刷新网页才能看到变化效果,但是我们需要实现的是雪花不停的移动位置。

首先我们需要借助setInterval函数不停的重画雪花,这里间隔时间为50毫秒:setInterval(DrawSnow,50);

同时每一朵雪花的坐标(X、Y)需要不停的改变(在一定幅度内),我们这里的雪花是从左上方飘落到右下方,所以每朵X、Y坐标值都在不停的增大,那我们用一个函数SnowFall()定义雪花飘过规则

该函数代码如下:

JavaScript Code复制内容到剪贴板

//雪花飘落   
function SnowFall() {   
    for (var i = 0; i < snow; i++) {   
        var p = arr[i];   
        p.y += Math.random() * 2 + 1;   
        if (p.y > hei) {   
            p.y = 0;   
        }   
        p.x += Math.random() * 2 + 1;   
        if (p.x > wid) {   
            p.x = 0;   
    <span style="white-space:pre">    </span>}   
    }   
}
登入後複製

然后将该函数放入DrawSnow()执行,注意:我们每隔50毫毛重画雪花,必须擦除画布,所以DrawSnow()函数体内必须在前面执行clearRect()函数,即:ctx.clearRect(0, 0, wid, hei);

此时DrawSnow函数定义如下:

JavaScript Code复制内容到剪贴板

//画雪花   
function DrawSnow() {   
    ctx.clearRect(0, 0, wid, hei);   
    ctx.fillStyle = "white";   
    ctx.beginPath();   
    for (var i = 0; i < snow; i++) {   
        var p = arr[i];   
        ctx.moveTo(p.x, p.y);   
        ctx.arc(p.x, p.y, p.r, 0, 2 * Math.PI, false);   
    }   
    ctx.fill();   
    SnowFall();   
    ctx.closePath();   
}
登入後複製

最后执行setInterval(DrawSnow, 50);

OK,经过我们上述步骤,小伙伴们是否已经对整个过程及技术实现很清晰了。

完整代码如下(大家可以直接复制到自己项目中执行,测试下效果):

XML/HTML Code复制内容到剪贴板

<!DOCTYPE html>  
<html>  
    <head>  
        <meta charset="utf-8" />  
        <title></title>  
        <script src="js/jquery-1.8.3.min.js"></script>  
        <style type="text/css">  
            * {   
                margin: 0;   
                padding: 0;   
            }   
               
            #mycanvas {   
                background: black;   
            }   
        </style>  
    </head>  
  
    <body>  
        <canvas id="mycanvas">  
            您的浏览器不支持canvas画布   
        </canvas>  
        <script>  
            //获取mycanvas画布   
            var can = document.getElementById("mycanvas");   
            var ctx = can.getContext("2d");   
            //画布宽度   
            var wid = window.innerWidth;   
            //画布高度   
            var hei = window.innerHeight;   
            can.width = wid;   
            can.height = hei;   
            //雪花数目   
            var snow = 100;   
            //雪花坐标、半径   
            var arr = []; //保存各圆坐标及半径   
            for (var i = 0; i < snow; i++) {   
                arr.push({   
                    x: Math.random() * wid,   
                    y: Math.random() * hei,   
                    r: Math.random() * 10 + 1   
                })   
            }   
            //画雪花   
            function DrawSnow() {   
                ctx.clearRect(0, 0, wid, hei);   
                ctx.fillStyle = "white";   
                ctx.beginPath();   
                for (var i = 0; i < snow; i++) {   
                    var p = arr[i];   
                    ctx.moveTo(p.x, p.y);   
                    ctx.arc(p.x, p.y, p.r, 0, 2 * Math.PI, false);   
                }   
                ctx.fill();   
                SnowFall();   
                ctx.closePath();   
            }   
            //雪花飘落   
            function SnowFall() {   
                for (var i = 0; i < snow; i++) {   
                    var p = arr[i];   
                    p.y += Math.random() * 2 + 1;   
                    if (p.y > hei) {   
                        p.y = 0;   
                    }   
                    p.x += Math.random() * 2 + 1;   
                    if (p.x > wid) {   
                        p.x = 0;   
                    }   
                }   
            }   
            setInterval(DrawSnow, 50);   
        </script>  
    </body>  
  
</html>
登入後複製

【相关推荐】

1. 特别推荐“php程序员工具箱”V0.1版本下载

2. h5 Canvas中Fill 与Stroke文字效果实现实例

3. 分享用canvas实现水流和水池动画的代码

以上是h5canvas實現雪花飄落的特效程式碼的詳細內容。更多資訊請關注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)

如何使用Vue實現彈出視窗特效 如何使用Vue實現彈出視窗特效 Sep 22, 2023 am 09:40 AM

如何使用Vue實現彈出視窗特效,需要具體程式碼範例近年來,隨著Web應用的發展,彈出視窗特效已成為廣大開發者常用的互動方式之一。 Vue作為一款受歡迎的JavaScript框架,提供了豐富的功能和易用性,非常適合用來實現彈出視窗特效。本文將介紹如何使用Vue實現彈出視窗特效,並提供具體程式碼範例。首先,我們需要使用Vue的CLI工具來建立一個新的Vue專案。打開終

實作微信小程式中的卡片翻轉特效 實作微信小程式中的卡片翻轉特效 Nov 21, 2023 am 10:55 AM

實作微信小程式中的卡片翻轉特效在微信小程式中,實現卡片翻轉特效是一種常見的動畫效果,可以提升使用者體驗和介面互動的吸引力。以下將具體介紹如何在微信小程式中實現卡片翻轉的特效,並提供相關程式碼範例。首先,需要在小程式的頁面佈局檔案中定義兩個卡片元素,一個用於顯示正面內容,一個用於顯示背面內容,具體範例程式碼如下:&lt;!--index.wxml--&gt;&l

HTML、CSS與jQuery:實現圖片折疊展開特效的技巧 HTML、CSS與jQuery:實現圖片折疊展開特效的技巧 Oct 24, 2023 am 11:05 AM

HTML、CSS和jQuery:實現圖片折疊展開特效的技巧介紹在網頁設計和開發中,我們經常需要實現一些動態特效來增加頁面的吸引力和互動性。其中,圖片折疊展開特效是常見但又很有趣的技巧。透過這種特效,我們可以讓圖片在使用者的操作下折疊或展開,從而展示更多的內容或細節。本文將介紹如何使用HTML、CSS和jQuery來實現這種效果,並附上具體的程式碼範例。實現思

學習canvas框架 詳解常用的canvas框架 學習canvas框架 詳解常用的canvas框架 Jan 17, 2024 am 11:03 AM

探索Canvas框架:了解常用的Canvas框架有哪些,需要具體程式碼範例引言:Canvas是HTML5中提供的一個繪圖API,透過它我們可以實現豐富的圖形和動畫效果。為了提高繪圖的效率和便利性,許多開發者開發了不同的Canvas框架。本文將介紹一些常用的Canvas框架,並提供具體程式碼範例,以幫助讀者更深入地了解這些框架的使用方法。一、EaselJS框架Ea

關閉Win10滑鼠軌跡特效的步驟 關閉Win10滑鼠軌跡特效的步驟 Dec 31, 2023 pm 09:53 PM

我們在使用win10系統的時候,可以進行很多個人化的設置,其中就包括滑鼠軌跡的特效,不過很多的用戶並不知道win10滑鼠軌跡特效如何關閉,為此我們帶來了詳細的方法。 win10滑鼠軌跡特效如何關閉:1、先在桌面空白處右鍵,然後點選「個人化」。 2、然後點選左側的「主題」選擇右側的「滑鼠遊標」。 3.進入屬性之後,可以看到並選擇「指標選項」。 4、然後下拉可以看到可見性,此時的√是勾選的。 5.取消勾選,再點選應用,確定即可。

uniapp實現如何使用canvas繪製圖表和動畫效果 uniapp實現如何使用canvas繪製圖表和動畫效果 Oct 18, 2023 am 10:42 AM

uniapp實現如何使用canvas繪製圖表和動畫效果,需要具體程式碼範例一、引言隨著行動裝置的普及,越來越多的應用程式需要在行動裝置上展示各種圖表和動畫效果。而uniapp作為一款基於Vue.js的跨平台開發框架,提供了使用canvas繪製圖表和動畫效果的能力。本文將介紹uniapp如何使用canvas來實現圖表和動畫效果,並給出具體的程式碼範例。二、canvas

如何使用Vue實現影片播放器特效 如何使用Vue實現影片播放器特效 Sep 20, 2023 pm 03:43 PM

如何使用Vue實作影片播放器特效摘要:本文將介紹如何使用Vue.js框架實作一個有各種特效的影片播放器。我們將使用Vue指令和元件來實現播放/暫停按鈕、進度條、音量控制以及全螢幕功能。同時,我們也將添加一些動畫效果來增強使用者體驗。以下將針對不同的特效分別進行詳細介紹,包括程式碼範例。播放/暫停按鈕特效:使用Vue指令來實現播放/暫停按鈕特效是非常簡單的。首先,

揭秘Canvas API:從簡單繪圖到進階特效無所不包 揭秘Canvas API:從簡單繪圖到進階特效無所不包 Jan 17, 2024 am 09:44 AM

CanvasAPI是HTML5提供的一個強大的繪圖工具,可實現從基礎繪圖到進階特效的各種功能。本文將帶您深入了解CanvasAPI的使用方法,並提供具體的程式碼範例。基礎繪圖CanvasAPI最基礎的就是繪製簡單的圖形,例如長方形、圓形、直線等。下面是一個建立矩形並填滿顏色的程式碼範例:constcanvas=document.getElementB

See all articles