成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > 5分鐘實(shí)現(xiàn)Canvas鼠標(biāo)跟隨動畫背景

5分鐘實(shí)現(xiàn)Canvas鼠標(biāo)跟隨動畫背景

熱門標(biāo)簽:黃石ai電銷機(jī)器人呼叫中心 欣鼎電銷機(jī)器人 效果 惡搞電話機(jī)器人 如何查看地圖標(biāo)注 電話機(jī)器人技術(shù) ok電銷機(jī)器人 高德地圖標(biāo)注商戶怎么標(biāo) 智能電銷機(jī)器人被禁用了么 地圖標(biāo)注軟件打印出來

關(guān)于Canvas制作炫酷背景,我會在git上不定時去更新,并會附上詳細(xì)的解析,如果有喜歡的話,可以到git上瞧瞧

gitHub傳送門

前言

相信很多前端小白都看過這樣的背景動畫,也好奇如何去實(shí)現(xiàn)這種效果!將這種效果應(yīng)用到自己的個人網(wǎng)站上,會讓整個網(wǎng)站變得與眾不同!

 

下面我會直擊重點(diǎn),用最短的時間,使用 Canvas 制作 鼠標(biāo)跟隨動畫

 如何制作動畫

常用的繪圖動畫的方式有以下幾種:

  • CSS3
  • SVG
  • Canvas
  • WebGL

讓我們先分析分析這些方法的優(yōu)劣性

  • CSS3 通過css3的關(guān)鍵幀等方式實(shí)現(xiàn)動畫效果,看起來好像挺實(shí)用,但這樣增加了一個沒有意義的DOM節(jié)點(diǎn),不符合語義化編程規(guī)范
  • SVG、Canvas 都可以使用腳本語言來實(shí)現(xiàn)動畫
    • SVG 本質(zhì)上是使用XML描述2D圖形的語言(矢量圖),SVG創(chuàng)建的每一個元素都是一個獨(dú)立的DOM元素,既然是獨(dú)立的DOM元素,那表示我們可以通過CSS和JS來控制DOM,也可以對每一個DOM元素進(jìn)行監(jiān)聽,但由于都是DOM元素,所以如果我們修改了SVG中的DOM元素,瀏覽器就會自動進(jìn)行DOM重繪
    • Canvas通過Javascript來繪制2D圖形(位圖),而Canvas只是一個HTML元素,其中的圖形不會單獨(dú)創(chuàng)建DOM元素,所以我們無法通過Js來操作Canvas內(nèi)的圖形,也無法監(jiān)聽具體圖形
  • WebGL 用于3D展示、動畫、游戲,說白了就是基于Canvas的3D框架

 Canvas、SVG適用場景

  • Canvas 適用于位圖,高數(shù)據(jù)量繪制頻率的場景,小游戲,小特效,繪制圖表、活動頁面、炫酷背景
  • SVG 適用于矢量圖,低數(shù)據(jù)量繪制頻率的場景,如圖形圖表

直擊重點(diǎn),制作鼠標(biāo)跟隨動畫

最終效果

需求分析:鼠標(biāo)移動,經(jīng)過的地方創(chuàng)建一個圓,圓的半徑大小由小變大,達(dá)到某個固定大小時該圓消失,圓的顏色隨機(jī)變化

創(chuàng)建全屏Canvas元素

var canvas = document.getElementById('canvas'),
    ctx = canvas.getContext('2d'),
    WIDTH = canvas.width = document.documentElement.clientWidth,
    HEIGHT = canvas.height = document.documentElement.clientHeight,
    para = {
        num: 100,
        color: false,    //  顏色  如果是false 則是隨機(jī)漸變顏色
        radius: 0.9,          //   圓每次增加的半徑 
        o: 0.09,         //      判斷圓消失的條件,數(shù)值越大,消失的越快
    },
    color,
    circleColor,
    round_arr = [];     // 存放圓的數(shù)組 

監(jiān)聽鼠標(biāo) onmousemove 事件

需求:在鼠標(biāo)移動的過程中,不斷在鼠標(biāo)滑過的位置產(chǎn)生一個逐漸變大的圓

Canvas中創(chuàng)建動畫的方式就是不斷的清除屏幕然后重繪

由于移動的軌跡是由一個個圓構(gòu)成,那我們就應(yīng)該使用數(shù)組存儲圓的信息(xy坐標(biāo),半徑),然后在鼠標(biāo)移動的時候?qū)⑹髽?biāo)的位置信息存放在數(shù)組中

所以監(jiān)聽onmousemove事件就是為了拿到鼠標(biāo)的信息

window.onmousemove = function(event) {
    X = event.clientX  // 當(dāng)前在屏幕的x位置
    Y = event.clientY  // 當(dāng)前在屏幕的y位置

    // 將信息存入圓數(shù)組
    round_arr.push({
        X:X,
        Y:Y,
        radius:para.radius
        o:1
    })
}

設(shè)置 color

在onmousemove中,我們已經(jīng)將坐標(biāo)信息和半徑存入round_arr圓數(shù)組中,接下來就設(shè)置顏色了

在para對象里,默認(rèn)的color是false,說明圓的顏色是隨機(jī)的,如果color不為false,則圓的顏色就為color的顏色

if(para.color){
    circleColor = para.color
}else{
    color = Math.random() * 360
}

若想要設(shè)置顏色漸變
if (!para.color) {
    color += .1;
    circleColor = 'hsl(' + color + ',100%,80%)';
}

如果要讓顏色變化,則需要將顏色變化的代碼放在一個會一直執(zhí)行的函數(shù)

定義 animation() 函數(shù) !important

function animate() {

    if (!para.color) {         # 設(shè)置顏色
        color += .1
        color2 = 'hsl(' + color + ',100%,80%)'
    }

    ctx.clearRect(0, 0, WIDTH, HEIGHT)      # 清除屏幕

    for (var i = 0; i < round_arr.length; i++) {

        ctx.fillStyle = circleColor 
        ctx.beginPath()
        ctx.arc( round_arr[i].X ,round_arr[i].Y,round_arr[i].radius,0, Math.PI * 2)     # 畫圓
        ctx.closePath()
        ctx.fill()
        round_arr[i].radius += para.radius    # 增大半徑
        round_arr[i].o -= para.o    # 消失快慢

        if( round_arr[i].o <= 0){       # 移除圓
            round_arr.splice(i,1)
            i--
        }
    }

    window.requestAnimationFrame(animate)   # 使用一個回調(diào)函數(shù)作為參數(shù),這個回調(diào)函數(shù)會在瀏覽器重繪之前調(diào)用
}

requestAnimationFrame()會告訴瀏覽器,你需要執(zhí)行動畫,并請求瀏覽器調(diào)用指定的函數(shù)在下一次重繪之前更新動畫。requestAnimationFrame()使用一個回調(diào)函數(shù)作為參數(shù),這個回調(diào)函數(shù)會在瀏覽器重繪之前調(diào)用

完整代碼

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

<head>
    <meta charset="UTF-8">
    <title>鼠標(biāo)屏幕互動動畫</title>
    <style>
        * {
            padding: 0;
            margin: 0;
        }
        
        #canvas {
            background: #000;
        }
    </style>
</head>

<body>
    <canvas id="canvas"></canvas>
    <script>
        var canvas = document.getElementById('canvas'),
            ctx = canvas.getContext('2d'),
            WIDTH = canvas.width = document.documentElement.clientWidth,
            HEIGHT = canvas.height = document.documentElement.clientHeight,
            para = {
                num: 100,
                color: false, //  顏色  如果是false 則是隨機(jī)漸變顏色
                radius: 0.9,
                o: 0.09, //  判斷圓消失的條件,數(shù)值越大,消失的越快
            },
            color,
            circleColor,
            round_arr = [];

        window.onmousemove = function(event) {
            X = event.clientX
            Y = event.clientY

            round_arr.push({
                X: X,
                Y: Y,
                radius: para.radius,
                o: 1
            })
        }

        // 判斷參數(shù)中是否設(shè)置color,設(shè)置則使用該color,否則為隨機(jī)
        if (para.color) {
            circleColor = para.color
        } else {
            color = Math.random() * 360
        }

        function animate() {
            if (!para.color) {
                color += .1
                circleColor = 'hsl(' + color + ',100%,80%)'
            }

            ctx.clearRect(0, 0, WIDTH, HEIGHT) // 清除屏幕

            for (var i = 0; i < round_arr.length; i++) {
                ctx.fillStyle = circleColor
                ctx.beginPath() // 開始路徑
                ctx.arc(round_arr[i].X, round_arr[i].Y, round_arr[i].radius, 0, Math.PI * 2) // 畫圓
                ctx.closePath() // 結(jié)束路徑
                ctx.fill()
                round_arr[i].radius += para.radius // 增大圓
                round_arr[i].o -= para.o //  消失時間變快

                if (round_arr[i].o <= 0) {
                    round_arr.splice(i, 1);
                    i--;
                }
            }

            window.requestAnimationFrame(animate)
        }

        animate()
    </script>
</body>

</html>

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:聊城 中山 阿壩 綏化 金昌 萍鄉(xiāng) 赤峰 盤錦

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《5分鐘實(shí)現(xiàn)Canvas鼠標(biāo)跟隨動畫背景》,本文關(guān)鍵詞  5分鐘,實(shí)現(xiàn),Canvas,鼠標(biāo),跟隨,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《5分鐘實(shí)現(xiàn)Canvas鼠標(biāo)跟隨動畫背景》相關(guān)的同類信息!
  • 本頁收集關(guān)于5分鐘實(shí)現(xiàn)Canvas鼠標(biāo)跟隨動畫背景的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    性生活一级大片| 永久免费成人代码| 91精品在线观看入口| 人成在线免费网站| 欧美日韩激情| 中文字幕色婷婷在线视频| www国产亚洲精品| 国产美女视频一区| 亚洲欧美小视频| 91色porny蝌蚪| 亚洲综合视频1区| 女性女同性aⅴ免费观女性恋| a一区二区三区| 欧美成人另类视频| 亚洲欧美综合另类中字| 亚洲国产精品久久久天堂| 午夜一区二区视频| 日日夜夜综合网| 国产精品熟妇一区二区三区四区| 国内精品嫩模av私拍在线观看| 亚洲男人的天堂一区二区| 蜜桃av一区| 97在线观看免费高清| 黄色片免费观看视频| 特级西西人体4444xxxx| 国产95在线|亚洲| 欧美日韩福利| 超碰97久久国产精品牛牛| 孩xxxx性bbbb欧美| 一区二区影院| 97在线电影| 欧美精品videofree1080p| 亚洲日本香蕉视频| 青青视频免费在线观看| 国产精品一区二区久久精品| 欧美激情在线精品一区二区三区| 蜜桃在线一区二区三区精品| 日韩一区二区三区四区视频| 亚洲av无码一区东京热久久| 日本精品一区二区三区高清 久久| 欧美三级午夜理伦三级老人| av在线电影播放| 人妻熟人中文字幕一区二区| 黑人操日本美女| 视频这里只有精品| 国产精品久久久久久成人| 国产亚洲女人久久久久毛片| 日韩欧美一区二区三区久久婷婷| 91久久久久久久久久久久久久| 日韩hd视频在线观看| 欧美日韩精品中文字幕一区二区| 久久欧美在线电影| 97精品国产福利一区二区三区| 三上悠亚 电影| 欧美精品一区二区三区四区| 一区二区三区不卡在线| 免费视频亚洲| 性欧美高清强烈性视频| 亚洲天堂导航| 日本在线天堂| 欧美日韩亚洲综合| 国产精品2区| 欧美一区二区中文字幕| 国产精品国产三级国产普通话对白| 日韩av在线一区二区| 国产黄色片在线播放| 在线国产情侣| 夜色福利刺激| 黄色免费大全亚洲| 日本精品网站| 狠狠精品干练久久久无码中文字幕| 精品国产免费久久久久久尖叫| 免费在线观看不卡| 蜜桃精品wwwmitaows| 欧美free嫩15| 欧美日韩亚洲一区二区三区在线| 免费观看成人鲁鲁鲁鲁鲁视频| 羞羞视频立即看| 国产色一区二区三区| 中文字幕在线播放不卡一区| 欧美成人女星排行榜| 欧美精品在线播放| 在线观看亚洲专区| 肥熟一91porny丨九色丨| 亚洲欧洲精品一区二区精品久久久| 精品精品欲导航| 国产成人精品三级麻豆| baoyu777.永久免费视频| 久久精品成人欧美大片| 亚洲va天堂va国产va久| 精品国产aaa| 真实新婚偷拍xxxxx| 国产精品美女在线观看直播| 久久精品视频网站| 欧美12一14sex性hd| 欧美自拍第一页| 日韩午夜小视频| a在线观看网站| 欧美自拍偷拍一区二区| 婷婷综合电影| 在线播放精品视频| 国产在线观看黄| 亚洲免费网站在线观看| 国产精品综合久久久| 中文字幕丰满人伦在线| 波多野结衣免费观看| 亚洲av片在线观看| 国产精品理人伦一区二区三区| 给个网站可以在线观看你懂的| 欧美成欧美va| 亚洲理论中文字幕| 久久久精品中文字幕| 久久91亚洲精品中文字幕| 挪威xxxx性hd极品| 国产麻豆入在线观看| 欧美独立站高清久久| 992tv国产精品成人影院| 免费污视频在线观看| 亚洲不卡在线播放| 亚洲三级性片| 青青草原成人在线视频| av片哪里在线观看| 波多野结衣一区二区在线| 亚洲一区二区三区免费| 九九爱免费视频在线观看| 免费一级特黄特色大片| 亚洲国产综合在线| 久草视频免费在线| 182在线视频| 国产精品久久久久婷婷| 国产911网站| 天海翼亚洲一区二区三区| 国产最新自拍视频| 一区二区久久久久久| 国产又色又爽又黄又免费| 国产精品手机视频| 成人资源在线| 国产二级一片内射视频播放| 国产无套内射又大又猛又粗又爽| 成年人视频网站免费| 日韩精品一页| 91精品久久久久久综合乱菊| 伊人影院蕉久影院在线播放| 天天综合天天添夜夜添狠狠添| 一道本在线免费视频| 欧美视频在线观看 亚洲欧| 男人天堂午夜在线| 久久精品亚洲一区| 美女性感视频久久| 欧美色综合网| 成人激情电影在线| 成人91在线| 久久久久久久久久免费视频| 福利视频第一区| 国产毛片一区二区三区| av中文字幕免费在线观看| 国产视频1区2区3区| 一级特黄aaa| 第一av在线| 国产一级做a爰片久久毛片男| 亚洲精品国产suv一区88| 色国产精品一区在线观看| 久久国产尿小便嘘嘘| 亚洲柠檬福利资源导航| 欧美另类久久久品| 亚洲天堂资源在线| 波多野结衣a v在线| av一区二区三区黑人| 成人羞羞视频免费看看| 欧美黄色免费视频| 波多野结衣一区二区三区在线观看| 9色在线视频网站| 亚洲色偷偷综合亚洲av伊人| 国内精品久久久久国产盗摄免费观看完整版| 国产激情视频网站| 日韩风俗一区 二区| 国产suv一区二区三区| 91精品久久久久久久久| 久久久国产亚洲精品| 91精品久久久久久久久久| 色吊一区二区三区| 日本人妻伦在线中文字幕| 可以免费观看的黄色网址| 永久91嫩草亚洲精品人人| 噜噜噜久久,亚洲精品国产品| 国产精品久久久久久久牛牛| 国产乱码精品一区二区三| 在线视频欧美性高潮| 一本一道人人妻人人妻αv| 在线观看免费av网| 国产一区二区高清不卡| 久久久久国产精品一区| 欧美做受高潮电影o| 极品白浆推特女神在线观看| 欧洲杯什么时候开赛| 欧洲精品一区二区三区久久| 最近2019免费中文字幕视频三| 亚洲区精品久久一区二区三区| 男人久久精品| 欧美激情论坛| 99re在线视频观看| 精品国产乱码久久久久久1区2匹| 懂色av成人一区二区三区| 国内久久婷婷综合| 国产大片在线免费观看| 99国产高清| 日本大胆欧美人术艺术动态| 久久精品噜噜噜成人av农村| 欧美福利网站| 97人人做人人人难人人做| 国产精品日韩精品在线播放| 波多野结衣在线观看一区二区| 欧美成人三级在线观看| 久久国产精品免费视频| 久久人人超碰| 国产欧美日韩在线一区二区| 综合图区亚洲| 男女爱爱视频网站| 欧美裸体视频| 精品51国产黑色丝袜高跟鞋| 久久久久久77777| 97人人爽人人澡人人精品| 亚洲天堂网在线观看| 欧美午夜电影一区| 五月激情在线| 色综合色狠狠综合色| 国产精品入口免费视| 久久久国际精品| xxxxxx国产精品视频| 国产精品久久久999| 欧美一级电影在线| 国产精品国产a级| 欧美一区二区三区免费观看| 亚洲男人天堂2023| 欧美与黑人午夜性猛交久久久| 久久这里只有精品视频首页| 久草香蕉在线| www.97视频| 日本少妇久久久| 欧美大片免费久久精品三p| 久久中文字幕国产| 4444在线观看| 最近中文字幕mv2018在线高清| 岛国大片在线免费观看| 国产黄色在线网站| 欧美日韩一级在线| 国产精品亚洲欧美导航| 免费成人午夜视频| 漫画在线观看av| 国产精品福利影院| 国产1区2区在线观看| 韩日视频在线| 91丨porny丨探花| 91精品国产综合久久精品性色| 毛片在线播放网址| mm131午夜| 在线看片免费人成视久网| 国产白浆在线免费观看| 久久r热视频| 九九热精品视频国产| 国产欧美日韩激情| 欧美精品中文字幕一区| 国产美女娇喘av呻吟久久| xxxwww在线观看| 永久免费av片在线观看全网站| 亚洲国产免费av| 亚洲午夜羞羞片| 99久久精品网站| 男人j桶女人的网站| 777电影在线观看| 97蝌蚪自拍自窝| 国产日韩欧美高清在线| 欧美女激情福利| 91视频 - 88av| 精品久久久久久无码人妻| 在线观看欧美视频| 国产馆手机在线观看| 久久精品水蜜桃av综合天堂| 九九热最新地址| 91精品国产综合久久久久久漫画| 不卡专区在线| 欧美日韩一区二区三区69堂| 久久久久国产精品厨房| 亚洲一区二区三区在线视频| 欧美一区二区三区视频免费| 只有这里有精品| 91free张津瑜movies| 国产又大又长又粗| 九九热精品视频在线观看| 色88久久久久高潮综合影院| 日韩精品视频在线免费观看| 国产一区一一区高清不卡| eeuss中文| 九九精品视频在线| 亚洲东热激情| 欧洲美女女同性互添| 毛片女人与拘交视频| 热99精品只有里视频最新| 国产精品无码专区| 亚洲欧美日韩在线播放| 天天综合天天色| 国产999精品视频| 中文字幕一区二区三中文字幕| 欧美国产精品| 黄色网页免费在线观看| 超碰超碰超碰超碰超碰| 日韩亚洲一区中文字幕| 综合图区欧美| 亚洲大胆av| 牛牛精品在线| 1区2区3区在线观看| yellow91字幕网在线| 蜜桃久久久久久久| 欧美成人三级伦在线观看| 国产真人无遮挡作爱免费视频| 今天的高清视频免费播放成人| 亚洲色图14p| 少妇无套内谢久久久久| 天天干天天草天天| 香蕉av在线| 在线中文字幕一区二区| 成人春色在线观看免费网站| 亚洲图片在线观看| 久久久噜噜噜www成人网| 国内成人精品2018免费看| 污导航在线观看| 国产成人免费av一区二区午夜| 欧美大胆a人体大胆做受|