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

主頁 > 知識(shí)庫 > 解析html5 canvas實(shí)現(xiàn)背景鼠標(biāo)連線動(dòng)態(tài)效果代碼

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

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

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

效果截圖:

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

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

總結(jié)

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

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《解析html5 canvas實(shí)現(xiàn)背景鼠標(biāo)連線動(dòng)態(tài)效果代碼》,本文關(guān)鍵詞  解析,html5,canvas,實(shí)現(xiàn),背景,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《解析html5 canvas實(shí)現(xiàn)背景鼠標(biāo)連線動(dòng)態(tài)效果代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于解析html5 canvas實(shí)現(xiàn)背景鼠標(biāo)連線動(dòng)態(tài)效果代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    看欧美ab黄色大片视频免费| 日韩欧美在线视频| 亚洲欧美在线aaa| 亚洲女厕所小便bbb| 亚洲精品成人a8198a| 日韩大片免费在线观看| 中文日本在线观看| 激情欧美亚洲| 国产成人精品一区二区| 99久久精品国产麻豆演员表| 欧美一级二级三级蜜桃| 中文字幕一区二区三区在线不卡| 亚洲乱妇老熟女爽到高潮的片| 国产妇女馒头高清泬20p多| 蜜桃传媒一区二区亚洲av| 中文字幕免费高清| 在线播放91灌醉迷j高跟美女| 红杏视频成人| 中文无码日韩欧| 欧洲一区在线观看| 欧美成人aa大片| 日本熟妇乱子伦xxxx| 日韩中文字幕视频| 欧美另类bbbxxxxx另类| 国产乱码精品一区二区| 国产成人午夜电影| 久久九九热re6这里有精品| 手机看片一区二区三区| 国产精品我不卡| 欧美成人免费全部观看天天性色| 中文无码日韩欧| 久久久影院一区二区三区| 国产成人精品视频免费看| 麻豆视频在线观看免费网站黄| 亚洲一区二区三区乱码| a天堂中文在线官网| 一区二区三区在线观看www| 特级西西444www大胆免费看| 激情欧美一区| 伊人久久99| 婷婷综合另类小说色区| 在线观看免费版| 国产日韩精品在线| 日韩激情在线视频| 免费高清在线观看电视| 亚洲精选视频在线| 91成人在线播放| 久久精品亚洲一区二区三区浴池| 自拍偷拍激情视频| 久久这里都是精品| 精品国产一区二区三区久久| 男男受被啪到高潮自述| 一二三四社区在线视频6| 在线播放国产一区| aⅴ在线视频男人的天堂| 922tv免费观看在线| 625成人欧美午夜电影| 欧美性猛交久久久乱大交小说| 欧美另类videos黑人极品| 亚洲深夜福利在线观看| 欧美亚洲另类视频| 日韩美女av在线| 日韩欧美在线视频播放| 69sex久久精品国产麻豆| 欧美国产乱视频| 欧美午夜宅男影院在线观看| 91久久免费视频| 26uuu精品一区二区三区四区在线| 中文久久乱码一区二区| 亚洲精品一区二区三区四区五区| 色欲欲www成人网站| 日韩欧美一区二区三区四区五区| 成人影院大全| 日本一本a高清免费不卡| 久久久久久久久一区| 97成人超碰| 一区二区三欧美| 久久久久久久久久久网| 91精品综合久久久久久久久久久| 99re免费99re在线视频手机版| 五月天婷婷激情网| 国产成人亚洲综合无码| 国产69精品久久久久孕妇| 亚洲欧洲中文日韩久久av乱码| 一级欧洲+日本+国产| 中文字幕手机在线观看| 九九久久精品视频| 91精品久久久久久蜜桃| 日本三级视频网站| 男人插女人欧美| 97超碰免费观看| 欧美视频自拍偷拍| 一区二区冒白浆视频| 五月天综合婷婷| 欧美一级在线| 久久精品国产成人精品| 国产精品久久久久久久久夜色| 久草精品视频在线观看| 91日韩在线专区| 日韩在线中文| 中文视频一区| 国产私人尤物无码不卡| 亚洲综合福利| 亚洲成a人片| 性高潮久久久久久| youjizz在线播放| 希岛爱理一区二区三区av高清| 亚洲国语精品自产拍在线观看| 成人亚洲综合| 久久亚洲av午夜福利精品一区| 欧美专区国产专区| av av片在线看| 欧美成人剧情片在线观看| 中文在线资源新版官网| 日韩成人中文字幕在线观看| 亚洲视频在线观看| 日韩高清专区| 欧美一a一片一级一片| 日韩中文在线视频| 一本色道久久hezyo无码| 中文字幕免费观看一区| 国产精品免费精品一区| 国产美女视频一区二区二三区| 免费国产黄线在线观看视频| 国产馆在线观看| 国产精品99久久久久久久女警| 99久久99久久精品国产片| 欧美精品电影免费在线观看| 精品久久在线| 日本少妇xxxx动漫| 潘金莲一级淫片aaaaa| 一区二区三区视频在线观看免费| xvideos成人免费中文版| 在线观看av每日更新免费| 国产美女被遭强高潮免费网站| 51精品国产黑色丝袜高跟鞋| 国产在线观看免费视频软件| 日本不卡一二三区黄网| 成人妇女淫片aaaa视频| 日本高清视频在线| 亚洲午夜精品久久久久久浪潮| 久久久精品免费网站| 18深夜视频在线观看| 欧美一区二区精品久久911| 亚洲成人aaa| 国内精品国产三级国产在线专| 久久精品成人欧美大片古装| 国产高清精品在线| 青青青爽久久午夜综合久久午夜| 91蝌蚪porny九色| 日韩精品色哟哟| 久久成人国产精品入口| 成人乱码手机视频| 天天操天天干天天综合网| 四虎影视成人精品国库在线观看| 天天av天天操| 午夜在线一区| 国产成人综合网站| 三上悠亚在线观看二区| 亚洲精品国产一区二区三区四区在线| 欧美日韩国产高清一区| 亚洲精品网站在线播放gif| 亚洲成人动漫在线| 欧洲精品99毛片免费高清观看| 欧美日韩大片| 国产精品久久久久久久岛一牛影视| 国产精品免费一区| 女人抽搐喷水高潮国产精品| 污污网站免费看| 久久精品日产第一区二区三区| ririsao中文字幕免费| 一区二区三区高清视频在线观看| 日韩欧美中文字幕在线播放| 亚洲三级一区| 国内老司机av在线| 波多野结衣视频在线看| 杨幂毛片午夜性生毛片| 99riav国产精品| 亚洲美女激情视频| 搞黄视频免费在线观看| 欧美成人免费小视频| 韩国主播福利视频一区二区三区| 一区二区成人av| 性做久久久久久久久| 91精品国产综合久久香蕉麻豆| www日本高清| 成人精品视频一区二区三区| 久久精品无码一区二区三区毛片| 女人天堂av手机在线| 中文字幕免费高| 日本阿v视频在线观看| 国产69精品99久久久久久宅男| 国产二区视频在线观看| 一区二区欧美在线| 国产无套在线观看| 日本妇女一区| 国产一区白浆| 97久久亚洲| 精品国产伦一区二区三区观看体验| 精品视频一区二区在线| 最新精品视频| 日韩暖暖在线视频| 麻豆传媒免费在线观看| 亚洲免费不卡| 欧美日韩一区二区三区高清| 日本xxxxwwww| 国产精品永久免费| 欧美中文字幕在线观看| 好吊色视频一区二区| 成人免费的视频| 亚洲v.com| 亚洲乱码国产乱码精品精大量| 免费高清视频在线一区| 一道精品视频一区二区三区图片| 国产精品久久视频| 精品96久久久久久中文字幕无| 色综合久久六月婷婷中文字幕| 在线观看一区二区三区视频| 可以直接看的av网址站| a视频网址在线观看| 高清一区二区中文字幕| 天天操综合网| 成人在线免费看| 99这里有精品视频| 成人xxxx视频| 小小影院久久| 国产在线精品观看| 自拍亚洲一区欧美另类| 日本中文字幕不卡| 久久免费美女视频| 韩国欧美国产一区| 韩日欧美一区二区三区| 精品亚洲porn| 樱桃成人精品视频在线播放| 欧美三日本三级少妇三99| 日韩区欧美区| 精品国产黄a∨片高清在线| 精品久久在线播放| 又黄又www的网站| 亚洲一区站长工具| 亚洲精品免费av| 91精品国产色综合久久不卡粉嫩| 亚洲精品电影在线一区| 成年人晚上看的视频| 日本成人福利| 污污软件在线观看| 国产精品一区二区三区乱码| 久久久久久国产精品一区| 91欧美一区二区| 久久综合久久美利坚合众国| 国产精品成人久久久| 成人台湾亚洲精品一区二区| 国产日产久久高清欧美一区| 欧美日韩精品综合在线| 中文av在线全新| 亚洲黄色性网站| 久久久精品2019中文字幕之3| 亚洲国产精品电影| 日韩免费黄色av| 日韩欧美手机在线| 国产精品扒开腿做爽爽爽视频| 欧美tickling挠脚心丨vk| 日韩一区二区久久| 国产精品午夜电影| 手机亚洲手机国产手机日韩| 久久99高清| 中文字幕电影在线观看| 女女色综合影院| 中文字幕欧美激情一区| 激情偷乱视频一区二区三区| 日韩精品一级中文字幕精品视频免费观看| 人妻丰满熟妇av无码久久洗澡| 国产精品免费一区二区三区四区| 尤物tv国产一区| 欧美性猛片xxxx免费看久爱| 一级特黄妇女高潮| 成人在线视频观看| 黄色一级片在线观看| 日韩精品一区不卡| 精品久久亚洲一级α| 久久久噜久噜久久综合| 天堂精品在线视频| 99视频精品在线| 日韩av中文| 精品盗摄女厕tp美女嘘嘘| 韩日三级av| 日本成人一区二区三区| 岳张嘴把我的精子吞下去| 北条麻妃国产九九精品视频| 久久国产高清| 亚洲人亚洲人色久| 亚洲一区二区国产| 欧美—级在线免费片| julia一区二区三区中文字幕| 成人深夜直播免费观看| 久久婷婷综合色| 国产精品va在线播放| 欧美片第一页| 黄无遮挡免费网站| 欧美一区二区啪啪| 欧美一级色片| 日韩电影免费| 亚洲色图综合久久| 免费男女羞羞的视频网站主页在线观看| 国产传媒一区| 成人免费直播在线| 亚洲精品国产a| 波多野在线观看| 国产精品久久毛片a| 亚洲xxxxx电影| 国产欧美日韩精品一区二区三区| 精品不卡一区二区三区| 极品美女扒开粉嫩小泬| 三区精品视频观看| 国产精品白丝jk黑袜喷水| 中文字幕精品综合| 午夜一区二区三区视频| 亚洲欧美国产日韩中文字幕| 国产精品一区在线观看乱码| 国产一区二区高清| 99在线精品视频免费观看20| 一级片免费在线观看视频| 国产精品77777| 中文字幕高清在线观看| 久久久精品久久久| 黄瓜视频污app| 欧美成人精品一区二区| 小早川怜子影音先锋在线观看|