久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

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

本篇文章主要介紹了canvas 實現 github404動態效果的示例代碼,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

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

效果圖

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

文件目錄

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對象去封裝數據和方法,如何組織代碼都有了更深的一些了解。

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

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

本篇文章主要介紹了html5中canvas圖表實現柱狀圖的示例,本文使用canvas來實現一個圖表,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
本篇文章主要介紹了教你使用Canvas處理圖片的方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
本篇文章主要介紹了Canvas與圖片壓縮的示例代碼,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
這篇文章主要介紹了基于HTML5 Canvas的3D動態Chart圖表的示例,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
本篇文章主要介紹了canvas之自定義頭像功能實現代碼示例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本篇文章主要介紹了html5清空畫布方法(三種),小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
主站蜘蛛池模板: 正在播放国产精品 | 欧美一级做a爰片免费视频 国产美女特级嫩嫩嫩bbb片 | 欧美日韩国产在线观看 | 久久视频精品 | 欧产日产国产精品v | 伦理二区 | 羞羞视频在线网站观看 | 国产精品亚洲一区二区三区在线观看 | 四虎影院免费在线播放 | 国产日韩av一区二区 | 久久久久国 | 在线免费中文字幕 | 1区2区3区视频 | 91精品国产综合久久久动漫日韩 | 久久91| 玖玖玖在线观看 | 欧美一区二区在线观看 | 在线视频一区二区 | 精久久久 | 中文字幕在线视频免费视频 | 一区二区久久 | www.久| 久久精品二区亚洲w码 | 日韩欧美在线观看 | 亚洲精品免费观看 | 狠狠操婷婷 | 操操操av | 成人免费视频网址 | 黄色片在线网站 | 成人一区二区三区视频 | 久草新在线| 自拍偷拍亚洲一区 | 麻豆精品国产91久久久久久 | 久久九| h视频在线观看免费 | 天天干干 | 欧美一级免费观看 | 久久久久久久综合 | 波多野结衣中文字幕一区二区三区 | 亚洲午夜av久久乱码 | 国产91丝袜在线播放 |