2017-10-10 12 views
0

私はJavaScriptのゲームを作ろうとしていて、オンラインでコードをいくつか持っています。私が望むものにそれを改良しようとしています。したがって、スコアが1000になった後に間隔を広げたいと思います。私のコードを洗練させてください。 start関数は、gamearea関数で20ミリ秒の間隔をとります。私はスコアが1000に到達したとき、その後、私はupdateGame機能あなたが明示的に古い区間の走行を停止し、新しいものを開始する必要がありスコアが1000になったら、開始機能の間隔をどのように増やしますか?

function startGame() { 
    myGameArea = new gamearea(); 
    myGamePiece = new component(30, 30, "red", 10, 75); 
    myscore = new component("15px", "Consolas", "black", 220, 25, "text"); 
    myGameArea.start(); 
} 

function gamearea() { 
    this.canvas = document.createElement("canvas"); 
    this.canvas.width = 320; 
    this.canvas.height = 180;  
    document.getElementById("canvascontainer").appendChild(this.canvas); 
    this.context = this.canvas.getContext("2d"); 
    this.pause = false; 
    this.frameNo = 0; 
    this.start = function() { 
     this.interval = setInterval(updateGameArea, 20); 
    } 
    this.stop = function() { 
     clearInterval(this.interval); 
     this.pause = true; 
    } 
    this.clear = function(){ 
     this.context.clearRect(0, 0, this.canvas.width, this.canvas.height); 
    } 
} 

function component(width, height, color, x, y, type) { 

    this.type = type; 
    if (type == "text") { 
     this.text = color; 
    } 
    this.score = 0; this.width = width; 
    this.height = height; 
    this.speedX = 0; 
    this.speedY = 0;  
    this.x = x; 
    this.y = y;  
    this.update = function() { 
     ctx = myGameArea.context; 
     if (this.type == "text") { 
      ctx.font = this.width + " " + this.height; 
      ctx.fillStyle = color; 
      ctx.fillText(this.text, this.x, this.y); 
     } else { 
      ctx.fillStyle = color; 
      ctx.fillRect(this.x, this.y, this.width, this.height); 
     } 
    } 
    this.crashWith = function(otherobj) { 
     var myleft = this.x; 
     var myright = this.x + (this.width); 
     var mytop = this.y; 
     var mybottom = this.y + (this.height); 
     var otherleft = otherobj.x; 
     var otherright = otherobj.x + (otherobj.width); 
     var othertop = otherobj.y; 
     var otherbottom = otherobj.y + (otherobj.height); 
     var crash = true; 
     if ((mybottom < othertop) || (mytop > otherbottom) || (myright < otherleft) || (myleft > otherright)) { 
      crash = false; 
     } 
     return crash; 
    } 
} 

function updateGameArea() { 
    var x, y, min, max, height, gap; 
    for (i = 0; i < myObstacles.length; i += 1) { 
     if (myGamePiece.crashWith(myObstacles[i])) { 
      myGameArea.stop(); 
      document.getElementById("myfilter").style.display = "block"; 
      document.getElementById("myrestartbutton").style.display = "block"; 
      return; 
     } 
    } 
    if (myGameArea.pause == false) { 
     myGameArea.clear(); 
     myGameArea.frameNo += 1; 
     myscore.score +=1;   
     if (myGameArea.frameNo == 1 || everyinterval(150)) { 
      x = myGameArea.canvas.width; 
      y = myGameArea.canvas.height - 100; 
      min = 20; 
      max = 100; 
      height = Math.floor(Math.random()*(max-min+1)+min); 
      min = 50; 
      max = 100; 
      gap = Math.floor(Math.random()*(max-min+1)+min); 
      myObstacles.push(new component(10, height, "green", x, 0)); 
      myObstacles.push(new component(10, x - height - gap, "green", x, height + gap)); 
     } 
     for (i = 0; i < myObstacles.length; i += 1) { 
      myObstacles[i].x += -1; 
      myObstacles[i].update(); 
     } 
     myscore.text="SCORE: " + myscore.score; 
     if (myscore.score == 1000){ 
      this.start = function() { 
       this.interval = setInterval(updateGameArea, 10); 
      } 
     } 

     myscore.update(); 
     myGamePiece.x += myGamePiece.speedX; 
     myGamePiece.y += myGamePiece.speedY;  
     myGamePiece.update(); 
    } 
} 


startGame(); 
+0

このコードはthis.interval = setInterval(updateGameArea、20);?はいの場合は、これを行うことができますthis.interval = setInterval(updateGameArea、this.interval + 10);以前の間隔値に10を追加する必要があります。 –

+0

ありがとう、しかし、私はまだゲームを再起動すると小さな問題がある、それはまだ新しい間隔を設定します – Pianistprogrammer

答えて

1

でそれをsettiingことにより、間隔を増やしたい、スコアのカウントを行います。

if (myscore.score == 1000){ 
     this.stop(); // Stop the old interval 
     // Start a new interval with the new timing 
     this.interval = setInterval(updateGameArea, 10); 
    } 
+0

私はこれを行い、間隔が変更されましたが、ゲームが停止して再起動する必要があるとき、新しい間隔と20のデフォルトではない場合(myscore.score == 1000){ myGameArea.interval = setInterval(updateGameArea、19); } else { myscore.update(); myGamePiece.x + = myGamePiece.speedX; myGamePiece.y + = myGamePiece.speedY; myGamePiece.update(); } – Pianistprogrammer

+0

this.stop()メソッドとthis.start()メソッドを使用して、例に表示されているようにすると、それは区間20に戻ります。それ以外の変更は、例? –

+0

私は変更を加えませんでしたが、window.location.reload()を使用して一時的な修正を行いました – Pianistprogrammer

関連する問題