亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

解析html5 canvas實現(xiàn)背景鼠標(biāo)連線動態(tài)效果代碼

2024-08-26 00:21:30
字體:
供稿:網(wǎng)友

流行的動態(tài)背景連線特效。下面的代碼是作者在扒下來的代碼上進行整理和注釋,很適應(yīng)參考學(xué)習(xí)。

效果截圖:

html5,canvas,鼠標(biāo)

效果演示: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代碼:

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

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

總結(jié)

以上所述是小編給大家介紹的解析html5 canvas實現(xiàn)背景鼠標(biāo)連線動態(tài)效果代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對VeVb武林網(wǎng)網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!


注:相關(guān)教程知識閱讀請移步到HTML教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
欧洲久久久久久| 快播电影网址老女人久久| 欧美不卡在线一区二区三区| 日本a级片视频| 午夜精品福利视频网站| aaa大片免费观看| 国产污污在线观看| 日韩视频在线一区二区| 欧美国产精品v| 黄色动漫在线免费观看| 麻豆精品在线视频| 欧美午夜在线| 在线免费看黄色| 日韩av成人高清| 日韩视频在线播放| 久久久久久久影院| 在线免费看91| 久久午夜a级毛片| 亚洲久久久久久| 电影亚洲精品噜噜在线观看| 欧美美乳在线| 午夜日韩影院| 色哟哟日韩精品| 免费一级特黄3大片视频| 日本一区不卡| 调教在线观看| 久久综合成人网| 成人av综合一区| 欧美五级在线观看视频播放| 污网站在线免费| 国产激情三区| 4444亚洲人成无码网在线观看| 国产成人强伦免费视频网站| 3d动漫精品啪啪| 亚洲国产高清国产精品| 久久精品免费电影| 亚洲高清av| 欧美精品激情在线观看| 欧美阿v一级看视频| 最新国产成人av网站网址麻豆| 9191国产精品| 在线免费看污| 三级小视频在线观看| 日韩一级二级三级| 麻豆成人av| 欧美不卡一二三| 激情五月综合婷婷| 精品久久亚洲一级α| 一级黄色片毛片| 精品国产一区二区三区av性色| 国产性色av一区二区| 国产校园另类小说区| 成人在色线视频在线观看免费大全| 五月精品视频| 日本精品在线观看| 欧美gv在线观看| 伊人激情综合| 欧美精品1区2区| 韩国中文免费在线视频| 香蕉视频久久久| 色中色综合影院手机版在线观看| 亚洲精品电影网| 亚洲精选一区二区三区| 爱啪视频在线观看视频免费| 日本xxxxxxxxxx75| 懂色av蜜臀av粉嫩av分享吧最新章节| 亚洲三级毛片| 国产精品av久久久久久无| 国产一级成人av| av成人黄色| 国产制服91一区二区三区制服| 麻豆视频久久| 日本在线一区二区三区| 亚洲一二三专区| 国产福利一区二区在线精品| 亚洲va电影大全| 色妇色综合久久夜夜| 亚洲视频一区在线观看| 亚洲熟妇无码av| 国产免费不卡| 欧美日韩亚洲第一| 91久久精品久久国产性色也91| 不卡的一区二区| 亚洲va欧美va国产综合剧情| 日本一级淫片色费放| 伊人国产在线看一| 国产午夜手机精彩视频| 午夜精品在线| 2019中文字幕全在线观看| 最新在线你懂的| 色综合久久88色综合天天看泰| 亚洲伊人观看| 日韩三级电影网站| 伊人久久综合视频| 美日韩精品视频| 在线观看黄色片| 综合av色偷偷网| 高清乱码免费看污| 欧美亚洲大片| 亚洲成人精品| 97国产在线观看| 在线成人激情| 成人午夜视频福利| 91九色美女在线视频| 乡村艳史在线观看| 国产精品视屏| 一个人看的www免费观看视频| 成人福利在线观看视频| 老司机2019福利精品视频导航| 乱小说综合网站| 91精品国产电影| 精品一区二区在线视频| 91直播在线观看| 成人性做爰aaa片免费看不忠| 素人fc2av清纯18岁| 久久6免费视频| 亚洲精品88| 一区二区三区四区不卡| 超碰97免费观看| 日韩欧美一区二区在线视频| 极品少妇xxxx精品少妇偷拍| 你懂的视频在线观看| 国产日韩影视精品| 国产三级欧美三级| 成人在线电影网| 国产成人精品一区二区无码呦| 青草青草久热精品视频在线观看| 日韩精品欧美精品| 欧洲日韩一区二区三区| 亚洲精品v欧美精品v日韩精品| 日韩av男人的天堂| 日韩av大片在线| 影音先锋在线中文字幕| 韩日中文字幕第一页| 在线日韩av观看| 爱久久·www| 熟妇女人妻丰满少妇中文字幕| 午夜免费久久看| 国产又粗又长又黄的视频| 欧美高清激情视频| 久热中文字幕在线精品免费| 岛国在线免费| 成人观看高清在线观看免费| 麻豆久久久久久久久久| 欧美日韩中文一区二区| 成年人三级网站| 精品国产一区av| 99r国产精品| 亚洲精品日韩久久久| 麻豆国产精品777777在线| 欧美精品www在线观看| 国产精品色在线| 色婷婷狠狠18| 欧美亚洲在线观看| 欧美色图综合网| 亚洲成人自拍| 69堂精品视频| 久久久av亚洲男天堂| 欧美视频免费看欧美视频| 你懂的网站在线| 国产精品啊啊啊| 色欲一区二区三区精品a片| **孕交吃奶水一级毛片| 福利一区二区免费视频| 精品一区二区三区在线观看| 欧美xxxx做受欧美.88| 午夜国产精品理论片久久影院| 偷拍女澡堂一区二区三区| 视频一区二区欧美| 天天做夜夜爱爱爱| 亚洲欧美日韩中文字幕在线观看| 国产免费黄色一级片| www日本高清| 精品一区2区三区| 91精品国产自产精品男人的天堂| 欧美午夜18电影| 国产黄色一区二区三区| a在线视频播放观看免费观看| 欧美疯狂xxxx大交乱88av| 亚洲黄色片在线观看| 黄色片视频网站| 国产免费一区二区三区四区五区| 国产福利精品一区二区三区| 亚洲三级免费电影| av不卡免费在线观看| 三级做a全过程在线观看| 日韩精品在线视频美女| 免费在线观看日韩av| 最近中文字幕在线观看视频| 中文字幕一区二区三区中文字幕| 六月丁香婷婷在线| 九九视频九九热| 日本一二三区不卡| 天堂а√在线中文在线鲁大师| 中国精品18videos性欧美| 成人av资源网址| 亚洲精品乱码久久久久久日本蜜臀| 久久成人久久鬼色| 日韩大片在线永久免费观看网站| 2018天天弄| 免费观看h电影在线观看| 在线观看一区二区三区视频| 亚洲欧美日本日韩| 亚洲第一页中文字幕| 美女把尿口扒开给男人桶视频| 欧美视频在线不卡| 久久久久资源| 久久福利影院| 国产精品久久久久77777| 亚洲男同gay网站| 黄色网址免费在线| 又嫩又硬又黄又爽的视频| 欧美6699在线视频免费| www日韩大片| 亚洲成人1234| 成人亚洲一区二区一| 日韩中文字幕av在线| 日韩三级电影免费观看| 国产精品一区二区三区99| 欧美aaaaaa午夜精品| 久久大胆人体视频| 手机av在线播放| 日韩av一级片| 亚洲色图16p| 中文字幕中文字幕一区二区| 亚洲电影免费| 欧美大片专区| 国产一区二区在线视频| 色网在线播放| 天堂资源最新在线| 欧美日韩中文一区二区| 996久久国产精品线观看| 国产爆乳无码一区二区麻豆| 美女被久久久| 亚洲字幕av一区二区三区四区| 国产一区二区福利视频| 国产一区二区三区亚洲综合| 视频一区二区三区免费观看| 久久免费视频播放| 清纯唯美日韩| 97成人精品区在线播放| 日本一区二区在线播放| 久久视频精品在线观看| 一级黄色免费| 亚洲成人激情视频| 蜜桃av乱码一区二区三区| 免费观看在线黄色网| 美女色狠狠久久| 精品国产福利在线| 亚洲一卡二卡区| h网站在线免费观看| 久久精品国产v日韩v亚洲| www.老鸭窝.com| 国产一卡不卡| 色婷婷狠狠18禁久久| 亚洲美女色视频| 678五月天丁香亚洲综合网| 国产视频一区二区三区在线播放| 国产精品久久久久久久久久久新郎| 欧洲成人在线视频| 日韩三级在线| 久久综合网络一区二区| 国产免费色视频| 精品国产一区二区三区四区精华| 国产精品情侣呻吟对白视频| 中文字幕一区二区三区四| 5566先锋影音夜色资源站在线观看| 7m精品福利视频导航| 欧美性色黄大片人与善| 欧美日韩另类一区| av午夜在线| 国产一级特黄aaa大片| 日韩一区二区三区免费观看| 亚洲国产高清福利视频| 国产精品久久精品国产| 精品三级久久久| 亚洲在线视频观看| 四虎影视在线播放| 欧洲猛交xxxx乱大交3| 国产性生活视频| 1pon在线| 久久国产乱子伦精品| 亚洲午夜视频在线| 最好看的中文字幕久久| 2021亚洲天堂| 日韩熟女精品一区二区三区| 精品国产一区二区三区四区在线观看| 美国一级片在线观看| 欧美亚洲一区二区在线观看| 亚洲精品国产一区| 中文字幕丰满乱码| 久久视频免费在线| 91视频观看视频| 亚洲国产美女搞黄色| 欧美一区二区麻豆红桃视频| 卡通动漫精品一区二区三区| 国产精品黄色片| 欧美另类69精品久久久久9999| 久久精品最新免费国产成人| 亚洲乱码一区二区三区| 香港三日本8a三级少妇三级99| 99免费观看视频| 俺也去精品视频在线观看| 成人情趣视频| 亚洲精品国产一区黑色丝袜| 国产乱人伦真实精品视频| 久久综合图区亚洲综合图区| 午夜欧美2019年伦理| 草草视频在线免费观看| 精品国产乱码久久久久久蜜臀网站| av电影在线播放高清免费观看| 视频一区二区三区不卡| 欧美日韩在线观看视频小说| 黄色大片中文字幕| 99久久精品国产一区二区小说| av天堂永久资源网| 国产大片中文字幕在线观看| 18禁裸男晨勃露j毛免费观看| 欧美日韩国产美| 欧美性受xxxx白人性爽| 亚洲一卡二卡在线观看| 欧洲精品久久久| 清纯唯美综合亚洲| 日本欧美日韩| 亚洲图片小说区| 女女百合国产免费网站| 日韩亚洲精品在线观看| 国产精品久久久久野外|