原生js canvas實(shí)現(xiàn)簡(jiǎn)單貪吃蛇
本文實(shí)例為大家分享了js canvas實(shí)現(xiàn)簡(jiǎ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;
//歷史食物var
var historyfood = new Array();
//食物數(shù)組
var img = new Image()
var arrFood = ["ananas.png","hamburg.png","watermelon.png"]
historyfood =[{x: 0,y:0}];
//貪吃蛇默認(rèn)值
var snake = [{x:3,y:0},{x:2,y:0},{x:1,y:0}]
//貪吃蛇方向
var directionX = 1;
var directionY = 0;
//添加一個(gè)標(biāo)記,標(biāo)記食物是否被吃掉
//默認(rèn)值:沒有被吃掉
var isFood = false;
//判斷游戲狀態(tài)
//默認(rèn)游戲繼續(xù)
var gameState = false;
//限制貪吃蛇所移動(dòng)的方向不能反方向操作
var lockleft = true;
var lockright = true;
var lockup = true;
var lockdown = true;
//貪吃蛇分?jǐn)?shù)
var count = 0;
//貪吃蛇速度
var speed = 1000 - (count + 5);
$(function () {
$("#divContainer").height($("#can").height());
//1,獲取到畫布對(duì)象
var can = document.getElementById("can");
//2,獲取到畫圖工具箱
var tools = can.getContext('2d');
tools.beginPath();
//設(shè)置食物默認(rèn)值
var XY = Randomfood();
console.log(XY);
var x1 = Randomfood().x;
var y1 = Randomfood().y;
img.src = "/aimless/img/GluttonousSnakeFood/"+ arrFood[Math.floor(Math.random() * arrFood.length)];
//控制貪吃蛇移動(dòng)
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 {
//蛇移動(dòng)
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 = "/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);
}
//隨機(jī)食物不
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)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
微信小程序一周時(shí)間表功能實(shí)現(xiàn)
這篇文章主要介紹了微信小程序一周時(shí)間表功能實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10
微信小程序自定義彈窗實(shí)現(xiàn)詳解(可通用)
這篇文章主要介紹了微信小程序自定義彈窗實(shí)現(xiàn)詳解(可通用),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07
微信小程序自定義toast實(shí)現(xiàn)方法詳解【附demo源碼下載】
這篇文章主要介紹了微信小程序自定義toast實(shí)現(xiàn)方法,簡(jiǎn)單描述了微信小程序自帶toast使用方法,并結(jié)合實(shí)例形式分析了自定義toast的定義與使用方法,需要的朋友可以參考下2017-11-11
使用JavaScript判斷圖片是否加載完成的三種實(shí)現(xiàn)方式
有時(shí)需要獲取圖片的尺寸,這需要在圖片加載完成以后才可以,本文有三個(gè)不錯(cuò)的實(shí)現(xiàn)方式在此與大家分享下2014-05-05
基于Bootstrap 3 JQuery及RegExp的表單驗(yàn)證功能
這篇文章主要介紹了基于Bootstrap 3 JQuery及RegExp的表單驗(yàn)證功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02
JavaScript實(shí)現(xiàn)瀑布流布局的代碼分享
不知道大家在線上購物的時(shí)候有沒有發(fā)現(xiàn)到,自己逛起來根本就停不下來,越往下翻越是覺得就會(huì)出現(xiàn)需要的東西,這就是很多電商公司都在使用的瀑布流布局。本文就來用JS實(shí)現(xiàn)這一布局,需要的可以參考一下2023-04-04
JavaScript登錄記住密碼操作(超簡(jiǎn)單代碼)
本文給大家分享一段簡(jiǎn)單的js代碼實(shí)現(xiàn)用戶登錄記住密碼操作,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2017-03-03

