欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

如何使用canvas實(shí)現(xiàn)github404動(dòng)態(tài)-創(chuàng)新互聯(lián)

如何使用canvas實(shí)現(xiàn)github404動(dòng)態(tài)?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。

十多年建站經(jīng)驗(yàn), 成都網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站客戶(hù)的見(jiàn)證與正確選擇。成都創(chuàng)新互聯(lián)提供完善的營(yíng)銷(xiāo)型網(wǎng)頁(yè)建站明細(xì)報(bào)價(jià)表。后期開(kāi)發(fā)更加便捷高效,我們致力于追求更美、更快、更規(guī)范。

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

文件資源

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

代碼

網(wǎng)頁(yè)的body部分

這里給canvas 定義好寬和高,設(shè)為塊級(jí)元素。這些img 標(biāo)簽是將這些圖片加載出來(lái),我們就不用在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()方法用來(lái)初始化,是與外部的接口

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

<script>
        var github404 = {
            imgData: {//將所有圖片的信息用json對(duì)象記錄
                bg: {
                    top: 0,
                    left: 110,//top和left用于定位,在畫(huà)圖時(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');//獲得畫(huà)筆
                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í)重新畫(huà)圖的方法
                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,下面畫(huà)圖時(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>

關(guān)于如何使用canvas實(shí)現(xiàn)github404動(dòng)態(tài)問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站制作公司行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

網(wǎng)站名稱(chēng):如何使用canvas實(shí)現(xiàn)github404動(dòng)態(tài)-創(chuàng)新互聯(lián)
網(wǎng)頁(yè)路徑:http://aaarwkj.com/article46/icphg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作軟件開(kāi)發(fā)商城網(wǎng)站網(wǎng)站維護(hù)、品牌網(wǎng)站制作、小程序開(kāi)發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運(yùn)營(yíng)
日韩精品一区福利合集| 高清中文字幕一区二区三区| 白天躁晚上躁天天躁在线| 欧美熟女av在线观看| 国产三级精品三级在线播放| 欧美日本午夜福利在线观看| 亚洲综合偷拍欧美一区色| 日韩一区二区三区中文字幕| 成人午夜激情四射av| 伊在人亚洲香蕉精品区| 亚洲精品在线观看日韩欧美| 国产精品久久久久久久av三级| 国产精品99久久久久久宅男九| 欧美性色黄大片人与善| 91精品人妻互换一区二区| 国产一区 亚洲精品| 国产自产一区二区三区精品| 精品久久激情中文字幕| 十八禁真人无摭挡观看| 精品人妻一区两区三区| 亚洲国产精品视频自拍| 四虎在线观看精品一区| 欧美日韩亚洲精品一区二区三区| 日韩欧美一区亚洲一区| 国产丝袜在线福利观看| 亚洲三级伦理在线视频| 国产自拍成人精品视频| 2023天天操夜夜操| 亚洲区一区二区三区精品| 亚洲国产精品一区二区成人| 欧美日韩精品乱码在线观看| 午夜激情视频福利在线观看| 精品国产一区二区日韩91| 另类视频在线观看免费| 国产精品久久久99| 欧美色高清视频在线播放| 国产一区二区三区精品女同| 亚洲中文永久免费视频| 麻豆视传媒官网免费观看| 亚洲中少妇久久中文字幕| 日本一区二区日本一区|