jquery实现走迷宫游戏代码

代码语言:html

所属分类:游戏

代码描述:jquery实现走迷宫游戏代码

代码标签: jquery 迷宫 游戏

下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <style>
html,body {
	width: 100vw;
	height: 100vh;
	position: fixed;
	padding: 0;
	margin: 0;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0
}

#mazeContainer {
	transition-property: opacity;
	transition-duration: 1s;
	transition-timing-function: linear;
	top: 75px;
	opacity: 0;
	display: inline-block;
	background-color: rgba(0,0,0,0.3);
	margin: auto
}

#mazeContainer #mazeCanvas {
	margin: 0;
	display: block;
	border: solid 1px black
}

input,select {
	transition-property: background-color opacity;
	transition-duration: .2s;
	transition-timing-function: ease-in-out;
	cursor: pointer;
	background-color: rgba(0,0,0,0.3);
	height: 45px;
	width: 150px;
	padding: 10px;
	border: 0;
	border-radius: 5px;
	color: white;
	display: inline-block;
	font-size: 15px;
	text-align: center;
	text-decoration: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none
}

input:hover,select:hover {
	background-color: rgba(0,0,0,0.7)
}

input:active,select:active {
	background-color: black
}

input:focus,select:focus {
	outline: 0
}

.custom-select {
	display: inline-block
}

.custom-select select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-image: url("");
	background-repeat: no-repeat;
	background-position: 125px center
}

#Message-Container {
	visibility: hidden;
	color: white;
	display: block;
	width: 100vw;
	height: 100vh;
	position: fixed;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	background-color: rgba(0,0,0,0.3);
	z-index: 1
}

#Message-Container #message {
	width: 300px;
	height: 300px;
	position: fixed;
	top: 50%;
	left: 50%;
	margin-left: -150px;
	margin-top: -150px
}

#page {
	font-family: "Segoe UI",Arial,sans-serif;
	text-align: center;
	height: auto;
	width: auto;
	margin: auto
}

#page #menu {
	margin: auto;
	padding: 10px;
	height: 65px;
	box-sizing: border-box
}

#page #menu h1 {
	margin: 0;
	margin-bottom: 10px;
	font-weight: 600;
	font-size: 3.2rem
}

#page #view {
	position: absolute;
	top: 65px;
	bottom: 0;
	left: 0;
	right: 0;
	width: 100%;
	height: auto
}

.border {
	border: 1px black solid;
	border-radius: 5px
}

#gradient {
	z-index: -1;
	position: fixed;
	top: 0;
	bottom: 0;
	width: 100vw;
	height: 100vh;
	color: #fff;
	background: linear-gradient(-45deg,#EE7752,#E73C7E,#23A6D5,#23D5AB);
	background-size: 400% 400%;
	-webkit-animation: Gradient 15s ease infinite;
	animation: Gradient 15s ease infinite
}

@-webkit-keyframes Gradient {
	0% {
		background-position: 0 50%
	}

	50% {
		background-position: 100% 50%
	}

	100% {
		background-position: 0 50%
	}
}

@keyframes Gradient {
	0% {
		background-position: 0 50%
	}

	50% {
		background-position: 100% 50%
	}

	100% {
		background-position: 0 50%
	}
}

@media only screen and (max-width:400px) {
	input,select {
		width: 120px
	}
}
    </style>
</head>


<body>
    <div id="gradient"></div>
    <div id="page">
        <div id="Message-Container">
            <div id="message">
                <h1>Congratulations!</h1>
                <p>You are done.</p>
                <p id="moves"></p><input id="okBtn" type="button" onclick="toggleVisablity('Message-Container')" value="Cool!" /></div>
        </div>
        <div id="menu">
            <div class="custom-select"><select id="diffSelect"><option value="10">简单</option><option value="15">初级</option><option value="25">困难</option><option value="38">变态难</option></select></div><input id="startMazeBtn" type="button" onclick="makeMaze()" value="开始" /></div>
        <div id="view">
            <div id="mazeContainer"><canvas id="mazeCanvas" class="border" height="800" width="1100"></canvas></div>
        </div>
    </div>
    <script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/jquery-3.2.1.min.js"></script>
    <script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/jquery.touchSwipe.js"></script>




    <script>
        function rand(max) {
  return Math.floor(Math.random() * max);
}

function shuffle(a) {
  for (let i = a.length - 1; i > 0; i--) {
    const j = Math.floor(Math.random() * (i + 1));
    [a[i], a[j]] = [a[j], a[i]];
  }
  return a;
}

function changeBrightness(factor, sprite) {
  var virtCanvas = document.createElement("canvas");
  virtCanvas.width = 500;
  virtCanvas.height = 500;
  var context = virtCanvas.getContext("2d");
  context.drawImage(sprite, 0, 0, 500, 500);

  var imgData = context.getImageData(0, 0, 500, 500);

  for (let i = 0; i < imgData.data.length; i += 4) {
    imgData.data[i] = imgData.data[i] * factor;
    imgData.data[i + 1] = imgData.data[i + 1] * factor;
    imgData.data[i + 2] = imgData.data[i + 2] * factor;
  }
  context.putImageData(imgData, 0, 0);

  var spriteOutput = new Image();
  spriteOutput.src = virtCanvas.toDataURL();
  virtCanvas.remove();
  return spriteOutput;
}

function displayVictoryMess(moves) {
  document.getElementById("moves").innerHTML = "You Moved " + moves + " Steps.";
  toggleVisablity("Message-Container");  
}

function toggleVisablity(id) {
  if (document.getElementById(id).style.visibility == "visible") {
    document.getElementById(id).style.visibility = "hidden";
  } else {
    document.getElementById(id).style.visibility = "visible";
  }
}

function Maze(Width, Height) {
  var mazeMap;
  var width = Width;
  var height = Height;
  var startCoord, endCoord;
  var dirs = ["n", "s", "e", "w"];
  var modDir = {
    n: {
      y: -1,
      x: .........完整代码请登录后点击上方下载按钮下载查看

网友评论0