濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫 > canvas 實(shí)現(xiàn) github404動(dòng)態(tài)效果的示例代碼

canvas 實(shí)現(xiàn) github404動(dòng)態(tài)效果的示例代碼

熱門標(biāo)簽:江蘇智能電銷機(jī)器人哪家好 成都智能外呼系統(tǒng)平臺(tái) 當(dāng)涂高德地圖標(biāo)注 鎮(zhèn)江智能外呼系統(tǒng)有效果嗎 電銷機(jī)器人電話用什么卡 云南大理400電話申請(qǐng)官方 黃島區(qū)地圖標(biāo)注 南寧點(diǎn)撥外呼系統(tǒng)哪家公司做的好 四川點(diǎn)撥外呼系統(tǒng)

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

效果圖

文件目錄

文件資源

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

代碼

網(wǎng)頁的body部分

這里給canvas 定義好寬和高,設(shè)為塊級(jí)元素。這些img 標(biāo)簽是將這些圖片加載出來,我們就不用在js中去加載了,再將圖片設(shè)為不顯示 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.這里我還是新建了一個(gè)名為github404的json對(duì)象,以對(duì)所有的參數(shù)和方法進(jìn)行封裝

2.再創(chuàng)建imgData的對(duì)象,將所有的img所需的參數(shù)傳入ps:top和left用于 drawImage() 方法時(shí)定位, scale 參數(shù)用于計(jì)算鼠標(biāo)移動(dòng)時(shí)對(duì)應(yīng)的圖片移動(dòng)的計(jì)算

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

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

<script>
        var github404 = {
            imgData: {//將所有圖片的信息用json對(duì)象記錄
                bg: {
                    top: 0,
                    left: 110,//top和left用于定位,在畫圖時(shí)使用
                    src: './images/field.png',//對(duì)應(yīng)圖片路徑
                    scale: 0.06,//鼠標(biāo)移動(dòng)時(shí),該圖片所對(duì)應(yīng)移動(dòng)的比例
                },
                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() {//計(jì)算偏移比的方法
                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 對(duì)象
                    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) {//鼠標(biāo)移動(dòng)時(shí)重新畫圖的方法
                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,下面畫圖時(shí)給參數(shù)定位
                    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() {
            //只調(diào)用github404的init方法 封裝了數(shù)據(jù)
            github404.init();
        }
    </script>

總結(jié)

此次使用canvas來完成這個(gè)動(dòng)態(tài)效果,使我更多的了解了canvas的用法。同時(shí)使我

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:西寧 佳木斯 淮安 酒泉 十堰 廣西 南京 咸寧

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《canvas 實(shí)現(xiàn) github404動(dòng)態(tài)效果的示例代碼》,本文關(guān)鍵詞  canvas,實(shí)現(xiàn),github404,動(dòng)態(tài),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《canvas 實(shí)現(xiàn) github404動(dòng)態(tài)效果的示例代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于canvas 實(shí)現(xiàn) github404動(dòng)態(tài)效果的示例代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    仁化县| 黄梅县| 惠东县| 唐山市| 仲巴县| 临湘市| 灌南县| 游戏| 永吉县| 仁布县| 泰安市| 昌宁县| 巢湖市| 兴文县| 东明县| 卢氏县| 平昌县| 馆陶县| 咸丰县| 蓬溪县| 澄迈县| 黔江区| 庆城县| 城固县| 泸水县| 大理市| 青龙| 西乡县| 贺兰县| 桐梓县| 东兴市| 嘉定区| 石屏县| 和龙市| 特克斯县| 昭平县| 旌德县| 永州市| 田阳县| 长沙市| 广宁县|