校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > canvas 實現 github404動態效果的示例代碼

canvas 實現 github404動態效果的示例代碼

熱門標簽:江蘇智能電銷機器人哪家好 成都智能外呼系統平臺 當涂高德地圖標注 鎮江智能外呼系統有效果嗎 電銷機器人電話用什么卡 云南大理400電話申請官方 黃島區地圖標注 南寧點撥外呼系統哪家公司做的好 四川點撥外呼系統

前幾天使用css樣式和js致敬了一下github404的類似界面,同時最近又接觸了canvas,本著瞎折騰的想法,便借著之前的js的算法,使用canvas來完成了github404的動態效果。

效果圖

文件目錄

文件資源

文件源碼與圖片在文章末尾給出

代碼

網頁的body部分

這里給canvas 定義好寬和高,設為塊級元素。這些img 標簽是將這些圖片加載出來,我們就不用在js中去加載了,再將圖片設為不顯示 display:none。

<body>
    <canvas id="mycanvas" width="1680" height="630"
        style="margin:0;display:block">
            您的瀏覽器不支持canvas
    </canvas>
    <img src="./images/field.png" style="display:none">
    <img src="./images/text.png" style="display:none">
    <img src="./images/cat.png" style="display:none">
    <img src="./images/cat_shadow.png" style="display:none">
    <img src="./images/speeder.png" style="display:none">                        
    <img src="./images/speeder_shadow.png" style="display:none">            
    <img src="./images/buliding_1.png" style="display:none">
    <img src="./images/building_2.png" style="display:none">  
 </body>

js部分

1.這里我還是新建了一個名為github404的json對象,以對所有的參數和方法進行封裝

2.再創建imgData的對象,將所有的img所需的參數傳入ps:top和left用于 drawImage() 方法時定位, scale 參數用于計算鼠標移動時對應的圖片移動的計算

3.init()方法用來初始化,是與外部的接口

4.畫圖方法的實現就是用 for in 循環遍歷 imgData[],再依次賦值,最后用drawImage()方法繪畫,只是在移動的繪圖方法中,需要注意使用了ctx.clearRect() 方法先將畫布清空。

<script>
        var github404 = {
            imgData: {//將所有圖片的信息用json對象記錄
                bg: {
                    top: 0,
                    left: 110,//top和left用于定位,在畫圖時使用
                    src: './images/field.png',//對應圖片路徑
                    scale: 0.06,//鼠標移動時,該圖片所對應移動的比例
                },
                building_2: {
                    top: 133,
                    left: 1182,
                    src: './images/building_2.png',
                    scale: 0.05,
                },
                building_1: {
                    top: 79,
                    left: 884,
                    src: './images/buliding_1.png',
                    scale: 0.03,
                },
                speeder_shadow: {
                    top: 261,
                    left: 776,
                    src: './images/speeder_shadow.png',
                    scale: 0.01,
                },
                cat_shadow: {
                    top: 288,
                    left: 667,
                    src: './images/cat_shadow.png',
                    scale: 0.02,
                },
                speeder: {
                    top: 146,
                    left: 777,
                    src: './images/speeder.png',
                    scale: 0.01,
                },
                cat: {
                    top: 88,
                    left: 656,
                    src: './images/cat.png',
                    scale: 0.05,
                },
                text: {
                    top: 70,
                    left: 364,
                    src: './images/text.png',
                    scale: 0.03,
                },
            },
            rate_w: 0,
            rate_h: 0,//偏移的比例
            field_width: 1680,
            field_height: 370,//背景高度和寬度
            canvas: document.querySelector('#mycanvas'),//獲得canvas元素

            init: function() {//初始化加載方法
                this.setRateWH();
                this.placeImg();
                this.attachMouseEvent();
            },
            setRateWH: function() {//計算偏移比的方法
                var window_width = document.body.clientWidth;
                var window_height = document.body.clientHeight;
                this.rate_w = this.field_width/window_width;
                this.rate_h = this.field_height/window_height;
            },

            placeImg: function() {//初始化的繪圖方法
                let ctx = this.canvas.getContext('2d');//獲得畫筆
                for(key in this.imgData){//遍歷imageData 對象
                    var image = new Image();
                    var left = this.imgData[key].left;
                    var top = this.imgData[key].top;    
                    image.src = this.imgData[key].src;
                    ctx.drawImage(image,left,top,
                        image.width,image.height);
                }

            },

            attachMouseEvent: function() {
                var that = this;
                document.body.onmousemove = function(e){
                    that.picMove(e.pageX,e.pageY);
                }
            },
            picMove: function(pageX,pageY) {//鼠標移動時重新畫圖的方法
                let ctx = this.canvas.getContext('2d');
                ctx.clearRect(0,0,this.canvas.width,this.canvas.height);
                for(key in this.imgData) {
                    var image = new Image();
                    var offer_w = this.rate_w * pageX * this.imgData[key].scale;
                var offer_h = this.rate_h * pageY * this.imgData[key].scale;
                    //定義 left和top,下面畫圖時給參數定位
                    var left = this.field_width/100 - offer_w + this.imgData[key].left; 
                    var top = this.field_height/100 - offer_h + this.imgData[key].top;
                    image.src = this.imgData[key].src;
                    ctx.drawImage(image,left,top,
                        image.width,image.height);
                }
            }
        }

        window.onload = function() {
            //只調用github404的init方法 封裝了數據
            github404.init();
        }
    </script>

總結

此次使用canvas來完成這個動態效果,使我更多的了解了canvas的用法。同時使我

對于使用json對象去封裝數據和方法,如何組織代碼都有了更深的一些了解。

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

標簽:西寧 佳木斯 淮安 酒泉 十堰 廣西 南京 咸寧

巨人網絡通訊聲明:本文標題《canvas 實現 github404動態效果的示例代碼》,本文關鍵詞  canvas,實現,github404,動態,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《canvas 實現 github404動態效果的示例代碼》相關的同類信息!
  • 本頁收集關于canvas 實現 github404動態效果的示例代碼的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    久久精品国产免费看久久精品| 91美女视频网站| 丁香六月久久综合狠狠色| 欧美在线你懂得| 久久精品亚洲一区二区三区浴池| 亚洲综合激情网| 国产91精品一区二区麻豆网站| 6080日韩午夜伦伦午夜伦| 国产精品高潮呻吟| 国产在线日韩欧美| 欧美一区国产二区| 亚洲成人久久影院| 欧美综合久久久| 亚洲日穴在线视频| 白白色 亚洲乱淫| 久久一二三国产| 韩国三级电影一区二区| 67194成人在线观看| 亚洲图片欧美色图| 欧美午夜免费电影| 一区二区三区国产豹纹内裤在线 | 欧美精品一区二区精品网| 一区二区三区成人| 色狠狠av一区二区三区| 国产精品二三区| 99re8在线精品视频免费播放| 国产亚洲精品精华液| 国产夫妻精品视频| 国产亚洲福利社区一区| 国产成人免费av在线| 中文字幕av一区二区三区高| 国产精品综合av一区二区国产馆| 久久老女人爱爱| 成人做爰69片免费看网站| 国产精品视频yy9299一区| 成人少妇影院yyyy| 亚洲天堂免费看| 色狠狠桃花综合| 三级不卡在线观看| 精品国内二区三区| 国产成人亚洲精品狼色在线| 国产精品狼人久久影院观看方式| 国产精品白丝jk白祙喷水网站| 亚洲国产成人一区二区三区| 97精品国产露脸对白| 亚洲人快播电影网| 欧美日韩第一区日日骚| 美女视频第一区二区三区免费观看网站 | 91尤物视频在线观看| 一个色在线综合| 在线不卡欧美精品一区二区三区| 日韩国产欧美三级| 国产午夜久久久久| 色综合激情久久| 蜜桃视频一区二区| 中文字幕中文在线不卡住| 91成人在线精品| 天天色综合成人网| 久久久国产精品麻豆| 色综合久久久久综合99| 免费高清在线一区| 中文字幕乱码久久午夜不卡 | 欧美大度的电影原声| 成人性生交大片免费看视频在线 | 国产三级一区二区三区| 色系网站成人免费| 九九九精品视频| 亚洲激情欧美激情| 精品国产在天天线2019| 91啦中文在线观看| 麻豆成人在线观看| 亚洲一区二区三区四区在线| 精品国产自在久精品国产| 在线视频综合导航| 国产精品综合一区二区三区| 一区二区在线免费| 久久久久久久久久电影| 欧美在线免费视屏| 不卡视频在线观看| 久久99久久久久| 亚洲国产美女搞黄色| 国产精品美女一区二区在线观看| 欧美另类变人与禽xxxxx| 成人黄色免费短视频| 极品销魂美女一区二区三区| 亚洲自拍都市欧美小说| 久久精品欧美日韩精品| 日韩欧美国产午夜精品| 欧美午夜精品电影| 色综合久久88色综合天天| 国产一区二区免费看| 视频一区视频二区中文字幕| 亚洲欧美激情在线| 国产精品国产三级国产aⅴ中文| 精品三级在线看| 7878成人国产在线观看| 欧美熟乱第一页| 色婷婷av一区二区三区软件 | 韩国在线一区二区| 久久精品理论片| 午夜伊人狠狠久久| 一个色在线综合| 一区二区视频在线| 亚洲人xxxx| 亚洲蜜臀av乱码久久精品 | 99久久精品国产一区二区三区 | 日韩av午夜在线观看| 亚洲宅男天堂在线观看无病毒| 中文字幕视频一区| 国产精品毛片久久久久久久| 26uuu色噜噜精品一区二区| 日韩免费视频一区| 久久综合久久久久88| 26uuu成人网一区二区三区| 精品国产91亚洲一区二区三区婷婷| 91麻豆精品国产91久久久久久 | 国产一区二区三区四| 国产成人精品午夜视频免费| 国产精品一色哟哟哟| 国产成人av电影| 成人动漫精品一区二区| 91网站黄www| 欧美影片第一页| 欧美一区二区三区免费大片| 欧美一区二区三区日韩| 精品黑人一区二区三区久久| 久久久久97国产精华液好用吗| 国产无人区一区二区三区| 人人狠狠综合久久亚洲| 亚洲欧洲综合另类| 综合婷婷亚洲小说| 亚洲自拍与偷拍| 伊人色综合久久天天人手人婷| 一区二区三区四区在线| 精品久久久久久久久久久院品网| 综合久久一区二区三区| 韩国av一区二区三区四区| 欧美丝袜丝nylons| 成人欧美一区二区三区1314| 精品无人码麻豆乱码1区2区| 欧美色窝79yyyycom| 国产精品成人网| 国产精品123区| 99精品国产99久久久久久白柏| 337p日本欧洲亚洲大胆色噜噜| 午夜精品免费在线| 91福利精品视频| 亚洲日本青草视频在线怡红院| 狠狠狠色丁香婷婷综合激情| 日韩欧美中文一区二区| 日本欧美一区二区在线观看| 欧美亚洲一区二区在线观看| 亚洲三级免费电影| 91丨九色porny丨蝌蚪| 中文字幕 久热精品 视频在线| 国产精品资源在线| 久久久亚洲精品石原莉奈| 捆绑调教美女网站视频一区| 日韩三级视频在线看| 日本免费在线视频不卡一不卡二| 在线不卡a资源高清| 日韩和欧美一区二区| 欧美日本国产视频| 日韩精品福利网| 欧美一三区三区四区免费在线看| 婷婷中文字幕一区三区| 欧美疯狂性受xxxxx喷水图片| 亚洲国产精品影院| 欧美精品v日韩精品v韩国精品v| 亚洲影视在线播放| 777午夜精品免费视频| 毛片av一区二区三区| 精品国产不卡一区二区三区| 久久成人羞羞网站| 中文在线一区二区| 91免费国产在线| 亚洲高清免费观看 | 精品免费99久久| 99久久精品一区| 亚洲国产色一区| 日韩视频免费观看高清完整版| 精品一区二区三区视频在线观看 | 成人av电影在线观看| 亚洲男同1069视频| 欧美日本一区二区三区四区| 毛片基地黄久久久久久天堂| 久久精品一区二区三区不卡牛牛| 成人亚洲精品久久久久软件| 亚洲蜜臀av乱码久久精品| 欧美日韩国产区一| 韩国午夜理伦三级不卡影院| 国产精品不卡一区二区三区| 欧美日本高清视频在线观看| 狠狠色狠狠色综合| 亚洲啪啪综合av一区二区三区| 91精品国产综合久久精品麻豆| 国产精品99久久久久久似苏梦涵 | 亚洲视频一二三区| 在线播放日韩导航| 国产麻豆91精品|