本篇文章小编给大家分享一下利用js+canvas实现扫雷游戏代码示例,文章代码介绍的很详细,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。
记录js学习后制作的第一关小游戏。
这里的代码还不够精简,许多地方偷懒没有封装,逻辑也有许多可以优化。
胜利条件,找出所有地雷并标记
lei.js
/* 一个自定义原型数组方法 可以放到html里 二维数组查找 arr:要找数组第一第二项 找到返回下标,没有返回-1 PS:只要this数组和arr数组第一第二项的值相等,即为找到。 */ Array.prototype.myindexOf = function(arr){ for(let i=0;i{ if(this.booArrs.length ==this.markArrs.length){ for(let i=0;i { return this.markArrs.myindexOf(this.booArrs[i])!=-1; })){ this.booNum--; } if(this.booNum==0){ clearInterval(this.tim); alert('you are win'); } } } },10) } isboo(ctx,x,y,booArrs,numArrs,markArrs,xyNum){ new Isboo(ctx,x,y,booArrs,numArrs,markArrs,xyNum); } /*标记 */ markObs(x,y){ console.log(x,y); new MarkObs(this.ctx,x,y,this.booArrs,this.divw,this.markArrs); } }
isboo.js
Array.prototype.myindexOf = function(arr){ for(let i=0;i=0)&&(markArrs.myindexOf([x,y])==-1)){ ctx.clearRect(x*21,y*21,20,20); x-=1; // this.isbool(ctx,x,y,booArrs,numArrs,markArrs,xyNum); this.isboor(ctx,x,y,booArrs,numArrs,markArrs,xyNum); this.isboot(ctx,x,y,booArrs,numArrs,markArrs,xyNum); this.isboob(ctx,x,y,booArrs,numArrs,markArrs,xyNum); }else { return ; } } isboot(ctx,x,y,booArrs,numArrs,markArrs,xyNum){ if((numArrs.myindexOf([x,y])==-1)&&(y =0)&&(markArrs.myindexOf([x,y])==-1)){ ctx.clearRect(x*21,y*21,20,20); y-=1; // this.isbool(ctx,x,y,booArrs,numArrs,markArrs,xyNum); // this.isboor(ctx,x,y,booArrs,numArrs,markArrs,xyNum); // this.isboot(ctx,x,y,booArrs,numArrs,markArrs,xyNum); this.isboob(ctx,x,y,booArrs,numArrs,markArrs,xyNum); }else { return ; } } }
MarkObs.js
Array.prototype.myindexOf = function(arr){ for(let i=0;i页面效果
初始化障碍物设置了透明度时
正常游戏时
这里点击右键标记后忘了把填充颜色设置回来。所以后面变红。
敢达决战官方正版 安卓版v6.7.9
下载敢达决战 安卓版v6.7.9
下载像素火影骨架佐助 (Perseverance Fire Shadow)手机版v1.16
下载要塞英雄 安卓版v33.20.0-39082670-Android
下载梦想城镇vivo最新版本 安卓版v12.0.1
梦想城镇vivo版是这款卡通风模拟经营类手游的渠道服版本,玩
怦然心动的瞬间 安卓版v1.0
怦然心动的瞬间是一款真人向的恋爱互动游戏,在游戏中玩家将扮演
曼尼汉堡店游戏 安卓版v1.0.3
曼尼汉堡店是一款非常好玩的精品恐怖类型冒险游戏,在这款游戏中
现代总统模拟器去广告版 安卓版v1.0.46
现代总统模拟器是一款休闲养成类游戏,可能对于不少的玩家来说都
现代总统模拟器付费完整版 安卓版v1.0.46
现代总统模拟器高级版在商店是需要付费的,相对于普通版本,高级