gpt4 book ai didi

javascript - 按下右/下箭头按钮时出现未知错误

转载 作者:行者123 更新时间:2023-12-02 18:53:58 25 4
gpt4 key购买 nike

首先大家好:-]
我的项目有问题 - HTML5 Canvas 中的游戏。我不会告诉你必须做什么,但我的 Action 有未知的问题。

index.html{

<!DOCTYPE HTML>
<html>
<head>
<title>StickySquares</title>
<script src="scripts/main.js"></script>
<style>
#gameArea{
background-image: url('images/bkg.jpg');
}
</style>
</head>
<body onload="init();">
<div id="fastimages" hidden="hidden">
<img id="bodyIMG" src="images/body.png" />
<img id="wallIMG" src="images/wall.png" />
</div>
<canvas id="gameArea" width="640" height="480">
ERROR... Update your browser!
</canvas>
<div id="debug"></div>
</body>
</html>

}

main.js{

var myCanvas, keyPressed = true;
var sprBody, sprWall;
var map = [];
var figures = [];
var debugtxt;
function unpressKey(){
keyPressed = false;
}
function debugText(){
debugtxt = document.getElementById("debug");
var text = "";
for(var y=0;y<15;y+=1){
for(var x=0;x<20;x+=1){
text += map[y][x].toString();
}
text += "<br />";
}
debugtxt.innerHTML = text;
}
function playerUpdate(button){
// 37 - left, 38 - up, 39 - right, 40 - down
if(!keyPressed){
for(var y=0;y<15;y+=1){
for(var x=0;x<20;x+=1){
if(map[y][x]==2){
switch(button.keyCode){
case 37: // Left
if(map[y][x-1]==0){
map[y][x]=0;
map[y][x-1]=2;
}
break;
case 38: // Up
if(map[y-1][x]==0){
map[y][x]=0;
map[y-1][x]=2;
}
break;
case 39: // Right
if(map[y][x+1]==0){
map[y][x]=0;
map[y][x+1]=2;
}
break;
case 40: // Down
if(map[y+1][x]==0){
map[y][x]=0;
map[y+1][x]=2;
}
break;
}
}
}
}
}
debugText();
}
function draw(){
myCanvas.clearRect(0, 0, 640, 480);

for(var y=0;y<15;y+=1){
for(var x=0;x<20;x+=1){
if(map[y][x]==1){
myCanvas.drawImage(sprWall, x*32, y*32);
}else{
if(map[y][x]==2 || map[y][x]==3){
myCanvas.drawImage(sprBody, x*32, y*32);
}
}
}
}
}
function init(){
myCanvas = document.getElementById("gameArea").getContext("2d");
sprBody = document.getElementById("bodyIMG");
sprWall = document.getElementById("wallIMG");
for(var firstIndex=0;firstIndex<15;firstIndex+=1){
map[firstIndex] = [];
figures[firstIndex] = [];
for(var secondIndex=0;secondIndex<20;secondIndex+=1){
map[firstIndex][secondIndex] = 0;
figures[firstIndex][secondIndex] = [];
}
}
for(var x=0;x<20;x+=1){
map[0][x] = 1;
map[14][x] = 1;
}
for(var y=0;y<15;y+=1){
map[y][0] = 1;
map[y][19] = 1;
}
map[2][2] = 3;
map[7][9] = 2;

window.addEventListener("keyup", playerUpdate, false);
window.addEventListener("keydown", unpressKey, false);

setInterval(draw, 1000 / 60);
}

}

当我测试我的游戏时,当我按下向右和向下箭头键时,方 block 不会随着+1移动,它会移向右侧的墙壁或向下的墙壁...
我正在查看我的代码,但我不明白为什么广场会犯这个错误......
有人可以告诉我我做错了什么吗? :)

编辑:我使用二维数组作为 map :
1 = 墙,2 = 可以移动的方 block ,0 = 自由空间(可以移动的地方),3 - 不能移动的方 block ,但当您靠近时可以激活它。

最佳答案

这取决于您处理按键的方式。现在它只能接受一个,它将覆盖之前的键是什么,这就是为什么你目前只能朝一个方向走。这就是我喜欢的方式。

var keys=[];

document.body.addEventListener("keydown", function (e) {
keys[e.keyCode] = true;
});
document.body.addEventListener("keyup", function (e) {
keys[e.keyCode] = false;
});

function updatePlayer(){
if (keys[38]) {
//up
}

if (keys[40]) {
//down
}

if (keys[39]) {
//right
}

if (keys[37]) {
//left
}
}

<强> Live Example Demonstrating This

它的作用是每次按下一个键时,您都会在数组中设置一个元素,该元素的索引号与它们的键代码为 true 相同。当您停止按下该键时,其设置为 false。然后你可以检查你通常处理玩家移动的位置。这允许您按下几乎无限数量的按键。

关于javascript - 按下右/下箭头按钮时出现未知错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15578824/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com