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

主頁 > 知識庫 > 解析html5 canvas實現背景鼠標連線動態效果代碼

解析html5 canvas實現背景鼠標連線動態效果代碼

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

流行的動態背景連線特效。下面的代碼是作者在扒下來的代碼上進行整理和注釋,很適應參考學習。

效果截圖:

效果演示:https://jc1144096387.github.io/canvas_nest/

作者地址:https://blog.csdn.net/u013556477/article/details/82819785

HTML代碼(測試代碼):

<!doctype html>
<html lang="en">    
<head>
 <meta charset="UTF-8">
 <meta name="Generator" content="EditPlus®">
 <meta name="Author" content="">
 <meta name="Keywords" content="">
 <meta name="Description" content="">
 <title>canvas場景連線特效</title>
 <style type="text/css">*{ margin: 0px; padding: 0px; } body{ background-color: #f4f4f4; }</style></head>

<body>
 <!-- <canvas id="c_n9" width="1366" height="403" style="position: fixed; top: 0px; left: 0px; z-index: -1; opacity: 0.5;"></canvas> -->
 <script type="text/javascript" src="test-clear.js" opacity=0 .6></script>
</body>
</html>

Javascript代碼:

//立即執行函數
//!的作用是告訴javascript引擎這是一個函數表達式,不是函數聲明,()、!、+、-等運算符都能實現這個作用,不過()是最安全的
//在!function(){}后面加上()會立即調用這個函數
//這樣做可以模仿一個私有作用域,這樣html文件引用多個js文件時便不會造成變量沖突
!
function() {
    //canvas元素相關
    //創建canvas元素,并設置canvas元素的id
    var canvas = document.createElement("canvas"),
    context = canvas.getContext("2d"),
    attr = getAttr();
    //設置創建的canvas的相關屬性
    canvas.id = "c_n" + attr.length;
    canvas.style.cssText = "position:fixed;top:0;left:0;z-index:" + attr.z + ";opacity:" + attr.opacity;
    //將canvas元素添加到body元素中
    document.getElementsByTagName("body")[0].appendChild(canvas);
    //該函數設置了canvas元素的width屬性和height屬性
    getWindowWH();
    //onresize 事件會在窗口或框架被調整大小時發生
    //此處即為當窗口大小改變時,重新獲取窗口的寬高和設置canvas元素的寬高
    window.onresize = getWindowWH;
    //該函數會得到引用了本文件的script元素,
    //因為本文件中在賦值時執行了一次getScript函數,html文件引用本文件時,本文件之后的script標簽還沒有被瀏覽器解釋,
    //所以得到的script數組中,引用了本文的script元素在該數組的末尾
    //該函數的用意為使開發者能直接修改在html中引入該文件的script元素的屬性來修改畫布的一些屬性,畫布的z-index,透明度和小方塊數量,顏色
    //與前面往body元素添加canvas元素的代碼配合,當開發者想要使用該特效作為背景時,只需在html文件中添加script元素并引用本文件即可
    function getAttr() {
        let scripts = document.getElementsByTagName("script"),
        len = scripts.length,
        script = scripts[len - 1]; //v為最后一個script元素,即引用了本文件的script元素
        return {
            length: len,
            z: script.getAttribute("zIndex") || -1,
            opacity: script.getAttribute("opacity") || 0.5,
            color: script.getAttribute("color") || "0,0,0",
            count: script.getAttribute("count") || 99
        }
    }
    //獲得窗口寬高,并設置canvas元素寬高
    function getWindowWH() {
        W = canvas.width = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth,
        H = canvas.height = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight
    }
    //生成隨機位置的小方塊
    var random = Math.random,
    squares = []; //存放小方塊
    //往squares[]數組放小方塊
    for (let p = 0; p < attr.count; p++) {
        var square_x = random() * W,
        //橫坐標
        square_y = random() * H,
        //縱坐標
        square_xa = 2 * random() - 1,
        //x軸位移 -1,1
        square_ya = 2 * random() - 1; //y軸位移
        squares.push({
            x: square_x,
            y: square_y,
            xa: square_xa,
            ya: square_ya,
            max: 6000
        })
    }
    //生成鼠標小方塊
    var mouse = {
        x: null,
        y: null,
        max: 20000
    };
    //獲取鼠標所在坐標
    window.onmousemove = function(i) {
        //i為W3C DOM,window.event 為 IE DOM,以實現兼容IE
        //不過目前似乎IE已經支持W3C DOM,我用的是IE11,我注釋掉下一句代碼也能實現鼠標交互效果,
        //網上說7/8/9是不支持的,本人沒有試驗,
        //當然加上是沒有錯的
        i = i || window.event;
        mouse.x = i.clientX;
        mouse.y = i.clientY;
    }
    //鼠標移出窗口后,消除鼠標小方塊
    window.onmouseout = function() {
        mouse.x = null;
        mouse.y = null;
    }
    //繪制小方塊,小方塊移動(碰到邊界反向移動),小方塊受鼠標束縛
    var animation = window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame ||
    function(i) {
        window.setTimeout(i, 1000 / 45)
    }; //各個瀏覽器支持的requestAnimationFrame有所不同,兼容各個瀏覽器
    function draw() {
        //清除畫布
        context.clearRect(0, 0, W, H);
        var w = [mouse].concat(squares); //連接(合并)鼠標小方塊數組和其他小方塊數組
        var x, v, A, B, z, y;
        //square屬性表:x,y,xa,ya,max
        squares.forEach(function(i) {
            //實現小方塊定向移動
            i.x += i.xa;
            i.y += i.ya;
            // 控制小方塊移動方向
            // 當小方塊達到窗口邊界時,反向移動
            i.xa = i.xa * (i.x > W || i.x < 0 ? -1 : 1);
            i.ya = i.ya * (i.y > H || i.y < 0 ? -1 : 1);
            //fillRect前兩個參數為矩形左上角的x,y坐標,后兩個分別為寬度和高度
            //繪制小方塊
            context.fillRect(i.x - 0.5, i.y - 0.5, 1, 1);
            //遍歷w中所有元素
            for (let n = 0; n < w.length; n++) {
                x = w[n];
                //如果x與i不是同一個對象實例且x的xy坐標存在
                if (i !== x && null !== x.x && null !== x.y) {
                    x_diff = i.x - x.x; //i和x的x坐標差
                    y_diff = i.y - x.y; //i和x的y坐標差
                    distance = x_diff * x_diff + y_diff * y_diff; //斜邊平方
                    if (distance < x.max) {
                        //使i小方塊受鼠標小方塊束縛,即如果i小方塊與鼠標小方塊距離過大,i小方塊會被鼠標小方塊束縛,
                        //造成 多個小方塊以鼠標為圓心,mouse.max/2為半徑繞成一圈
                        if (x === mouse && distance > x.max / 2) {
                            i.x = i.x - 0.03 * x_diff;
                            i.y = i.y - 0.03 * y_diff;
                        }
                        A = (x.max - distance) / x.max;
                        context.beginPath();
                        //設置畫筆的畫線的粗細與兩個小方塊的距離相關,范圍0-0.5,兩個小方塊距離越遠畫線越細,達到max時畫線消失
                        context.lineWidth = A / 2;
                        //設置畫筆的畫線顏色為s.c即畫布顏色,透明度為(A+0.2)即兩個小方塊距離越遠畫線越淡
                        context.strokeStyle = "rgba(" + attr.color + "," + (A + 0.2) + ")";
                        //設置畫筆的筆觸為i小方塊
                        context.moveTo(i.x, i.y);
                        //使畫筆的筆觸移動到x小方塊
                        context.lineTo(x.x, x.y);
                        //完成畫線的繪制,即繪制連接小方塊的線
                        context.stroke();
                    }
                }
            }
            //把i小方塊從w數組中去掉
            //防止兩個小方塊重復連線
            w.splice(w.indexOf(i), 1);
        });
        //window.requestAnimationFrame與setTimeout相似,形成遞歸調用,
        //不過window.requestAnimationFrame采用系統時間間隔,保持最佳繪制效率,提供了更好地優化,使動畫更流暢
        //經過瀏覽器優化,動畫更流暢;
        //窗口沒激活時,動畫將停止,省計算資源;
        animation(draw);
    }
    //此處是等待0.1秒后,執行一次draw(),真正的動畫效果是用window.requestAnimationFrame實現的
    setTimeout(function() {
        draw();
    },
    100)
} ();

源碼地址: https://github.com/jc1144096387/canvas_nest

總結

以上所述是小編給大家介紹的解析html5 canvas實現背景鼠標連線動態效果代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

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

巨人網絡通訊聲明:本文標題《解析html5 canvas實現背景鼠標連線動態效果代碼》,本文關鍵詞  解析,html5,canvas,實現,背景,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《解析html5 canvas實現背景鼠標連線動態效果代碼》相關的同類信息!
  • 本頁收集關于解析html5 canvas實現背景鼠標連線動態效果代碼的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产拍揄自揄精品视频麻豆| 亚洲天堂精品在线观看| 亚洲欧美另类图片小说| 久久综合九色综合欧美就去吻| 欧美一级爆毛片| 国产精品欧美一级免费| 亚洲色图制服诱惑 | 亚洲免费资源在线播放| 国产精品久久久久久户外露出 | 捆绑紧缚一区二区三区视频| 亚洲3atv精品一区二区三区| 亚洲成人黄色小说| 国产亚洲综合在线| 欧美亚洲丝袜传媒另类| 91在线观看视频| 欧美亚洲日本国产| 日本韩国一区二区| 91精品国产入口| 欧美日韩国产天堂| 欧美性感一区二区三区| 丰满白嫩尤物一区二区| 国产真实乱子伦精品视频| 日韩av高清在线观看| 久久久不卡网国产精品二区| 亚洲自拍与偷拍| 国产欧美日韩激情| 看片的网站亚洲| 欧美成人女星排名| 激情小说欧美图片| 国产乱人伦偷精品视频免下载 | 91福利精品第一导航| 国产精品电影一区二区三区| 狠狠色丁香婷婷综合| 成人免费一区二区三区在线观看| 精品亚洲成a人| 欧美国产日韩精品免费观看| 成人激情电影免费在线观看| 国产精品第一页第二页第三页| 成人黄色a**站在线观看| 99国内精品久久| 欧美日韩电影在线播放| 久久66热re国产| 国产精品久久久久一区二区三区| 欧美日韩dvd在线观看| 精品一区二区三区免费毛片爱| 亚洲黄一区二区三区| 91精品婷婷国产综合久久竹菊| 精品一区中文字幕| 日本怡春院一区二区| 久久精品夜色噜噜亚洲a∨| 欧美久久一区二区| 欧美一区二区三区在线看| www.亚洲在线| 国产一级精品在线| 午夜视频久久久久久| 亚洲欧洲精品一区二区精品久久久 | 日韩av中文在线观看| 欧美日韩亚洲高清一区二区| 一区二区三区精品视频| 亚洲天堂av一区| 亚洲美女少妇撒尿| 五月婷婷另类国产| 日韩精品欧美精品| 久久机这里只有精品| 国产精品一二三区| 粉嫩久久99精品久久久久久夜| 成人性生交大片免费看中文网站| 亚洲影视资源网| 日韩国产高清影视| 精品一区二区三区视频在线观看 | 中文字幕一区在线观看| 国产成人av一区二区三区在线 | 欧美另类z0zxhd电影| 亚洲国产精品激情在线观看| 日韩国产在线观看一区| 欧美三级电影在线看| 欧美日韩电影一区| 日韩一区二区影院| 日本不卡的三区四区五区| 久久综合资源网| eeuss鲁片一区二区三区在线看| 国产日韩欧美一区二区三区综合| 精品一区二区久久| 国产福利一区二区| 水野朝阳av一区二区三区| 国产在线精品一区二区三区不卡| 不卡视频一二三四| 精品对白一区国产伦| 亚洲男人都懂的| 国产成人高清在线| 亚洲欧美日韩国产成人精品影院| 怡红院av一区二区三区| 欧美在线观看你懂的| 香蕉久久一区二区不卡无毒影院| 喷水一区二区三区| 欧美国产在线观看| 99久久er热在这里只有精品15| 国产精品盗摄一区二区三区| 成人免费av资源| 亚洲欧美在线高清| 在线成人av网站| 欧美亚洲禁片免费| 成人激情开心网| 日本v片在线高清不卡在线观看| 国产午夜精品久久久久久免费视 | 7777精品伊人久久久大香线蕉超级流畅 | 欧美区视频在线观看| 依依成人综合视频| 91精品国产丝袜白色高跟鞋| 亚洲最新在线观看| 亚洲福利视频一区二区| 日韩一级片在线观看| 成人激情开心网| 午夜精品免费在线观看| 日韩一级二级三级| 麻豆精品在线看| 国产成人午夜片在线观看高清观看| 欧美日韩国产综合草草| 99精品久久99久久久久| 免费观看久久久4p| 亚洲欧美日韩国产手机在线| 亚洲少妇中出一区| 国产精品久久久久婷婷二区次| 精品久久久三级丝袜| 2019国产精品| 精品日韩欧美在线| 国产欧美一区视频| 国产精品色一区二区三区| 久久亚洲欧美国产精品乐播| 久久日韩粉嫩一区二区三区| 欧美激情资源网| 亚洲精品国产无天堂网2021| 一区二区三区四区蜜桃| 久久精品免费观看| 在线欧美小视频| 国产精品女同一区二区三区| 亚洲三级电影网站| 国产福利91精品一区| 色综合久久66| 欧美成人video| 国产成人av网站| 欧美大片顶级少妇| 亚洲影视在线观看| 精品少妇一区二区三区视频免付费| 欧美色爱综合网| 久久美女艺术照精彩视频福利播放 | 一本大道久久a久久综合婷婷| 99久久精品国产精品久久| 欧美一级高清大全免费观看| 亚洲国产日韩在线一区模特| 91久久精品一区二区二区| 精品国产成人在线影院| 日韩黄色在线观看| 欧美另类z0zxhd电影| 亚洲乱码精品一二三四区日韩在线| 5566中文字幕一区二区电影| 成人午夜激情在线| 精品成人a区在线观看| 亚洲一区二区欧美| 欧美人妇做爰xxxⅹ性高电影| 欧美日韩电影一区| 亚洲精品在线电影| 精品一区二区在线免费观看| 久久久久久久久久久电影| 日韩精品久久久久久| 蜜臀精品一区二区三区在线观看 | 2022国产精品视频| 欧美亚洲丝袜传媒另类| 91免费观看视频| 精品国产乱码久久久久久图片| 亚洲日本va午夜在线电影| 一区二区成人在线| 日本va欧美va欧美va精品| 欧美日韩免费电影| 国产美女av一区二区三区| 91论坛在线播放| 这里只有精品免费| 久久久久久毛片| 中文字幕中文在线不卡住| 国产91精品一区二区麻豆亚洲| 奇米精品一区二区三区四区| 精品国产自在久精品国产| 一区二区三区欧美在线观看| 国产一区亚洲一区| 在线精品视频一区二区三四| 中文字幕日本乱码精品影院| 欧美在线免费播放| 日本中文字幕不卡| 中文字幕一区免费在线观看| 在线观看视频一区| 岛国精品在线播放| 日韩av高清在线观看| 日韩欧美在线1卡| 99久久er热在这里只有精品15| 一区二区三区四区蜜桃| 亚洲日本免费电影| 色综合久久久网| 中文字幕国产一区| 91国产视频在线观看| 亚洲电影一级黄|