前幾天使用css樣式和js致敬了一下github404的類似界面,同時(shí)最近又接觸了canvas,本著瞎折騰的想法,便借著之前的js的算法,使用canvas來完成了github404的動(dòng)態(tài)效果。
這里給canvas 定義好寬和高,設(shè)為塊級(jí)元素。這些img 標(biāo)簽是將這些圖片加載出來,我們就不用在js中去加載了,再將圖片設(shè)為不顯示 display:none。
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ì)算
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>