日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

原生js canvas實現(xiàn)簡單貪吃蛇

瀏覽:170日期:2024-04-03 18:01:06

本文實例為大家分享了js canvas實現(xiàn)簡單貪吃蛇的具體代碼,供大家參考,具體內(nèi)容如下

Js原生貪吃蛇:canvas

HTML

<canvas id='can'></canvas>

CSS

#can{ background: #000000; height: 400px; width: 850px;}

JS

//公共板塊var blockSize = 10;//地圖的高寬var mapW = 300;var mapH = 150;//歷史食物varvar historyfood = new Array();//食物數(shù)組var img = new Image()var arrFood = ['ananas.png','hamburg.png','watermelon.png']historyfood =[{x: 0,y:0}];//貪吃蛇默認值var snake = [{x:3,y:0},{x:2,y:0},{x:1,y:0}]//貪吃蛇方向var directionX = 1;var directionY = 0;//添加一個標記,標記食物是否被吃掉//默認值:沒有被吃掉var isFood = false;//判斷游戲狀態(tài)//默認游戲繼續(xù)var gameState = false;//限制貪吃蛇所移動的方向不能反方向操作var lockleft = true;var lockright = true;var lockup = true;var lockdown = true;//貪吃蛇分數(shù)var count = 0;//貪吃蛇速度var speed = 1000 - (count + 5);$(function () { $('#divContainer').height($('#can').height()); //1,獲取到畫布對象 var can = document.getElementById('can'); //2,獲取到畫圖工具箱 var tools = can.getContext(’2d’); tools.beginPath(); //設置食物默認值 var XY = Randomfood(); console.log(XY); var x1 = Randomfood().x; var y1 = Randomfood().y; img.src = 'http://www.b3g6.com/aimless/img/GluttonousSnakeFood/'+ arrFood[Math.floor(Math.random() * arrFood.length)]; //控制貪吃蛇移動 document.addEventListener(’keydown’,function (e){ switch (e.keyCode) { case 38: if (lockup){ directionX = 0; directionY = -1; lockdown = false; lockleft = true; lockright = true; } break; case 40: if (lockdown){ directionX = 0; directionY = 1; lockup = false; lockleft = true; lockright = true; } break; case 37: if (lockleft){ directionX = - 1; directionY = 0; lockright = false; lockup = true; lockdown = true; } break; case 39: if (lockright){ directionX = 1; directionY = 0; lockleft = false; lockup = true; lockdown = true; } break; } }) setIntervalSnake(tools,x1,y1); //4,找位置})function setIntervalSnake(tools,x1,y1){ setInterval(function (){ if (gameState){ return; } //1,擦除畫板 tools.clearRect(0,0,850,420); var oldHead = snake[0]; if (oldHead.x < 0 || oldHead.y < 0 || oldHead.x * blockSize >= mapW || oldHead.y * blockSize >= mapH){ gameState = true; alert('游戲結(jié)束'); }else { //蛇移動 if (snake[0].x * blockSize === x1 && snake[0].y * blockSize === y1){ isFood = true; } else { snake.pop() } var newHead = { x: oldHead.x + directionX, y: oldHead.y + directionY } snake.unshift(newHead); } //2,判斷食物是否被吃掉,吃掉刷新,不吃掉不刷新 if (isFood){ count = count + 1; $('#count').html(count); x1 = Randomfood().x; y1 = Randomfood().y; img.src = 'http://www.b3g6.com/aimless/img/GluttonousSnakeFood/'+ arrFood[Math.floor(Math.random() * arrFood.length)]; isFood = false; } tools.drawImage(img,x1,y1,blockSize,blockSize); //蛇身數(shù)組 var Thesnakebody = new Array(); //3,畫蛇 for (var i = 0; i < snake.length; i++){ if (i == 0){ tools.fillStyle = '#9933CC'; } else { var newHead1 = { x: snake[i].x, y: snake[i].y } Thesnakebody.unshift(newHead1); tools.fillStyle = '#33adcc'; } tools.fillRect(snake[i].x * blockSize,snake[i].y * blockSize,blockSize,blockSize); } // //判斷蛇頭咬到了蛇身 Thesnakebody.forEach(item=>{ if(item.x == snake[0].x && item.y == snake[0].y){ gameState = true; setIntervalSnake(tools,x1,y1); } }) //4,畫地圖 var width = Math.round($('#can').width() / blockSize); var height = Math.round($('#can').height() / blockSize); for (var i = 1; i < width;i++){ tools.moveTo(0,blockSize * i); tools.lineTo($('#can').width(),blockSize * i); } for (var i = 1; i < height;i++){ tools.moveTo(blockSize * i,0); tools.lineTo(blockSize * i,$('#can').height()); } tools.strokeStyle = '#FFFFFF'; //5,繪制 tools.stroke(); },speed / 3);}//隨機食物不function Randomfood() { var RandomX = Math.floor(Math.random() * mapW / blockSize) * blockSize; var RandomY = Math.floor(Math.random() * mapH / blockSize) * blockSize; setInterval(function (){ snake.forEach(item=>{ console.log(RandomX / blockSize,RandomY / blockSize); // console.log(item.x,item.y); if(item.x == RandomX / blockSize && item.y == RandomY / blockSize){ return Randomfood(); } else { return ; } }) }, 10 / 3); var newRandom = { x: RandomX, y: RandomY } return newRandom;}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产 日韩 欧美 综合 一区| 激情五月综合| 蜜臀av在线播放一区二区三区 | 久久亚洲视频| 国内精品伊人| av综合电影网站| 亚洲v在线看| 亚洲一区二区三区高清不卡| 亚洲激情婷婷| 亚洲v天堂v手机在线| 日韩av字幕| 国产精久久久| 日本精品在线中文字幕| 91久久黄色| 日韩av网站在线观看| 国产精品大片免费观看| 成人美女视频| 亚洲欧美日韩视频二区| 亚洲精品系列| 美女久久99| 欧美亚洲精品在线| 综合激情网...| 国内精品伊人| 99国产精品私拍| 91综合网人人| 亚洲综合小说| 精品入口麻豆88视频| 日韩av一级| 日韩精品一区二区三区中文| 精品久久一区| 亚洲天堂av资源在线观看| 国产福利一区二区精品秒拍 | 免费人成精品欧美精品| 国产伦乱精品| 香蕉成人av| 日本不卡高清| 激情国产在线| 亚洲综合色婷婷在线观看| 精品一区视频| 在线视频亚洲| 欧美国产中文高清| 99久久精品网| 国产色噜噜噜91在线精品| 日韩毛片在线| 久久狠狠亚洲综合| 黄色不卡一区| 精品一区二区三区中文字幕视频| 岛国精品一区| 亚洲精品第一| 欧美一级精品| 精品91福利视频| 免费不卡中文字幕在线| 欧美国产极品| 日韩美女精品| 麻豆精品蜜桃| 久久91视频| 日韩精品视频中文字幕| 亚洲性视频h| 亚洲精品一二三区区别| 粉嫩av一区二区三区四区五区| 亚洲精品无播放器在线播放| 伊人久久av| 欧美中文一区| 999在线观看精品免费不卡网站| 国产精品麻豆久久| 国产亚洲久久| 午夜性色一区二区三区免费视频| 免费黄色成人| 激情国产在线| 高清av一区| 久久69成人| 久久的色偷偷| 国产欧美一区二区精品久久久 | 婷婷综合六月| 精品高清久久| 国产精品手机在线播放| 亚洲一区有码| 99在线|亚洲一区二区| 精品捆绑调教一区二区三区| 精品一二三区| 久久久精品国产**网站| 欧美视频二区| 日韩精品亚洲专区| 午夜精品影视国产一区在线麻豆| 日韩午夜黄色| 久久精品播放| 人人香蕉久久| a天堂资源在线| 国产精品15p| 欧美黑人做爰爽爽爽| 国产精品密蕾丝视频下载| 国产一级成人av| 国产精品最新| 伊人精品久久| 日韩国产在线观看| 国产视频一区二区在线播放| 日韩av影院| 国产精品调教视频| 精品网站999| 亚洲精品成人图区| 国产美女高潮在线观看| 日韩啪啪电影网| 久久国产中文字幕| 9久re热视频在线精品| 爽爽淫人综合网网站| 日韩一区二区三区精品| 欧美日韩一区二区三区四区在线观看| 欧美亚洲专区| 精品久久99| 欧美日韩视频免费观看| 99精品一区| 视频一区二区欧美| 日韩成人午夜精品| 国产一区二区色噜噜| 日本免费一区二区三区四区| 日韩一区自拍| 香蕉久久久久久久av网站| 亚洲综合婷婷| 久久精品国产999大香线蕉| 欧美二三四区| 久久高清免费观看| 欧美日一区二区在线观看| 久久爱www.| 亚洲va在线| 免费精品视频| 国产精东传媒成人av电影| 日韩电影免费在线观看| 国产毛片久久| 欧美日韩99| 久久婷婷丁香| 日韩精品一二三区| 国产精品v亚洲精品v日韩精品| 在线天堂资源www在线污| 欧美精品一线| 国产亚洲久久| 亚洲福利免费| 日韩高清在线不卡| 久久精品国产精品亚洲毛片| 激情欧美亚洲| 日韩精品久久理论片| 综合日韩av| 亚洲九九精品| 日韩伦理在线一区| 日本亚洲视频| 成人午夜网址| 一区二区亚洲精品| 国产剧情在线观看一区| 九九综合九九| 国产毛片一区二区三区| 91精品国产自产在线观看永久∴| 中文一区一区三区免费在线观 | 亚洲伦乱视频| 亚洲色图国产| 国产精品成久久久久| 香蕉成人久久| 国产suv精品一区二区四区视频| 视频一区中文字幕| 国产一区二区三区亚洲综合| 免费一级片91| 91精品啪在线观看国产18| 日本强好片久久久久久aaa| 久久一区二区中文字幕| 国产高清亚洲| 亚洲香蕉视频| 亚洲成人不卡| 国产精品欧美三级在线观看| 国产精品日韩| 日韩精品dvd| 国产精品久久久久久久久久久久久久久| 久久精品不卡| 日韩国产激情| 免费精品一区| 日韩高清一区| 亚洲资源av| 久久影视一区| 国产福利片在线观看| 国产精品视频一区二区三区综合 | 欧美日韩三区| 亚洲欧洲高清| 久久超级碰碰| 日韩福利视频导航| 蜜桃视频一区二区三区| 伊人久久成人| 久久精品国产大片免费观看| 成人精品久久| 精品三级av| 欧美激情三区| 日韩av成人高清| 蜜桃视频一区二区三区| 在线国产一区二区| 99热国内精品| 中国字幕a在线看韩国电影| 国产伦乱精品| 国产精品一区高清| 日韩不卡在线观看日韩不卡视频| 在线国产一区二区| 免费精品国产的网站免费观看| 少妇精品导航| 久久男女视频| 亚洲激情久久|