欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > 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動態效果的示例代碼的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    一区二区欧美在线观看| 亚洲天堂网一区二区| 日本人亚洲人jjzzjjz| 日韩久久免费av| 视频一区国产视频| 久久性爱视频网站| 91麻豆精品国产91| 天天色图综合网| 在线xxxxx| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲高清中文字幕| 色哟哟免费视频| 欧美视频中文一区二区三区在线观看| 国产精品国产自产拍高清av| 福利一区二区在线| www日韩在线| 国产精品免费av| 成人中文字幕在线| 国产波霸爆乳一区二区| 国产精品白丝在线| aaa亚洲精品| 欧美男生操女生| 日韩影视精彩在线| 法国空姐电影在线观看| 久久精品一区二区| 国产成人av自拍| 一本一本大道香蕉久在线精品| 亚洲日本乱码在线观看| 不许穿内裤随时挨c调教h苏绵| 欧美丰满少妇xxxxx高潮对白| 亚洲成人一区二区| 90岁老太婆乱淫| 国产亚洲欧美一区在线观看| 成人福利视频网站| 欧美三电影在线| 日韩成人午夜精品| 99精品全国免费观看| 中文字幕在线视频一区| 日本55丰满熟妇厨房伦| 5566中文字幕一区二区电影| 久草在线在线精品观看| 中日韩一级黄色片| 一区二区三区.www| 国产精品无码久久久久一区二区| 久久精品视频在线看| av在线一区二区三区| 欧美精品tushy高清| 久久机这里只有精品| 成人在线观看高清| 亚洲国产精品久久艾草纯爱| 国产精品无码久久久久久| 中文字幕欧美日本乱码一线二线 | 久久香蕉国产线看观看99| 丰满少妇久久久久久久| 欧美色欧美亚洲另类二区| 日本 国产 欧美色综合| 日本高清不卡免费| 午夜私人影院久久久久| 成人性视频免费看| 一区二区三区加勒比av| 高潮毛片无遮挡| 综合网在线视频| 日韩精品一区二区三区高清免费| 国产人久久人人人人爽| 欧美xxxx黑人| 久久精品欧美日韩| 亚洲av无码成人精品区| 久久久九九九九| a级大片免费看| 久久综合狠狠综合久久综合88| a美女胸又www黄视频久久| 日韩视频免费观看高清完整版在线观看 | 亚洲成人日韩在线| 亚洲欧洲www| 欧美狂猛xxxxx乱大交3| 亚洲视频狠狠干| 亚洲自拍偷拍图| 亚洲午夜免费福利视频| 战狼4完整免费观看在线播放版| 亚洲综合色丁香婷婷六月图片| 欧美做受喷浆在线观看| 亚洲激情综合网| 天美传媒免费在线观看| 性欧美大战久久久久久久久| 午夜爱爱毛片xxxx视频免费看| 日本不卡不码高清免费观看| 国产精品久久久久久久精| 美女视频免费一区| 欧美日韩一区视频| 成人免费毛片嘿嘿连载视频| 欧美mv日韩mv| 亚洲黄色小说在线观看| 国产精品第一页第二页第三页| 中文幕无线码中文字蜜桃| 亚洲午夜免费电影| 一本在线高清不卡dvd| 韩国女主播一区二区三区| 91精品在线一区二区| 91首页免费视频| 国产精品久久久久久福利一牛影视 | 丁香另类激情小说| 2020国产精品自拍| 无码一区二区精品| 亚洲一区二区在线观看视频 | 国产精品国产三级国产有无不卡| 亚洲 小说 欧美 激情 另类| 天天色综合成人网| 欧美精品三级日韩久久| 一个人看的视频www| 最新成人av在线| 国产精品国产三级国产传播| 精品在线你懂的| 日韩免费高清av| 亚洲图片综合网| 午夜久久福利影院| 欧美日韩大陆一区二区| 91猫先生在线| 亚洲另类在线一区| 国产免费无码一区二区视频| 国产精品亚洲第一| 国产欧美日韩不卡免费| 日韩免费成人av| 久草中文综合在线| 久久影院午夜论| 国产美女永久免费无遮挡| 美女视频黄免费的久久| 日韩精品一区二区三区在线播放| 色诱av手机版| 亚洲成人一区二区在线观看| 欧美日本精品一区二区三区| 亚洲成年人av| 性做久久久久久免费观看 | 成人久久18免费网站麻豆| 国产精品视频一二| 午夜精品一区二区三区视频| 成人小视频在线| 亚洲手机成人高清视频| 91成人免费电影| 国产高潮失禁喷水爽到抽搐| 视频一区二区三区中文字幕| 日韩免费观看2025年上映的电影| 中文字幕一区二区人妻在线不卡| 另类人妖一区二区av| 久久影院视频免费| а天堂中文在线资源| 粉嫩嫩av羞羞动漫久久久 | 欧美在线制服丝袜| 丰满饥渴老女人hd| 午夜精品福利一区二区三区av| 欧美一二三四在线| 性猛交娇小69hd| 国产精品一区二区无线| 亚洲视频网在线直播| 欧美日韩国产在线观看| 国产中文字幕一区二区| 国内外精品视频| 中文字幕亚洲欧美在线不卡| 欧美性猛交xxxxxx富婆| 欧洲一级黄色片| 国产久卡久卡久卡久卡视频精品| 国产精品入口麻豆原神| 色丁香久综合在线久综合在线观看| 少妇欧美激情一区二区三区| 秋霞影院一区二区| 亚洲国产精品激情在线观看| 欧美中文一区二区三区| 亚洲一区二区三区蜜桃| 成人午夜视频福利| 亚洲国产精品久久一线不卡| 久久综合九色综合欧美就去吻| 午夜国产小视频| 26uuu国产| 毛片一区二区三区| 国产精品久久久久aaaa| 欧美日韩不卡视频| 国产又粗又长免费视频| 99久久精品99国产精品| 婷婷亚洲久悠悠色悠在线播放| 欧美精品一区二区在线播放| 男女性高潮免费网站| 中文字幕乱码一区| 国产jizzjizz一区二区| 亚洲国产成人av| 久久九九国产精品| 欧美三日本三级三级在线播放| 欧美色图亚洲激情| voyeur盗摄精品| 欧美aaa在线| 亚洲三级免费电影| 欧美成人精品高清在线播放| 午夜精品福利在线视频| 一本加勒比波多野结衣| 成人午夜精品在线| 日本在线播放一区二区三区| 国产精品乱码一区二区三区软件| 555www色欧美视频| 色综合婷婷久久| 亚洲精品午夜视频| 国产精品欧美性爱| 成人激情动漫在线观看|