亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > 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動態效果的示例代碼的相關信息資訊供網民參考!
  • 推薦文章
    午夜久久网| 国产视频一区在线| 日本免费乱人伦在线观看 | 一本高清在线| 国产a免费观看| 韩国三级视频在线观看| 精品在线视频播放| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 日本伦理片网站| 亚洲 男人 天堂| 日本伦理网站| 999久久久免费精品国产牛牛| 国产91丝袜在线播放0| 99久久精品国产片| 四虎影视精品永久免费网站| 欧美激情中文字幕一区二区| 国产高清在线精品一区二区| 欧美国产日韩在线| 黄视频网站在线观看| 久久精品大片| 国产精品1024永久免费视频| 麻豆系列国产剧在线观看| 99久久精品国产高清一区二区| 久久精品大片| 国产麻豆精品免费密入口| 亚久久伊人精品青青草原2020| 精品毛片视频| 青草国产在线观看| 国产韩国精品一区二区三区| 亚洲天堂免费| 日韩字幕在线| a级毛片免费观看网站| 999精品在线| 日韩欧美一二三区| 欧美a级v片不卡在线观看| a级毛片免费全部播放| 精品视频免费在线| 精品国产一区二区三区免费| 欧美一级视频免费观看| 二级特黄绝大片免费视频大片| 精品视频在线观看免费| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 精品国产一区二区三区免费| 四虎久久影院| 国产精品自拍一区| 一级毛片视频免费| 日本在线www| 四虎影视库| 久久成人亚洲| 毛片高清| 亚洲不卡一区二区三区在线| 九九热精品免费观看| 欧美一级视| 国产国语对白一级毛片| 亚欧乱色一区二区三区| 成人免费福利片在线观看| 韩国三级香港三级日本三级la| 黄色短视屏| 国产a免费观看| 九九久久国产精品| 一级毛片视频在线观看| 国产麻豆精品免费视频| 国产精品自拍亚洲| 天堂网中文字幕| 午夜激情视频在线播放| 午夜欧美福利| 亚洲女人国产香蕉久久精品| 精品久久久久久免费影院| 九九久久99| 中文字幕一区二区三区精彩视频| 日日夜夜婷婷| 亚洲精品中文字幕久久久久久| 999精品在线| 九九精品久久久久久久久| 天天做日日干| 国产一级生活片| 成人a大片高清在线观看| 国产一区二区精品| 国产国语对白一级毛片| 国产不卡高清在线观看视频| 国产成人精品综合在线| 台湾美女古装一级毛片| 黄视频网站在线看| 成人免费网站久久久| 国产91素人搭讪系列天堂| 久久99中文字幕| 日本乱中文字幕系列| 国产一区二区精品| 国产伦精品一区二区三区在线观看| 亚洲精品影院一区二区| 黄视频网站在线观看| 你懂的福利视频| 欧美激情一区二区三区中文字幕| 欧美激情一区二区三区视频| 91麻豆国产福利精品| 精品视频在线看 | 国产成人女人在线视频观看| 可以免费在线看黄的网站| 色综合久久手机在线| 成人a大片高清在线观看| 国产成人精品影视| 国产激情视频在线观看| 亚洲精品中文字幕久久久久久| 国产伦久视频免费观看 视频| 日韩男人天堂| 精品视频在线观看一区二区| 国产视频一区二区在线观看| 亚洲精品永久一区| 成人a大片高清在线观看| 久草免费资源| 免费一级片在线观看| 欧美另类videosbestsex久久| 999久久狠狠免费精品| 成人a级高清视频在线观看| 91麻豆精品国产高清在线| 午夜激情视频在线播放| 日本伦理片网站| 91麻豆精品国产自产在线| 精品国产一区二区三区免费| 国产亚洲免费观看| 久久成人亚洲| 99久久精品国产国产毛片| 日韩一级黄色| 99色视频在线| 国产欧美精品| 99久久精品费精品国产一区二区| 黄视频网站在线观看| 日本免费看视频| 国产不卡精品一区二区三区| 国产国语在线播放视频| 日本乱中文字幕系列| 久草免费资源| 国产91视频网| 成人在免费观看视频国产| 成人影院一区二区三区| 天天色成人网| 国产网站免费视频| 日日夜夜婷婷| 成人免费观看视频| 亚洲 欧美 成人日韩| 成人免费观看男女羞羞视频| 成人免费一级毛片在线播放视频| 九九精品久久久久久久久| 久久国产精品自由自在| 国产原创视频在线| 中文字幕一区二区三区精彩视频| 国产伦精品一区二区三区在线观看| 精品国产一区二区三区久久久蜜臀 | 精品在线视频播放| 日本在线www| 国产不卡在线观看| 精品美女| 国产高清视频免费| 午夜在线观看视频免费 成人| 久久精品大片| 国产麻豆精品高清在线播放| 国产伦理精品| 亚洲第一色在线| 欧美国产日韩精品| 精品视频一区二区三区免费| 你懂的日韩| 天天做人人爱夜夜爽2020| 欧美激情一区二区三区在线播放| 国产成人精品综合在线| 亚洲女初尝黑人巨高清在线观看| 日韩女人做爰大片| 国产a视频| 国产一区二区福利久久| 天天做人人爱夜夜爽2020| 国产高清视频免费| 午夜在线亚洲| 日日夜夜婷婷| 国产不卡福利| 欧美1区| 亚飞与亚基在线观看| 香蕉视频亚洲一级| 亚洲 欧美 91| 九九热国产视频| 九九精品在线播放| 美女免费毛片| 国产高清在线精品一区二区 | 999久久久免费精品国产牛牛| 日韩在线观看免费| a级毛片免费观看网站| 国产91丝袜在线播放0| 日韩av东京社区男人的天堂| 国产国产人免费视频成69堂| 精品国产亚洲一区二区三区| 成人免费福利片在线观看| 国产一区二区精品久久| 日韩免费在线视频| 日韩字幕在线| 国产精品123| 日韩女人做爰大片| 九九久久99| 久久久久久久久综合影视网| 色综合久久手机在线| 尤物视频网站在线观看| 99热精品在线| 免费一级生活片|