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

主頁 > 知識庫 > 5分鐘實現Canvas鼠標跟隨動畫背景

5分鐘實現Canvas鼠標跟隨動畫背景

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

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

gitHub傳送門

前言

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

 

下面我會直擊重點,用最短的時間,使用 Canvas 制作 鼠標跟隨動畫

 如何制作動畫

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

  • CSS3
  • SVG
  • Canvas
  • WebGL

讓我們先分析分析這些方法的優劣性

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

 Canvas、SVG適用場景

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

直擊重點,制作鼠標跟隨動畫

最終效果

需求分析:鼠標移動,經過的地方創建一個圓,圓的半徑大小由小變大,達到某個固定大小時該圓消失,圓的顏色隨機變化

創建全屏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 則是隨機漸變顏色
        radius: 0.9,          //   圓每次增加的半徑 
        o: 0.09,         //      判斷圓消失的條件,數值越大,消失的越快
    },
    color,
    circleColor,
    round_arr = [];     // 存放圓的數組 

監聽鼠標 onmousemove 事件

需求:在鼠標移動的過程中,不斷在鼠標滑過的位置產生一個逐漸變大的圓

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

由于移動的軌跡是由一個個圓構成,那我們就應該使用數組存儲圓的信息(xy坐標,半徑),然后在鼠標移動的時候將鼠標的位置信息存放在數組中

所以監聽onmousemove事件就是為了拿到鼠標的信息

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

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

設置 color

在onmousemove中,我們已經將坐標信息和半徑存入round_arr圓數組中,接下來就設置顏色了

在para對象里,默認的color是false,說明圓的顏色是隨機的,如果color不為false,則圓的顏色就為color的顏色

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

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

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

定義 animation() 函數 !important

function animate() {

    if (!para.color) {         # 設置顏色
        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)   # 使用一個回調函數作為參數,這個回調函數會在瀏覽器重繪之前調用
}

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

完整代碼

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

<head>
    <meta charset="UTF-8">
    <title>鼠標屏幕互動動畫</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 則是隨機漸變顏色
                radius: 0.9,
                o: 0.09, //  判斷圓消失的條件,數值越大,消失的越快
            },
            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
            })
        }

        // 判斷參數中是否設置color,設置則使用該color,否則為隨機
        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() // 結束路徑
                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>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:聊城 中山 阿壩 綏化 金昌 萍鄉 赤峰 盤錦

巨人網絡通訊聲明:本文標題《5分鐘實現Canvas鼠標跟隨動畫背景》,本文關鍵詞  5分鐘,實現,Canvas,鼠標,跟隨,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《5分鐘實現Canvas鼠標跟隨動畫背景》相關的同類信息!
  • 本頁收集關于5分鐘實現Canvas鼠標跟隨動畫背景的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    福利一区福利二区| 秋霞电影一区二区| 99re66热这里只有精品3直播 | 91福利在线免费观看| 日韩精品高清不卡| 精品国产乱码久久久久久闺蜜| 国产乱国产乱300精品| 亚洲一区免费在线观看| 亚洲精品一区二区精华| 色婷婷综合久久久久中文一区二区 | 国产999精品久久| 午夜久久久影院| 1024成人网色www| 精品理论电影在线| 欧美高清激情brazzers| www精品美女久久久tv| 2023国产精华国产精品| 久久综合久久综合久久综合| 精品日韩在线一区| 亚洲精品一区二区三区99| 91成人在线观看喷潮| 欧美丰满嫩嫩电影| 日韩丝袜美女视频| 一区二区三区在线不卡| 亚洲激情av在线| 午夜精品福利一区二区蜜股av | 岛国一区二区在线观看| 午夜精品久久久久久不卡8050| 亚洲成人精品一区| 亚洲激情男女视频| 久久超碰97中文字幕| 国产成人鲁色资源国产91色综| 99精品视频在线免费观看| 91麻豆国产福利精品| 欧美视频一区在线观看| 日韩一区二区在线观看| 国产日韩精品一区二区三区在线| 欧美午夜精品久久久久久超碰| 欧美三级视频在线| 国产日产欧产精品推荐色 | 有码一区二区三区| 午夜精品一区二区三区三上悠亚| 国产精品一区在线| 日韩三级中文字幕| 一区二区高清在线| 91同城在线观看| 欧美日韩高清一区二区三区| 国产精品午夜在线| 精品一区二区日韩| 亚洲第四色夜色| 色综合色狠狠天天综合色| 欧美成va人片在线观看| 中文字幕中文在线不卡住| 国产成人8x视频一区二区| 欧美精品第1页| 亚洲日本电影在线| 成人性生交大片免费看中文网站| 欧美精品一区二区三区一线天视频 | 日韩一级黄色片| 亚洲靠逼com| 国产精华液一区二区三区| 欧美成人伊人久久综合网| 日韩欧美一区二区三区在线| 亚洲三级在线免费观看| 亚洲综合激情网| 免费在线一区观看| 国产偷国产偷亚洲高清人白洁| 亚洲精品国产第一综合99久久| 91麻豆123| 亚洲福利国产精品| 在线观看中文字幕不卡| 亚洲成人激情综合网| 欧美在线综合视频| 老司机免费视频一区二区三区| www.亚洲免费av| 1024精品合集| 日韩欧美高清一区| 91婷婷韩国欧美一区二区| 午夜精品久久久久久久久| 91麻豆精品国产91久久久更新时间| 美日韩一区二区| 一级女性全黄久久生活片免费| 欧美一级高清片在线观看| 丁香一区二区三区| 亚洲国产视频一区| 欧美亚洲尤物久久| 国产毛片精品国产一区二区三区| 一区二区三区在线视频播放| 日韩欧美aaaaaa| 欧美亚洲图片小说| 国产女主播视频一区二区| 在线播放/欧美激情| 成人国产亚洲欧美成人综合网| 东方欧美亚洲色图在线| 美女一区二区视频| 午夜精品视频在线观看| 久久免费偷拍视频| 国产综合色精品一区二区三区| 一区二区久久久久| 久久精品视频一区二区三区| 欧美日韩视频一区二区| 视频一区视频二区中文字幕| 亚洲欧美另类久久久精品| 精品国产成人系列| 国产一区二区久久| 免费在线观看不卡| 亚洲线精品一区二区三区| 国产精品私人自拍| www激情久久| 欧美影视一区二区三区| 亚洲一区二区三区四区的| 亚洲图片另类小说| 亚洲人一二三区| 久色婷婷小香蕉久久| 色婷婷国产精品综合在线观看| 日韩色视频在线观看| 亚洲制服丝袜在线| 99久久精品国产导航| 久久嫩草精品久久久久| 夜夜嗨av一区二区三区 | 欧美一区二区三区免费观看视频| 日本一区二区高清| 久久国产精品72免费观看| 欧美色图片你懂的| 国产女人18毛片水真多成人如厕| 秋霞午夜鲁丝一区二区老狼| 97久久超碰国产精品| 国产午夜亚洲精品午夜鲁丝片| 日日夜夜免费精品| 欧美在线free| 樱花影视一区二区| 91捆绑美女网站| 国产精品毛片久久久久久| 国产91在线观看| 69堂国产成人免费视频| 亚洲一区二区免费视频| 国产色91在线| 成人av在线电影| 亚洲日本中文字幕区| 一本久久a久久免费精品不卡| 国产精品久久久久国产精品日日| 国产99久久久国产精品潘金| 国产视频不卡一区| 成人免费毛片a| 国产精品成人一区二区艾草| 91一区二区在线| 一区二区三区精品视频在线| 91免费精品国自产拍在线不卡| 亚洲欧美二区三区| 99精品热视频| 亚洲一区二区欧美| 337p亚洲精品色噜噜狠狠| 首页综合国产亚洲丝袜| 日韩欧美专区在线| 风间由美一区二区三区在线观看| 国产日韩欧美精品电影三级在线| 成人午夜在线播放| 亚洲日本va午夜在线影院| 欧美三级乱人伦电影| 久久精品国产精品青草| 久久综合九色综合欧美亚洲| jlzzjlzz亚洲女人18| 国产精品电影一区二区| 国产成人免费视频网站| 亚洲人xxxx| 日韩欧美国产电影| 99精品久久久久久| 视频一区二区不卡| 国产欧美日韩精品在线| 欧美日韩一区久久| 国产曰批免费观看久久久| 亚洲人xxxx| 欧美va亚洲va| 在线观看亚洲精品视频| 经典三级在线一区| 亚洲午夜精品久久久久久久久| 日韩一级二级三级精品视频| 国产91丝袜在线播放九色| 亚洲国产一二三| 国产三级精品视频| 7777精品伊人久久久大香线蕉经典版下载 | 青青草国产成人av片免费| 久久久久国产精品麻豆ai换脸| 国产成人丝袜美腿| 亚洲123区在线观看| 精品国产一区二区三区av性色 | 国产精品毛片大码女人| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 国产综合久久久久影院| 国产69精品一区二区亚洲孕妇| 亚洲精品久久嫩草网站秘色| 精品国产第一区二区三区观看体验| 99精品热视频| 国产乱人伦偷精品视频不卡| 亚洲一区影音先锋| 亚洲国产成人在线| 精品国产一区a| 一本大道综合伊人精品热热| 欧美一级xxx| 欧美日韩国产一级片|