游戏结束

时间:2018-09-12 19:53:53

标签: javascript function return

我正在写游戏。当满足条件(玩家寿命<1)时,游戏应停止。整个游戏都在singlePlayer功能中。问题是,我不知道如何结束此功能。在singlePlayer函数中放置简单条件是行不通的,因为在开始游戏时只检查了一次。

if (playerlife < 1) {
 return;
}

我也尝试过间隔放置此条件,并检查条件是否连续满足,但我无法正常工作,而且看起来也不是一个好主意。

下面是代码的一部分,在移动播放器后,需要检查一些条件。游戏类似于守旧派《青蛙》。当玩家跳入水中时,他失去了1条生命。失去3条生命后,游戏应该结束了。

$(function() {
function singlePlayer() {

  checkPosition(x, y) {
    for (var i = 0; i < raftsTab.length; i++) {
      if (x == raftsTab[i].PosX && y == raftsTab[i].PosY) {
        let thisRaft = raftsTab[i];
        console.log(x, y);
        console.log(thisRaft);
        clearInterval(MoveToPlayer);
        movePlayer(thisRaft);
        return;
      }
    }

    for (var i = 0; i < raftsTab.length; i++) {
      if (x !== raftsTab[i].PosX && y !== raftsTab[i].PosY && y !== 0 && y !== 5 && y !== 10) {
        player1.lifes = player1.lifes - 1;
        //player dead after loosing 3 lives - it would be perfect if game could be ended from here
        $('.lifes').text("Player lifes: " + player1.lifes);

        for (var i = 0; i < trophiesTab.length; i++) {
          if (player1.trophie - 1 == i) {
            trophiesTab[i].show();
            player1.trophie = -1;
          }
        }
        player1.PosX = 5;
        player1.PosY = 10;
        clearInterval(MoveToPlayer);
        changePosition();
        return;
      }
    }

    for (var i = 0; i < trophiesTab.length; i++) {
      if (x == trophiesTab[i].PosX && y == trophiesTab[i].PosY && player1.trophie == -1) {
        trophiesTab[i].hide();
      }
    }

    if (x == 5 && y == 0 && player1.trophie !== -1) {
      tresure1 = tresure1 + player1.trophie;
      player1.items = player1.items + 1;
      $('.items').text("Gathered items: " + player1.items + "/3");
      player1.trophie = -1;
      console.log(tresure1);
    }
    clearInterval(MoveToPlayer);
  }
}
});

0 个答案:

没有答案