婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > 使用canvas實(shí)現(xiàn)雪花飄動(dòng)效果的示例代碼

使用canvas實(shí)現(xiàn)雪花飄動(dòng)效果的示例代碼

熱門標(biāo)簽:智能語(yǔ)音電銷機(jī)器人客戶端 高德地圖標(biāo)注廁所 江西ai電銷機(jī)器人如何 西安金倫外呼系統(tǒng) 地圖標(biāo)注沿海城市房?jī)r(jià) 威海語(yǔ)音外呼系統(tǒng)平臺(tái) 中國(guó)地圖標(biāo)注城市的 地圖標(biāo)注員工作內(nèi)容 通遼地圖標(biāo)注app

今天我們就使用canvas來(lái)實(shí)現(xiàn)雪花飄落的效果❄️

一、canvas是什么?

HTML5 <canvas> 元素用于圖形的繪制,通過(guò)腳本 (通常是JavaScript)來(lái)完成.

<canvas> 標(biāo)簽只是圖形容器,您必須使用腳本來(lái)繪制圖形。

你可以通過(guò)多種方法使用 canvas 繪制路徑,盒、圓、字符以及添加圖像。

二、canvas的基本用法

1.創(chuàng)建一個(gè)畫(huà)布(Canvas)

<canvas id="myCanvas" width="200" height="100"></canvas>

2.使用JavaScript繪制圖像

//首先找到<canvas>元素
var c=document.getElementById("myCanvas");
//然后創(chuàng)建context對(duì)象
var ctx=c.getContext("2d");
//下面的兩行代碼繪制一個(gè)紅色的矩形:
ctx.fillStyle="#FF0000";
ctx.fillRect(0,0,150,75);

getContext("2d") 對(duì)象是內(nèi)建的 HTML5 對(duì)象,擁有多種繪制路徑、矩形、圓形、字符以及添加圖像的方法。

設(shè)置fillStyle屬性可以是CSS顏色,漸變,或圖案。fillStyle 默認(rèn)設(shè)置是#000000。

3.Canvas 坐標(biāo)

canvas 是一個(gè)二維網(wǎng)格。
canvas 的左上角坐標(biāo)為 (0,0)
ctx.fillRect(0,0,150,75);
上面的 fillRect 方法擁有參數(shù) (0,0,150,75)。
意思是:在畫(huà)布上繪制 150x75 的矩形,從左上角開(kāi)始 (0,0)。

4.Canvas - 路徑

moveTo(x,y) 定義線條開(kāi)始坐標(biāo)
lineTo(x,y) 定義線條結(jié)束坐標(biāo)
在canvas中繪制圓形, 我們將使用以下方法:

arc(x,y,r,start,stop)

使用arc() 畫(huà)一個(gè)圓

var c=document.getElementById("myCanvas");
var ctx=c.getContext("2d");
ctx.beginPath();
ctx.arc(95,50,40,0,2*Math.PI);
ctx.stroke();

三、實(shí)現(xiàn)雪花飄動(dòng)的思路

1.創(chuàng)建一個(gè)畫(huà)布(Canvas)

 var canvas =document.getElementById("canvas")
    //參數(shù) contextID 指定了您想要在畫(huà)布上繪制的類型。
    //當(dāng)前唯一的合法值是 "2d",它指定了二維繪圖,
    //并且導(dǎo)致這個(gè)方法返回一個(gè)環(huán)境對(duì)象,該對(duì)象導(dǎo)出一個(gè)二維繪圖 API。
    var context = canvas.getContext("2d")
    var w =window.innerWidth
    var h =window.innerHeight
    canvas.width = w;
    canvas.height =h;

2.創(chuàng)建雪花的對(duì)象數(shù)組

 var count =200 //雪花的個(gè)數(shù)
    var snows=[] //雪花對(duì)象數(shù)組
    for (var i=0 ; i< count;i++){
        snows.push({
            x:Math.random()*w,//Math.random()用于生成0~1的隨機(jī)數(shù)
            y:Math.random()*h,
            r:Math.random()*5,
        })
    }

3.繪制雪花樣式

 function draw(){
        context.clearRect(0,0,w,h)
        context.beginPath()
        for(var i=0; i<count;i++){
            var snow = snows[i];//遍歷每一片雪花
            context.fillStyle ="rgb(255,255,255)" //設(shè)置雪花的樣式
            context.shadowBlur=10;
            context.shadowColor="rgb(255,255,255)";
            //moveTo 的方法是可以移動(dòng)到指定的坐標(biāo)
            context.moveTo(snow.x,snow.y)
            // 使用canvas arc()創(chuàng)建一個(gè)圓形
             //x,y,r:圓的中心的x坐標(biāo)和y坐標(biāo),r為半徑
            //0,Math.PI * 2起始弧度和結(jié)束弧度
            
            context.arc(snow.x,snow.y,snow.r,0,Math.PI * 2)
            
        }
        //畫(huà)布填充
        context.fill()
        move()
    }

4.實(shí)現(xiàn)雪花飄動(dòng)

 function move(){
        for (var i=0;i<count;i++){
            var snow =snows[i];
            snow.y +=(7-snow.r)/10 //從上往下飄落
            snow.x+=((5-snow.r)/10)//從左到右飄落
            if(snow.y>h){
                snows[i]={
                    x:Math.random()*w,
                    y:Math.random()*h,
                    r:Math.random()*5,
                }
            }
        }
    }

5.設(shè)置刷新

  draw()
    //每毫秒刷新一次
 setInterval(draw,1)

6.完整代碼

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>雪花飄飄之使用canvas元素用于在網(wǎng)頁(yè)上繪制圖形。</title>
 
 <style type="text/css">
  *{
            margin:0;
            padding:0;
            /* background-color: seagreen; */
            background: url("雪人.jpg")  no-repeat;
            background-size:100% 100%;
        }
  /* .can{
            filter: blur(1px);
        } */
 </style>
</head>
<body>
 <canvas id="canvas" class="can"></canvas>

 <script type="text/javascript">
    //canvas 元素用于在網(wǎng)頁(yè)上繪制圖形。
 var canvas =document.getElementById("canvas")
    //參數(shù) contextID 指定了您想要在畫(huà)布上繪制的類型。
    //當(dāng)前唯一的合法值是 "2d",它指定了二維繪圖,
    //并且導(dǎo)致這個(gè)方法返回一個(gè)環(huán)境對(duì)象,該對(duì)象導(dǎo)出一個(gè)二維繪圖 API。
    var context = canvas.getContext("2d")
    var w =window.innerWidth
    var h =window.innerHeight
    canvas.width = w;
    canvas.height =h;
    var count =200 //雪花的個(gè)數(shù)
    var snows=[] //雪花對(duì)象數(shù)組
    for (var i=0 ; i< count;i++){
        snows.push({
            x:Math.random()*w,//Math.random()用于生成0~1的隨機(jī)數(shù)
            y:Math.random()*h,
            r:Math.random()*5,
        })
    }
    //繪制雪花
    function draw(){
        context.clearRect(0,0,w,h)
        context.beginPath()
        for(var i=0; i<count;i++){
            var snow = snows[i];//遍歷每一片雪花
            context.fillStyle ="rgb(255,255,255)" //設(shè)置雪花的樣式
            context.shadowBlur=10;
            context.shadowColor="rgb(255,255,255)";
            //moveTo 的方法是可以移動(dòng)到指定的坐標(biāo)
            context.moveTo(snow.x,snow.y)
            // 使用canvas arc()創(chuàng)建一個(gè)圓形
             //x,y,r:圓的中心的x坐標(biāo)和y坐標(biāo),r為半徑
            //0,Math.PI * 2起始弧度和結(jié)束弧度
            
            context.arc(snow.x,snow.y,snow.r,0,Math.PI * 2)
           
            
        }
        //畫(huà)布填充
        context.fill()
        move()
    }
    //雪花飄動(dòng)
    function move(){
        for (var i=0;i<count;i++){
            var snow =snows[i];
            snow.y +=(7-snow.r)/10 //從上往下飄落
            snow.x+=((5-snow.r)/10)//從左到右飄落
            if(snow.y>h){
                snows[i]={
                    x:Math.random()*w,
                    y:Math.random()*h,
                    r:Math.random()*5,
                }
            }
        }
    }
    draw()
    //每毫秒刷新一次
 setInterval(draw,1)
 </script>
</body>
</html>

總結(jié)

到此這篇關(guān)于使用canvas實(shí)現(xiàn)雪花飄動(dòng)效果的示例代碼的文章就介紹到這了,更多相關(guān)canvas雪花飄動(dòng)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!

標(biāo)簽:營(yíng)口 北海 河池 眉山 阜陽(yáng) 青海 晉中 崇左

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用canvas實(shí)現(xiàn)雪花飄動(dòng)效果的示例代碼》,本文關(guān)鍵詞  使用,canvas,實(shí)現(xiàn),雪花,飄動(dòng),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《使用canvas實(shí)現(xiàn)雪花飄動(dòng)效果的示例代碼》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于使用canvas實(shí)現(xiàn)雪花飄動(dòng)效果的示例代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    成人av免费网站| 欧美精品一区视频| 在线视频你懂得一区| 一级日本不卡的影视| 日韩av在线免费观看不卡| 成人av网址在线观看| 久久久蜜臀国产一区二区| 7777精品伊人久久久大香线蕉的| gogo大胆日本视频一区| 国产亚洲欧美在线| 国产精品久久久久久户外露出| 2021国产精品久久精品| 欧美日韩免费在线视频| 91麻豆精品国产91久久久使用方法| 欧美成人女星排行榜| 国产精品第13页| 亚洲欧美一区二区三区国产精品| 九一久久久久久| ww亚洲ww在线观看国产| 亚洲一区二区三区美女| 狂野欧美性猛交blacked| 国产成人精品三级麻豆| 欧美亚洲国产一区二区三区va | 国产精品人妖ts系列视频| 亚洲欧美欧美一区二区三区| 日本精品一区二区三区高清| 麻豆久久久久久| 亚洲免费看黄网站| 成人深夜福利app| 极品少妇一区二区| 成人网在线播放| 亚洲精品日韩专区silk| 国产乱人伦偷精品视频不卡| 欧美猛男男办公室激情| 日韩一区二区视频| 高清国产一区二区三区| 国产精品福利av | 欧美精选在线播放| 精品一区二区三区av| 一区二区高清免费观看影视大全| wwww国产精品欧美| 欧美亚洲国产一区在线观看网站 | 日韩欧美成人午夜| 欧美大度的电影原声| 欧美日韩黄色影视| 欧美精品视频www在线观看| 欧美日本在线看| 日韩午夜电影在线观看| 日韩欧美一区二区不卡| 精品电影一区二区| 久久久高清一区二区三区| 久久久不卡影院| 国产精品国产三级国产a| 成人欧美一区二区三区视频网页| 国产精品久久久久婷婷| 亚洲三级久久久| 亚洲另类在线一区| 五月综合激情日本mⅴ| 久久av资源站| 99视频在线观看一区三区| 欧美亚一区二区| 欧美一级电影网站| 精品国产一区二区三区四区四| 日韩精品一区二区三区在线观看 | 亚洲一区成人在线| 成人激情视频网站| 国产精品久久久久久妇女6080| 欧美一区二区在线播放| 精品少妇一区二区三区免费观看| 精品电影一区二区| 欧美精品xxxxbbbb| 日韩你懂的在线播放| 国产日韩欧美精品在线| 免费人成黄页网站在线一区二区| 国产精品午夜在线观看| 99久久精品国产精品久久| 不卡欧美aaaaa| 在线观看91精品国产麻豆| 精品视频一区三区九区| 91精品91久久久中77777| 99久久99精品久久久久久| 色视频成人在线观看免| 欧美日高清视频| 91精品欧美一区二区三区综合在| 日韩一区二区免费在线电影| 精品久久一区二区| 久久久久久久综合狠狠综合| 亚洲在线视频一区| 青娱乐精品在线视频| 国精品**一区二区三区在线蜜桃| 国产专区欧美精品| 国产麻豆视频一区| 91小视频在线观看| 91精品国产综合久久久久久久 | 成人免费高清在线观看| 国产精选一区二区三区| 色屁屁一区二区| 精品捆绑美女sm三区| 亚洲男人的天堂一区二区| 青青草国产精品97视觉盛宴| 麻豆精品一二三| 成人精品免费视频| 欧美一区二区三区在| 夜夜嗨av一区二区三区| 成人app在线观看| 国产午夜精品久久| 日本成人超碰在线观看| 在线观看免费亚洲| 亚洲一线二线三线视频| 激情久久五月天| 久久免费视频一区| 韩国一区二区在线观看| 日韩午夜小视频| 天天色图综合网| 在线观看欧美黄色| 欧美激情自拍偷拍| 日韩激情中文字幕| 色综合色综合色综合色综合色综合| 久久免费美女视频| 免费久久精品视频| 欧美高清视频不卡网| 欧美一区二区三区啪啪| 国产精品久久看| 国产精品中文欧美| 日韩欧美一区中文| 亚洲午夜一区二区三区| 99re热这里只有精品视频| 亚洲国产精品黑人久久久| 亚洲成人手机在线| 色94色欧美sute亚洲线路一久| 亚洲三级免费电影| 国产夫妻精品视频| 精品国产三级电影在线观看| 国产一区二区三区四区五区美女 | 色综合久久88色综合天天免费| 欧美成人vr18sexvr| 美腿丝袜亚洲色图| 国产午夜亚洲精品羞羞网站| 国产成人综合精品三级| 成人免费一区二区三区视频| 在线电影一区二区三区| 国产综合色视频| 国产欧美一区二区三区沐欲 | 久久精品久久综合| 26uuu亚洲综合色| 成人国产精品免费网站| 一区二区三区中文字幕电影 | 精品美女在线观看| 亚洲欧美另类久久久精品| 91亚洲精品乱码久久久久久蜜桃 | 久久国产精品99精品国产| 欧美一区二区观看视频| 国产精品77777竹菊影视小说| 亚洲黄色录像片| 欧美一级久久久久久久大片| 国产超碰在线一区| 亚洲欧美日韩国产综合在线 | 亚洲国产激情av| 色中色一区二区| 亚洲美女少妇撒尿| 欧美乱妇15p| 国产精品77777竹菊影视小说| 国产精品免费看片| 欧美日韩国产三级| 国产精品18久久久久| 一区二区三区中文免费| 中文一区在线播放| 精品国产乱码久久| 3d动漫精品啪啪| av色综合久久天堂av综合| 国产毛片精品视频| 日韩精品一级中文字幕精品视频免费观看 | 久久99精品久久久久久国产越南| 国产精品女上位| 精品电影一区二区| 精品视频在线看| 国产99一区视频免费| 日韩高清一区二区| 一区二区三区中文在线| 亚洲蜜臀av乱码久久精品| 国产精品成人一区二区三区夜夜夜| 精品国产区一区| 8v天堂国产在线一区二区| 欧美日韩国产高清一区二区三区 | 热久久久久久久| 国产视频一区二区在线| 欧美一级欧美三级在线观看| 欧美女孩性生活视频| jizzjizzjizz欧美| 免费一级欧美片在线观看| 亚洲午夜精品在线| 综合久久久久综合| 中文字幕av在线一区二区三区| 日韩精品一区二区在线| 欧美人动与zoxxxx乱| 欧美日韩大陆一区二区| 久久综合久色欧美综合狠狠| 2023国产精品自拍| 亚洲国产精品激情在线观看| 亚洲综合av网|