mardi 17 janvier 2017

Tic-Tac-Toe Opponent doesn't work

Well, I used events for my tic-tac-toe game, and now it works better. However, now the opponent (which is based on an array and selecting a random value) doesn't work correctly. Whenever something is selected, it is removed from the array. How do I fix this?

<html>
<head>
<title>Canvas</title>
</head>
<body>
      <canvas id="canvas" width="300" height="300"></canvas>
      <script src="http://ift.tt/1Gz3Xjq"></script>
      <script>
      //Setup
      //defines canvas
      var canvas = document.getElementById("canvas");
      var ctx = canvas.getContext("2d");
      //defines various functions
  function getRandomFromInterval(interval) {
    return(Math.floor(Math.random() * interval));
  };
  function getRandomFromArray(array) {
    return(array[getRandomFromInterval(array.length)])
  };
  function isNumberBetween(number, low, high) {
    return(number >= low && number <= high);
  };
  function removeFromArray(array, value) {
    var helper = array.indexOf(value)
    if (helper != -1) {
      array.splice(helper, helper);
    };
    return(helper);
  };
  function circle (x, y, radius, color, filled) {
    ctx.beginPath();
    ctx.arc(x, y, radius, 0, Math.PI * 2, false);
    if (filled === true) {
      ctx.fillStyle = color;
      ctx.fill()
    } else {
      ctx.strokeStyle = color;
      ctx.stroke();
    };
  };
  //defines the spot object constructor
  function Spot(x, y, cloneID, type) {
    this.x = x,
    this.y = y,
    this.cloneID = cloneID,
    this.type = type
  };
  //defines the spot object drawing functions for drawing X and O
  Spot.prototype.drawX = function () {
    ctx.lineWidth = 4;
    ctx.beginPath();
    ctx.moveTo(this.x - 30, this.y - 30);
    ctx.lineTo(this.x + 30, this.y + 30);
    ctx.moveTo(this.x - 30, this.y + 30);
    ctx.lineTo(this.x + 30, this.y - 30);
    ctx.stroke();
  };
  Spot.prototype.drawCircle = function () {
    ctx.lineWidth = 4;
    circle(this.x, this.y, 30, "Black", false);
  };
  //defines several variables used in these functions
  var playerValidity = true;
  var availableSpots = [1, 2, 3, 4, 5, 6, 7, 8, 9];
  //defines the spots and other variables
  var spot1 = new Spot(50, 50, 1, "");
  var spot2 = new Spot(150, 50, 2, "");
  var spot3 = new Spot(250, 50, 3, "");
  var spot4 = new Spot(50, 150, 4, "");
  var spot5 = new Spot(150, 150, 5, "");
  var spot6 = new Spot(250, 150, 6, "");
  var spot7 = new Spot(50, 250, 7, "");
  var spot8 = new Spot(150, 250, 8, "");
  var spot9 = new Spot(250, 250, 9, "");
  //defines the opponent's turn (WIP)
  function opponentTurn () {
    if (playerValidity === true) {
    var opponentChoice = getRandomFromArray(availableSpots);
    if (opponentChoice === 1) {
      removeFromArray(availableSpots, 1)
      if (opponentSymbol === "X") {
        spot1.drawX();
        spot1.type = "X"
      } else {
        spot1.drawCircle();
        spot1.type = "O"
      };
      currentTurn = "player"
    } else if (opponentChoice === 2) {
      removeFromArray(availableSpots, 2)
      if (opponentSymbol === "X") {
      spot2.drawX();
      spot2.type = "X"
    } else {
      spot2.type = "O"
    };
    };
    currentTurn = "player"
  } else if (opponentChoice === 3) {
    removeFromArray(availableSpots, 3)
      if (opponentSymbol === "X") {
      spot3.drawX();
      spot3.type = "X"
    } else {
      spot3.drawCircle();
    };
    currentTurn = "player"
  } else if (opponentChoice === 4) {
      removeFromArray(availableSpots, 4)
      if (opponentSymbol === "X") {
      spot4.drawX();
      spot4.type = "X"
    } else {
      spot4.drawCircle();
      spot4.type = "O"
    };
    currentTurn = "player"
  } else if (opponentChoice === 5) {
      removeFromArray(availableSpots, 5)
      if (opponentSymbol === "X") {
      spot5.drawX();
      spot5.type = "X"
    } else {
      spot5.drawCircle();
      spot5.type = "O"
    };
    currentTurn = "player"
  } else if (opponentChoice === 6) {
      removeFromArray(availableSpots, 6)
      if (opponentSymbol === "X") {
      spot6.drawX();
      spot6.type = "X"
    } else {
      spot6.drawCircle();
      spot6.type = "O"
    };
    currentTurn = "player"
  } else if (opponentChoice === 7) {
    removeFromArray(availableSpots, 7)
      if (opponentSymbol === "X") {
      spot7.drawX();
      spot7.type = "X"
    } else {
      spot7.drawCircle();
      spot7.type = "O"
    };
    currentTurn = "player"
  } else if (opponentChoice === 8) {
      removeFromArray(availableSpots, 8)
      if (opponentSymbol === "X") {
      spot8.drawX();
      spot8.type = "X"
    } else {
      spot8.drawCircle();
      spot8.type = "O"
    };
    currentTurn = "player"
  } else if (opponentChoice === 9 && spot9.type === "") {
      removeFromArray(availableSpots, 9)
        if (opponentSymbol === "X") {
        spot9.drawX();
        spot9.type = "X"
      } else {
        spot9.drawCircle();
        spot9.type = "O"
      };
      //switches to player's turn
      currentTurn = "player"
    };
  };
  //decides the first player
  function decideFirst () {
    if (getRandomFromInterval(2) === 1) {
      currentTurn = "player";
      playerSymbol = "X";
      opponentSymbol = "O";
      alert("The player is going first!");
    } else {
      currentTurn = "opponent"
      playerSymbol = "O"
      opponentSymbol = "X"
      alert("The opponent is going first!");
      opponentTurn();
    };
  };
  //draws the grid
  ctx.lineWidth = 4;
  ctx.beginPath();
  ctx.moveTo(0, 100);
  ctx.lineTo(300, 100);
  ctx.moveTo(0, 200);
  ctx.lineTo(300, 200);
  ctx.moveTo(100, 0);
  ctx.lineTo(100, 300);
  ctx.moveTo(200, 0);
  ctx.lineTo(200, 300);
  ctx.stroke();
  var currentTurn = "";
  var playerSymbol = "";
  var opponentSymbol = "";
  setTimeout(decideFirst, 100)
  //Game
  //executes a player turn if the canvas is clicked
    $("canvas").click(function (event) {
      playerValidity = false;
      if (currentTurn === "player") {
      if (isNumberBetween(event.pageX, 0, 100) && isNumberBetween(event.pageY, 0, 100) && spot1.type === "") {
        removeFromArray(availableSpots, 1)
        spot1.type = playerSymbol;
        if (playerSymbol === "X") {
          spot1.drawX();
          spot1.type = "X"
        } else {
          spot1.drawCircle();
          spot1.type = "O"
        };
        playerValidity = true;
        currentTurn = "opponent";
        opponentTurn();
      } else if (isNumberBetween(event.pageX, 100, 200) && isNumberBetween(event.pageY, 0, 100) && spot2.type === "") {
        removeFromArray(availableSpots, 2)
        spot2.type = playerSymbol;
        if (playerSymbol === "X") {
          spot2.drawX();
          spot2.type = "X"
        } else {
          spot2.drawCircle();
          spot2.type = "O"
        };
        playerValidity = true;
        currentTurn = "opponent";
        opponentTurn();
      } else if (isNumberBetween(event.pageX, 200, 300) && isNumberBetween(event.pageY, 0, 100) && spot3.type === "") {
        removeFromArray(availableSpots, 3)
        spot3.type = playerSymbol;
        if (playerSymbol === "X") {
          spot3.drawX();
          spot3.type = "X"
        } else {
          spot3.drawCircle();
          spot3.type = "O"
        };
        playerValidity = true;
        currentTurn = "opponent";
        opponentTurn();
      } else if (isNumberBetween(event.pageX, 0, 100) && isNumberBetween(event.pageY, 100, 200) && spot4.type === "") {
        removeFromArray(availableSpots, 4)
        spot4.type = playerSymbol;
        if (playerSymbol === "X") {
          spot4.drawX();
          spot4.type = "X"
        } else {
          spot4.drawCircle();
          spot4.type = "O"
        };
        playerValidity = true;
        currentTurn = "opponent";
        opponentTurn();
      } else if (isNumberBetween(event.pageX, 100, 200) && isNumberBetween(event.pageY, 100, 200) && spot5.type === "") {
        removeFromArray(availableSpots, 5)
        spot5.type = playerSymbol;
        if (playerSymbol === "X") {
          spot5.drawX();
          spot5.type = "X"
        } else {
          spot5.drawCircle();
          spot5.type = "O"
        };
        playerValidity = true;
        currentTurn = "opponent";
        opponentTurn();
      } else if (isNumberBetween(event.pageX, 200, 300) && isNumberBetween(event.pageY, 100, 200) && spot6.type === "") {
        removeFromArray(availableSpots, 6)
        spot6.type = playerSymbol;
        if (playerSymbol === "X") {
          spot6.drawX();
          spot6.type = "X"
        } else {
          spot6.drawCircle();
          spot6.type = "O"
        };
        playerValidity = true;
        currentTurn = "opponent";
        opponentTurn();
      } else if (isNumberBetween(event.pageX, 0, 100) && isNumberBetween(event.pageY, 200, 300) && spot7.type === "") {
        removeFromArray(availableSpots, 7)
        spot7.type = playerSymbol;
        if (playerSymbol === "X") {
          spot7.drawX();
          spot7.type = "X"
        } else {
          spot7.drawCircle();
          spot7.type = "O"
        };
        playerValidity = true;
        currentTurn = "opponent";
        opponentTurn();
      } else if (isNumberBetween(event.pageX, 100, 200) && isNumberBetween(event.pageY, 200, 300) && spot8.type === "") {
        removeFromArray(availableSpots, 8)
        spot8.type = playerSymbol;
        if (playerSymbol === "X") {
          spot8.drawX();
          spot8.type = "X"
        } else {
          spot8.drawCircle();
          spot8.type = "O"
        };
        playerValidity = true;
        currentTurn = "opponent";
        opponentTurn();
      } else if (isNumberBetween(event.pageX, 200, 300) && isNumberBetween(event.pageY, 200, 300) && spot9.type === "") {
        removeFromArray(availableSpots, 9)
        spot9.type = playerSymbol;
        if (playerSymbol === "X") {
          spot9.drawX();
          spot9.type = "X"
        } else {
          spot9.drawCircle();
          spot9.type = "O"
        };
        playerValidity = true;
        currentTurn = "opponent";
        setTimeout(opponentTurn, 100);
      };
    };
});
</script>
</body>
</html>




Aucun commentaire:

Enregistrer un commentaire