JavaScript实现网页版贪吃蛇游戏(JavaScript实现网页版贪吃蛇游戏)
类别:编程学习 浏览量:1885
时间:2021-09-30 00:25:15 JavaScript实现网页版贪吃蛇游戏
JavaScript实现网页版贪吃蛇游戏本文实例为大家分享了JavaScript实现网页贪吃蛇游戏的具体代码,供大家参考,具体内容如下
<!DOCTYPE html> <html> <head><title>贪吃蛇</title> </head> <body> <canvas id="canvas" width="400" height="400"></canvas> <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.js"></script> <script> var canv=document.getElementById("canvas"); var ctx=canv.getContext("2d"); var score=0; //定义一个方块的构造函数 var Block=function(col,row,size) { this.col=col; this.row=row; this.size=size; }; //定义Block函数的原型方法draw; Block.prototype.draw =function() { ctx.fillRect(this.col*this.size,this.row*this.size,this.size,this.size) } //定义对象蛇 var snake ={ body:[ new Block(20,20,10), new Block(20,21,10), new Block(20,22,10) ], direction:"right", }; //定义画蛇的函数 snake.draw=function() { for(var i=0;i<this.body.length;i++) { this.body[i].draw(); } }; snake.move = function() { var head = this.body[0]; if(snake.direction=="right") { var newhead=new Block(head.col+1,head.row,head.size) } if(snake.direction =="left") { var newhead = new Block(head.col-1,head.row,head.size); } if(snake.direction=="up") { var newhead=new Block(head.col,head.row-1,head.size) } if(snake.direction=="down") { var newhead=new Block(head.col,head.row+1,head.size) } if(newhead.col<0 || newhead.col>39 ) { clearInterval(intervalId); gameover(); } if(newhead.row<0 || newhead.row>39 ) { clearInterval(intervalId); gameover(); } for(var i=0;i<this.body.length;i++) { if(this.body[i].col==newhead.col &&this.body[i].row==newhead.row) { clearInterval(intervalId); gameover(); } } this.body.unshift(newhead); if(newhead.col==apple.posX &&newhead.row==apple.posY) { score=score+100; while(true) { var checkApple =false; apple.posX=Math.floor(Math.random()*40); apple.posY=Math.floor(Math.random()*40); for(var i=0; i<this.body.length;i++) { if(this.body[i].col==apple.posX &&this.body[i].row==apple.posY) checkApple=true; } if(!checkApple) break; } } else{ this.body.pop(); } }; //创建苹果对象 var apple={ posX:Math.floor(Math.random()*40), posY:Math.floor(Math.random()*40), sizeR:5 } //画苹果函数 apple.draw=function() { ctx.fillStyle="Green"; ctx.beginPath(); ctx.arc(this.posX*10+5,this.posY*10+5,5,0,Math.PI*2,false); ctx.fill(); ctx.fillStyle="Black"; }; //结束 var gameover=function() { ctx.font="60px Comic Sans MS"; ctx.textAlign="center"; ctx.textBaseline="middle"; ctx.fillText("GAME OVER!",200,200) }; //定时功能 var intervalId=setInterval (function () { ctx.clearRect(0,0,400,400); ctx.font="20px Arial"; ctx.fillText("Score:"+score,5,15); snake.draw(); snake.move(); apple.draw(); ctx.strokeRect(0,0,400,400); },200); //贪吃蛇的按键控制 $("body").keydown(function(event) { console.log(event.keyCode); if(event.keyCode==37 &&snake.direction!="right") { snake.direction="left"; } if(event.keyCode==38 &&snake.direction!="down") { snake.direction="up"; } if(event.keyCode==39 &&snake.direction!="left") { snake.direction="right"; } if(event.keyCode==40 &&snake.direction!="up") { snake.direction="down"; } } ); </script> </body> </html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。
您可能感兴趣
- js解除网页屏蔽(js检测标题与描述中的关键词发现就替换或跳转到别的页面)
- js array的所有方法(js 数组 find,some,filter,reduce区别详解)
- js中this的用法
- extjs中apply和applyIf的用法
- node.js缓存区(如何利用node实现静态文件缓存详解)
- js网页截图(JS如何实现页面截屏功能实例代码)
- js手写数组去重(JS对象数组去重的3种方法示例及对比)
- vue.js入门教学第15讲(Vue.js 使用AntV X6的示例步骤)
- extjs中Toolbar工具栏
- vue.js 怎么做插件(Vue.js实现音乐播放器)
- html和js代码结合(JS、CSS和HTML实现注册页面)
- js竖屏切换程序(js判断移动端横竖屏视口检测实现的几种方法)
- jspromise原理(JavaScript使用promise处理多重复请求)
- extjs checkboxGroup 复选框的用法
- js复制内容到剪贴板
- Extjs中grid 的ColumnModel 属性配置
- 王伦狭隘,晁盖霸道,宋江奸诈骨头软,只有鲁智深才适合当寨主(王伦狭隘晁盖霸道)
- 他是梁山最早的头目,江湖人称 旱地忽律 ,宋江几乎将其遗忘(他是梁山最早的头目)
- 梁山创始人杜迁,为何不受宋江待见,只排名83位(梁山创始人杜迁)
- 法国面包(法国面包法棍)
- 微信(微信分身)
- 双十二(双十二和双十一哪个划算)
热门推荐
- 网页颜色的选择
- 阿里云ecs服务器挂了怎么办(阿里云服务器ECS不支持合并多块数据盘怎么办?)
- html5+canvas动画(解析html5 canvas实现背景鼠标连线动态效果代码)
- centos安装mysql8.0教程(Centos7 安装 Mysql8教程)
- html5创作(HTML5录音实践总结Preact)
- tomcat原理详解(解析Tomcat架构原理到架构设计)
- 香港服务器有哪些优势呢(浅谈香港服务器与香港云主机的区别)
- 云服务器的安全问题(云服务器如何提高安全组性能?)
- docker配置文件详解(Docker中搭建FastDFS文件系统多图教程)
- css如何做出矩形三角流程效果(css做个波浪悬浮球的实现方法)