亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > HTML5 > 正文

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

2024-09-05 07:22:12
字體:
來源:轉載
供稿:網友

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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久免费高清电视剧观看| 国产亚洲人成网站在线观看| 欧美视频在线观看 亚洲欧| 亚洲国产一区二区三区在线观看| 精品福利樱桃av导航| 久久人体大胆视频| 久久精品电影网| 色悠悠国产精品| 欧美成人中文字幕在线| 日韩一区二区福利| 亚洲精品视频中文字幕| 欧美资源在线观看| 国产精品极品美女粉嫩高清在线| 色噜噜狠狠狠综合曰曰曰88av| 欧美麻豆久久久久久中文| 亚洲最大福利网| 51ⅴ精品国产91久久久久久| 国产午夜精品全部视频在线播放| 欧美特黄级在线| 亚洲高清久久久久久| 尤物yw午夜国产精品视频明星| 91chinesevideo永久地址| 91在线观看免费观看| 亚洲美女性生活视频| 色哟哟入口国产精品| 日韩精品在线视频观看| 国产成人极品视频| 欧美日韩国产色| 欧美性xxxx18| 中文字幕日韩欧美在线视频| 91高清视频在线免费观看| 中文字幕九色91在线| 国产精品久久一区主播| 日韩在线观看免费高清| 色婷婷亚洲mv天堂mv在影片| 久久久久久久久91| 欧美日韩性生活视频| 成人在线一区二区| 国产一区二区三区在线观看视频| 一夜七次郎国产精品亚洲| 欧美一级片免费在线| 欧美性色视频在线| 国外色69视频在线观看| 国产专区精品视频| 亚洲日本欧美中文幕| 日韩禁在线播放| 国语自产精品视频在免费| 国产不卡精品视男人的天堂| 亚洲码在线观看| 国产精品狠色婷| 日韩成人av在线播放| 国产精品99蜜臀久久不卡二区| 欧亚精品中文字幕| 日韩av免费在线播放| 国产精品扒开腿做爽爽爽视频| 亚洲国产成人精品一区二区| 久久91亚洲人成电影网站| 一区二区亚洲欧洲国产日韩| 欧美成人中文字幕在线| 色悠久久久久综合先锋影音下载| 亚洲国产精品人人爽夜夜爽| 日本久久久久久久| 一本一道久久a久久精品逆3p| 中日韩美女免费视频网址在线观看| 亚洲人免费视频| 亚洲欧美激情在线视频| 欧美综合国产精品久久丁香| 亚洲欧洲偷拍精品| 日本免费一区二区三区视频观看| 日韩免费在线播放| 久久精品一偷一偷国产| 欧美成人第一页| 国产精品日韩在线播放| 国产精品亚洲美女av网站| 亚洲国产欧美在线成人app| 亚洲欧美一区二区三区情侣bbw| 亚洲综合成人婷婷小说| 亚洲成人网久久久| 国产在线观看一区二区三区| 国产在线视频91| 国产精品一区二区久久精品| 国产精品自拍小视频| 欧美在线视频导航| 色综合久久久久久中文网| 国内精品久久久久久| 日韩av在线最新| 久久久精品2019中文字幕神马| 亚洲色在线视频| 日韩成人免费视频| 欧美另类极品videosbestfree| 日韩精品999| 欧美日韩国产精品专区| 亚洲aⅴ日韩av电影在线观看| 国产精品偷伦视频免费观看国产| 亚洲专区中文字幕| 日本国产精品视频| 亚洲欧美一区二区三区四区| 欧亚精品中文字幕| 亚洲2020天天堂在线观看| 国产美女91呻吟求| 日韩欧美国产视频| 97在线看免费观看视频在线观看| 欧美性xxxxx极品| 亚洲2020天天堂在线观看| 亚洲国产欧美一区二区丝袜黑人| 欧美日韩国产一区在线| 国产一区二区丝袜| 久久夜色撩人精品| 91日本在线视频| 97超级碰碰碰久久久| 国产成人精品久久| 国产69精品久久久久9999| 欧美性猛交xxxx富婆弯腰| 欧美日韩精品中文字幕| 欧美日韩福利在线观看| 欧美在线观看一区二区三区| 国产精品久久久久91| 色婷婷综合成人| 国产精品99久久久久久人| 中文字幕亚洲一区在线观看| 91精品国产91久久久久| 亚洲人成网站免费播放| 亚洲xxxx做受欧美| 国产精品日韩一区| 亚洲91精品在线| 亚洲人成电影在线观看天堂色| 欧美精品一本久久男人的天堂| 久久久免费av| 亚洲精选在线观看| 亚洲第一综合天堂另类专| 国产精品精品一区二区三区午夜版| 亚洲高清久久久久久| 日韩免费在线播放| 国产精品十八以下禁看| 美女扒开尿口让男人操亚洲视频网站| 久久久精品国产| 久久99视频免费| 久久偷看各类女兵18女厕嘘嘘| 在线不卡国产精品| 97超碰蝌蚪网人人做人人爽| 欧美精品18videos性欧| 欧美国产一区二区三区| 亚洲三级免费看| 久久色免费在线视频| 国产又爽又黄的激情精品视频| 狠狠久久亚洲欧美专区| www.欧美精品一二三区| 国语自产在线不卡| 中文字幕视频一区二区在线有码| 欧美精品久久久久久久| 日韩av大片在线| 欧美高清在线播放| 日韩高清电影免费观看完整版| 亚洲国产小视频| 性欧美xxxx交| 日韩女优人人人人射在线视频| 欧美激情欧美激情| 亚洲精品一区在线观看香蕉| 亚洲aⅴ日韩av电影在线观看| 色樱桃影院亚洲精品影院| 成人黄色午夜影院| 国产精品嫩草影院久久久| 成人做爰www免费看视频网站| 亚洲天堂网在线观看|