本篇文章小编给大家分享一下利用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页面效果
初始化障碍物设置了透明度时
正常游戏时
这里点击右键标记后忘了把填充颜色设置回来。所以后面变红。
丛林探险3 安卓版v454.0
下载敢达决战官方正版 安卓版v6.7.9
下载敢达决战 安卓版v6.7.9
下载像素火影骨架佐助 (Perseverance Fire Shadow)手机版v1.16
下载佩皮之家 最新版v1.14.2
佩皮之家(Pepi House)是一款卡通风格的育儿益智游戏
海魂少女 官方最新版v1.0
海魂少女是一款十分好玩的模拟经营类游戏,玩家在游戏中因为炒股
永远的拓麻歌子 最新安卓版v7.7.2.6078
永远的拓麻歌子是一款十分好玩的模拟类游戏,在这里玩家可以拥有
梦想城镇vivo最新版本 安卓版v12.0.1
梦想城镇vivo版是这款卡通风模拟经营类手游的渠道服版本,玩
怦然心动的瞬间 安卓版v1.0
怦然心动的瞬间是一款真人向的恋爱互动游戏,在游戏中玩家将扮演