2017-07-15 3 views
0

Ich habe Javascript-Code erstellt, der ein Quadrat auf dem Bildschirm zeichnet und es ständig nach oben animiert. Ich möchte, dass das Quadrat in der Mitte des Bildschirms bleibt, während die Welt (Leinwand) sich nach unten bewegt und die Illusion erzeugt, dass sich das Quadrat unendlich nach oben bewegt. Das Problem ist, ich habe keine Ahnung, wie dies zu tun wäre, jede Hilfe würde sehr geschätzt werden!Wie man das Ansichtsfenster dem Rect in diesem Javascript-Code folgen lässt?

My-Code

var canvas = document.getElementById("myCanvas"); 
 
var ctx = canvas.getContext("2d"); 
 
var rectWidth = 50; 
 
var rectHeight = 50; 
 
var rectRad = 25; 
 
var x = (canvas.width/2)-rectRad; 
 
var y = canvas.height-rectHeight; 
 
var dx = 2; 
 
var dy = 4; 
 
var ch = canvas.height; 
 

 
function rect() { 
 
\t ctx.beginPath(); 
 
\t ctx.rect(x, y, rectWidth, rectHeight); 
 
\t ctx.fillStyle = "#0095DD"; 
 
\t ctx.fill(); 
 
\t ctx.closePath(); 
 
} 
 

 
function draw() { 
 
\t ctx.clearRect(0, 0, canvas.width, canvas.height); 
 
\t rect(); 
 

 
\t if(y + dy < 0) { 
 
\t \t ch += 4; 
 
\t } 
 

 
\t if(y + dy > canvas.height-rectHeight) { 
 
\t \t dy = -dy; 
 
\t } 
 

 
\t y += dy; 
 
} 
 
setInterval(draw, 10);
* { padding: 0; margin: 0; } 
 
\t \t canvas { background: #eee; display: block; margin: 0 auto; }
<!DOCTYPE html> 
 

 
<html> 
 

 
<head> 
 
\t <meta charset="utf-8" /> 
 
\t <title>Game</title> 
 
\t 
 
\t <style> 
 
\t \t * { padding: 0; margin: 0; } 
 
\t \t canvas { background: #eee; display: block; margin: 0 auto; } 
 
\t </style> 
 

 
</head> 
 
<body> 
 

 
<canvas id="myCanvas" width="480" height="320"></canvas> 
 

 
<script src="gameJS.js"></script> 
 

 
</body> 
 

 
</html>

Antwort

0

Sie müssen nur den desiged Hintergrund zeichnen und die Hintergründe y-Position von Ihrer der Geschwindigkeit, die Sie haben wollen, übersetzen.

Dies wird meist als Kamera bezeichnet. Die Kamera übernimmt die Übersetzung der x- und y-Positionen, während sich das Quadrat (oder die Spielereinheit) in der Mitte des Bildschirms befindet.

Sie müssen auch sicherstellen, dass Ihr Hintergrund (Bild, Farbe, Muster) immer durch das Ansichtsfenster sichtbar ist.

Ich gebe Ihnen eine Beispielkamera, die ich für ein Testspiel-Engine in Typoskript geschrieben, um die Koordinaten zu übersetzen.

/** 
* calculates the position offset for camera following 
*/ 
private static calculatePositionOffsetForCameraFollow(originalPosition: Vector2D, camera: Camera): Vector2D { 

    // first check if there is any following 
    let entity = camera.getFollowingEntity(); 

    // if no following is active, return the original position 
    if (!entity) return originalPosition; 

    // calculate the offset. the entity should be in the center of the screen 
    let canvasDim = CameraOffsetCalculator.getCanvasDimension(); 

    // calculate the center position for the entity and shift the other 
    // vectors. 
    let tmpVector = originalPosition.substract(entity.getPosition()).add(
     canvasDim.divide(new Vector2D(2, 2)) 
    ); 

    // now check if the camera has world bounds 
    let worldBounds = camera.getWorldBounds(); 
    if (!worldBounds) return tmpVector; 

    // check if the original vector is smaller than the shifted vector 
    // this will bound the left and top world bounds 
    if (originalPosition.x < tmpVector.x) { 

     // reset the x axis to fix the camera 
     tmpVector.x = originalPosition.x; 
    } 

    if (originalPosition.y < tmpVector.y) { 

     // reset the y axis to fix the camera 
     tmpVector.y = originalPosition.y; 
    } 

    // now the left and bottom bounds 
    // we need the world dimension to check if the camera reaches 
    // the end of the world in the visible area 
    let entityPosition = entity.getPosition(); 
    let worldBoundCanvas = worldBounds.substract(canvasDim.half()); 

    if (entityPosition.x > worldBoundCanvas.x) { 

     // get the original position and substract 
     // the distance from world bounds and canvas dim 
     tmpVector.x = originalPosition.x - (worldBounds.x - canvasDim.x); 
    } 

    if (entityPosition.y > worldBoundCanvas.y) { 

     // get the original position and substract 
     // the distance from world bounds and canvas dim 
     tmpVector.y = originalPosition.y - (worldBounds.y - canvasDim.y); 
    } 

    // return the corrected position vector 
    return tmpVector; 
} 

Diese Funktion gibt einen neuen Punkt für das Hintergrundbild oder Fliesen auf, während im Anschluss an eine Entität (in Ihrem Fall des Quadrat) zu zeichnen.

Lassen Sie mich wissen, ob dies Ihnen geholfen hat! Hier

ist die Illusion im Code integriert mit einer sehr vereinfachten Kamera:

var canvas = document.getElementById("myCanvas"); 
    var ctx = canvas.getContext("2d"); 
    var rectWidth = 50; 
    var rectHeight = 50; 
    var rectRad = 25; 
    var x = (canvas.width/2) - rectRad; 
    var y = (canvas.height/2) - rectHeight; 
    //var dx = 2; 
    //var dy = 4; 
    var ch = canvas.height; 

    // should be lower than bgHeight 
    var scrollSpeed = .0475; 

    // a boolean to make the background shifts differently at 
    // y position to make the user think the player entity is moving 
    // forwards 
    var scroller = 0; 

    // the repeating background 
    var bg = ""; 
    var bgBitmap = createImageBitmap(b64ToBlob(bg, "image/png")); 

    function rect() { 
     ctx.beginPath(); 
     ctx.rect(x, y, rectWidth, rectHeight); 
     ctx.fillStyle = "#0095DD"; 
     ctx.fill(); 
     ctx.closePath(); 
    } 

    function draw() { 
     ctx.clearRect(0, 0, canvas.width, canvas.height); 

     // first draw the background 
     drawBackground(); 

     // and now the rectangle 
     rect(); 
    } 

    function drawBackground() { 

     var bgWidth = 14, bgHeight = 14; 

     // draw the full visible screen and on each edge, draw another tile 
     // to make a smooth scrolling 
     for (var x = -1; x < canvas.width/bgWidth; x++) { 
      for (var y = -1; y < canvas.height/bgHeight; y++) { 

       var yCorrectedCoordinate = y + (scroller * scrollSpeed); 

       // draw! 
       ctx.drawImage(
        bgBitmap, x * bgWidth, yCorrectedCoordinate * bgHeight, 
        bgWidth, bgHeight 
       ); 
      } 
     } 

     // change the scroller offset 
     scroller++; 
     if (scroller > 20) 
      scroller = 0; 
    } 

    /** 
    * converts a base64 string to a blob image capable for using in canvas environment 
    * @see https://stackoverflow.com/questions/16245767/creating-a-blob-from-a-base64-string-in-javascript 
    */ 
    function b64ToBlob(b64Data, contentType, sliceSize) { 

     contentType = contentType || ''; 
     sliceSize = sliceSize || 512; 

     var byteCharacters = atob(b64Data.split(',')[1]); 
     var byteArrays = []; 

     for (var offset = 0; offset < byteCharacters.length; offset += sliceSize) { 
      var slice = byteCharacters.slice(offset, offset + sliceSize); 

      var byteNumbers = new Array(slice.length); 
      for (var i = 0; i < slice.length; i++) { 
       byteNumbers[i] = slice.charCodeAt(i); 
      } 

      var byteArray = new Uint8Array(byteNumbers); 

      byteArrays.push(byteArray); 
     } 

     var blob = new Blob(byteArrays, { type: contentType }); 
     return blob; 
    } 

    // start the game loop after the image has beed loaded 
    bgBitmap.then(function (bg) { 

     bgBitmap = bg; 
     setInterval(draw, 10); 
    }); 

    // i would recommend to use window.requestAnimationFrame() instead 

Wenn es andere Fragen über die Entwicklung von Spielen sind, hier mein Repository ist: qhun-engine at Github.com

+0

ich irgendwie verstehen, konnte aber Du schreibst das in meinen Code für mich, damit ich es vollständig verstehen kann? Entschuldigung, ich bin neu in diesem –

+0

Ich mache es später heute oder morgen! – Wartoshika

+0

Ok, danke Kumpel! –

Verwandte Themen