成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

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

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

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

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

效果圖

文件目錄

文件資源

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

代碼

網(wǎng)頁的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對象,以對所有的參數(shù)和方法進行封裝

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

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

4.畫圖方法的實現(xiàn)就是用 for in 循環(huán)遍歷 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,下面畫圖時給參數(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>

總結

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

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

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

標簽:西寧 佳木斯 淮安 酒泉 十堰 廣西 南京 咸寧

巨人網(wǎng)絡通訊聲明:本文標題《canvas 實現(xiàn) github404動態(tài)效果的示例代碼》,本文關鍵詞  canvas,實現(xiàn),github404,動態(tài),;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《canvas 實現(xiàn) github404動態(tài)效果的示例代碼》相關的同類信息!
  • 本頁收集關于canvas 實現(xiàn) github404動態(tài)效果的示例代碼的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    久久综合九色综合97婷婷女人| 久久九九久久九九| 国产美女高潮| 国产一级二级毛片| 成人免费淫片在线费观看| 东方av正在进入| 国产精品国产三级国产普通话对白| 亚洲国产天堂久久综合网| 99久久人妻无码中文字幕系列| 色狠狠av一区二区三区| 日本少妇aaa| 亚洲一二三四在线观看| 91美女精品福利| 99热国产在线观看| 蜜桃视频在线观看网站| 亚洲伦理久久| 精品亚洲aⅴ在线观看| 开心色怡人综合网站| 不卡中文字幕| 精品成人久久av| xvideos.蜜桃一区二区| 日韩中文字幕久久| 国产精品婷婷午夜在线观看| 一级久久久久久久| 丰满白嫩尤物一区二区| 男人的天堂视频在线| 中文字幕欧美日韩一区| 欧洲激情综合| 国自产精品手机在线观看视频| 美女mm1313爽爽久久久蜜臀| 国产福利精品一区二区| 网曝门事件国产精品二区| 粉嫩av蜜桃av蜜臀av| 亚洲一卡2卡三卡4卡2021四卡| 欧美 日本 国产| 日韩国产一二三区| 国产精品福利视频| 69精品小视频| 欧美亚洲tv| 黄色一区二区视频| 欧美a级片一区| 亚洲天堂视频在线观看免费| 136福利视频| 久久久999视频| 人妻精油按摩bd高清中文字幕| 欧美一级淫片007| 日本激情五月| 好看的av在线不卡观看| 国产精品网红福利| 亚洲综合图区| 亚洲日日夜夜| 国产伦精品一区二区三区妓女下载| 中文字幕一区av| k8久久久一区二区三区| 日本午夜在线亚洲.国产| 97精品国产91久久久久久| aa日韩免费精品视频一| 尤物av无码色av无码| 鲁一鲁一鲁一鲁一av| 另类图片激情| 国产超碰人人模人人爽人人添| 一级黄色av| 欧美乱大交做爰xxxⅹ小说| japanese日本护士撒尿| 国产精品久久久久久9999| 91看片就是不一样| 中文字幕中文字幕在线十八区| 国产精品区一区二区三含羞草| jizz免费观看视频| jvid一区二区三区| 国产盗摄一区二区三区在线| 在线看片中文字幕| 水蜜桃精品av一区二区| 国产美女亚洲精品7777| 欧美一级高清免费播放| 亚洲国产精品久久久久秋霞不卡| 欧洲美女网站| 亚洲制服中文| 国产情侣在线视频| 国产欧美一区二区三区在线看蜜臀| 99热这里只有精品1| 国产综合色在线| 亚洲人成小说网站色在线| 天天综合亚洲| 亚洲一区在线免费| 2020国产成人综合网| 综合在线亚洲| 欧美猛烈性xbxbxbxb| 尤物在线网址| 99re在线精品| 国产 日韩 欧美 成人| 欧美在线一区二区三区四区| 99国产揄拍国产精品| 国产视频一区二区三区在线播放| 羞羞的网站在线观看| 无码av中文一区二区三区桃花岛| 国产人妻777人伦精品hd| 久久精品2019中文字幕| 又粗又硬又爽国产视频| 91免费视频网站| 99久久国产综合精品色伊| 91超碰国产在线| av免费网站在线观看| 日本欧美色综合网站免费| 亚洲天堂国产精品| 久久视频在线视频| 欧美18一14sex性处hd| 久久93精品国产91久久综合| 欧美成人精品3d动漫h| 久久久午夜影院| 黑人巨大亚洲一区二区久| 综合欧美精品| 日韩精品福利网站| 国模私拍一区二区三区| 91视频最新地址| 国产a级全部精品| 日韩欧美精品一区二区综合视频| 色婷婷久久一区二区三区麻豆| 曰批又黄又爽免费视频| 日韩中字在线观看| 精品一区二区国语对白| 成年人网站免费在线观看| av在线无限看| 91精品国产自产在线观看永久∴| 日本成人伦理电影| 日本黄色片在线播放| 亚洲国产一区二区三区四区| 综合综合综合综合综合网| 久久久精品一区| 亚洲免费精彩视频| 久久99久久99精品免观看软件| 精品久久久久一区二区三区| 国产乱xxⅹxx国语对白| www.桃色av嫩草.com| 国产aⅴ精品一区二区三区久久| 亚洲综合图片网| 精品magnet| 国产黄色大片在线观看| 亚洲一区二区精品3399| 噜噜噜噜噜在线视频| 韩日欧美一区二区| 可以免费看黄色的网站| 欧美色图一区二区三区| 爱情岛论坛亚洲首页入口章节| 色婷婷综合网| 精品久久久久一区二区国产| 国产精品成人免费电影| 久久久久久久久影视| 日本久久中文字幕| av成人在线网站| 亚洲永久精品唐人导航网址| 懂色av蜜臀av粉嫩av分享吧| 欧美性受xxxx黑人xyx性爽| 91在线精品播放| 秋霞毛片大全| 逼特逼视频在线| 水野朝阳av一区二区三区| 久久国产精品1区2区3区网页| 国产精品网在线观看| 日本激情一区二区三区| 日日摸夜夜夜夜夜添| 精品免费久久久久久久| 日韩在线视频第一页| 国语自产精品视频在免费| 国产婷婷一区二区| xfplay精品久久| 色播视频在线播放| 亚洲小说区图片| a级片免费观看| 在线成人免费网站| xxxx日本免费| 欧美momandson| 精品一区二区三区电影| 久久精品国产精品亚洲红杏| 欧美日韩高清一区二区| 最近更新的2019中文字幕| 手机在线成人av| 久久久久88色偷偷| 中文字幕日韩一区二区不卡| 最近2019中文免费高清视频观看www99| 欧在线一二三四区| 国产成人精品av久久| 国产又粗又猛又爽又黄的网站| 精品久久久久久中文字幕动漫| 亚洲精品国产成人久久av盗摄| 精品无码一区二区三区爱欲| 婷婷丁香激情网| 欧美在线不卡区| 天天久久夜夜| 91在线观看免费观看| 亚洲人成免费| 欧美精品二区| 亚洲国产91视频| 国产一区二区三区高清在线观看| 视频在线不卡免费观看| 国产999在线观看| 亚洲视频一区在线播放| 加勒比成人在线| 黄页网址在线观看| 天天色天天操天天| 日韩一区欧美小说| 91禁在线看| 中文字幕成人一区| 成人天堂yy6080亚洲高清| 国产精品国产馆在线真实露脸| 成人亚洲精品777777ww| 国产成人精品白浆久久69| 欧美精品黑人性xxxx| 粉嫩粉嫩芽的虎白女18在线视频| 欧美精品一区二区在线观看| 久久精品视频导航| 亚洲卡一卡二| 国产成人av一区二区三区在线观看| 欧美人动性xxxxz0oz| 日韩成人精品一区二区三区| 国产精品毛片在线看| 丰满岳乱妇一区二区三区| 性猛交ⅹ×××乱大交| 日韩欧美123区| 日韩精品视频在线看| 看片网站欧美日韩| 日本免费一区二区视频| 波多野结衣综合网| 蜜桃传媒在线| 老汉av免费一区二区三区| 亚洲最大中文字幕| 三年片观看免费观看大全视频下载| 国产精品996| 日本一二三区在线视频| xxxx在线免费观看| 国产精品免费网站在线观看| 青青草影院在线观看| 亚洲色图欧美在线| 国产精品宾馆| 久久综合九色综合欧美狠狠| 色婷婷综合久久久久中文一区二区| 久久国产精品免费一区二区三区| 免费看av的网址| 国产精品视频一二三| 免费网站成人| 亚洲精品乱码久久久久久自慰| 久久亚洲AV成人无码国产野外| 国产成人77亚洲精品www| 亚洲中文字幕无码一区| 亚洲一区二区少妇| 懂色一区二区三区av片| 亚洲伊人成人网| 国产精品女人久久久久久| 久热免费在线视频| 一本色道久久综合亚洲二区三区| 一区二区导航| 国产精品51麻豆cm传媒| 人妻互换一区二区激情偷拍| 久本草在线中文字幕亚洲| 成 人 黄 色 小说网站 s色| 国产亚洲一区二区三区在线播放| 99.玖玖.com| 四虎精品成人a在线观看| 日韩av在线一区| 国产一区二区三区探花| 高清久久久久久| 亚洲精品自拍区在线观看| 国产传媒国产传媒| 久久久久免费看黄a片app| 伊人免费视频二| 日韩Av无码精品| 午夜免费福利在线观看| 最新国产精品拍自在线播放| 日韩高清免费在线| 久久人妻一区二区| 久久精品色播| 免费日本视频一区| 日本理论片2828理论片| 久久久噜噜噜久久中文字幕色伊伊| 污污视频网站免费观看| 久久在线观看| 精品久久久久久久久久久久| 欧美日韩视频不卡| 国产日韩视频在线观看| 久久99国产精品免费网站| 国产欧美日韩一区二区三区| 久久精品视频16| 91美女视频在线| 成年人福利视频| 你懂得在线视频| 三级电影一区| www.老鸭窝.com| 男男gaygays亚洲| 麻豆免费在线观看视频| 亚洲欧美变态国产另类| 欧美日韩国产中文字幕| 成人在线免费视频| 电影一区二区三区| 最新欧美色图| 九色porny丨入口在线| 欧美黄色大片在线观看| 亚洲成在人线av| 成人av动漫| 在线免费av资源| 99视频免费看| 久久久www成人免费无遮挡大片| 亚洲精品视频网| 777精品久无码人妻蜜桃| 首页综合国产亚洲丝袜| 欧美亚洲黄色| 国产真人无遮挡作爱免费视频| 一级片在线观看视频| 国产精品白丝喷水在线观看| 久久成人一区| 日韩精品一区二区三区在线播放| 狠狠色成人综合网图片区| 欧美另类视频| 久久久久99精品| 国产大尺度视频| 欧美欧美天天天天操| 高清视频一区二区三区| 最近2019中文字幕第三页视频| 泷泽萝拉在线播放| 国产女18毛片多18精品| 欧美全黄视频| 精品国产欧美日韩| 涩涩在线视频| zzijzzij亚洲日本少妇熟睡| 夜夜爽8888| 超碰caoporn久久| 亚洲精品一区中文字幕电影| 欧美高清无遮挡| 国产一区清纯|