Spieleentwicklung mit JavaScript - Scrollende Spielfelder
(Unterschied zwischen Versionen)
(→Ermittlung der Tiles-Größe) |
(→Canvas-Größe) |
||
Zeile 45: | Zeile 45: | ||
== Canvas-Größe == | == Canvas-Größe == | ||
- | Die Breite und Höhe des sichtbaren Bereichs kann im Canvas festgelegt werden. Leider muss sie direkt als width="xx" height="yy" im <canvas>-Element festgelegt werden. Wird eine Größe im Style für das Canvas definiert führt das zu einer Skalierung und nicht zu einer Erhöhung der Pixelanzahl. | + | Die Breite und Höhe des sichtbaren Bereichs kann im Canvas festgelegt werden. Leider muss sie direkt als width="xx" height="yy" im <canvas>-Element festgelegt werden. Wird eine Größe im Style für das Canvas definiert führt das zu einer Skalierung und nicht zu einer Erhöhung der Pixelanzahl. Deshalb ist es leider nicht möglich, die Pixel-Dimensionen eines Canvas über ein Stylesheet zu ändern. |
+ | |||
+ | Dennoch ist es sinnvoll, die Größe des Canvas aus den Angaben im canvas-Tag zu entnehmen: | ||
+ | |||
+ | <pre> | ||
+ | var display_pixel_width = 0; | ||
+ | var display_pixel_height = 0; | ||
+ | var display_tile_width = 0; | ||
+ | var display_tile_height = 0; | ||
+ | |||
+ | function init() | ||
+ | { | ||
+ | //... | ||
+ | display_pixel_width = canvas.width; | ||
+ | display_pixel_height = canvas.height; | ||
+ | display_tile_width = Math.floor( display_pixel_width / tile_pixel_width )+1; | ||
+ | display_tile_height = Math.floor( display_pixel_height / tile_pixel_height )+1; | ||
+ | //... | ||
+ | } | ||
+ | </pre> | ||
+ | |||
+ | == Spielfeld-Größe == | ||
+ | Die Größe des gesamten Spielfelds hängt von der Level-Definition und der Tile-Größe ab. Die Dimensionen des Arrays lassen sich mit | ||
+ | dem length-Attribut ermitteln. Wir gehen von der Annahme aus, dass alle Zeilen gleich lang sind und ermitteln nur die Länge der ersten | ||
+ | Zeile: | ||
+ | <pre> | ||
+ | var map_tile_width = 0; | ||
+ | var map_tile_height = 0; | ||
+ | var map_pixel_width = 0; | ||
+ | var map_pixel_height = 0; | ||
+ | |||
+ | var level = new Array( | ||
+ | new Array( 0,4,0,0,0,0 ), | ||
+ | new Array( 2,1,1,1,1,1 ), | ||
+ | new Array( 2,0,3,0,0,0 ), | ||
+ | new Array( 2,0,3,0,0,0 ), | ||
+ | new Array( 2,0,3,2,1,1 ) | ||
+ | ); | ||
+ | |||
+ | function init() | ||
+ | { | ||
+ | //.. | ||
+ | map_tile_width = level[0].length; | ||
+ | map_tile_height = level.length; | ||
+ | map_pixel_width = map_tile_width * tile_pixel_width; | ||
+ | map_pixel_height = map_tile_height * tile_pixel_height; | ||
+ | //.. | ||
+ | } | ||
+ | </pre> |
Version vom 11:47, 2. Sep. 2010
Inhaltsverzeichnis |
Scrollende Spielfelder
In vielen Spielen wie zum Beispiel Jump'n'Run- oder Strategiespielen wird nur ein Auschnitt des gesamten Spielfelds dargestellt. Der Spieler kann auf unterschiedliche Art und Weise durch das Spielfeld navigieren, wobei jeweils nur der aktuell sichtbare Bildschirmausschnitt gezeichnet wird.
Weil sich das Spielfeld aus Tiles zusammensetzt, deren Größe sich von Spiel zu Spiel ändern kann, ist eine indirekte Berechnung der Spielfeldgröße notwendig: Spielfeld-Breite = Anzahl der Tiles * Breite der Tiles. Spielfeld-Höhe = Anzahl der Tiles * Höhe der Tiles.
Es ist sinnvoll, die Größe und Position des sichtbaren Bildschirmausschnitts in Pixel anzugeben und nicht in Tiles. Das hat den Vorteil, dass ein "Softscrolling" möglich ist, also eine Bewegung des sichtbaren Ausschnitts um einzelne Pixel. Würde man nur die Tile-Position angeben, würde das Bild immer um die Größe eines ganzen Tiles springen und das würde wirklich nicht gut aussehen.
Allerdings muss auch berechnet werden, welche Tiles im sichtbaren Bereich gezeichnet werden müssen. Es sind also eine ganze Reihe von Größenangaben und Berechnungen notwendig. Damit der Algorithmus für das scrollende Spielfeld möglichst flexibel eingesetzt werden kann, werden wir soviele Werte wie möglich dynamisch errechnen. Das hat den Vorteil, dass später Änderungen und Anpassungen sehr einfach vorgenommen werden können. So könnte sich zum Beispiel die Größe der einzelnen Tiles ändern, die Kartengröße von Level zu Level variieren oder sich die Größe des sichtbaren Bildausschnitts an die Größe des Browserfensters anpassen.
Ermittlung der Tiles-Größe
Von folgendem Tileset können wir sagen, dass sich insgesamt 5 Tiles darin befinden. Wenn wir die Größe des Bildes kennen, können wir daraus leicht die Größe der einzelnen Tiles berechnen. Wenn man gleich vorsieht, dass die Tiles nicht unbedingt nebeneinander, sondern auch übereinander plaziert werden können, ist es lediglich notwendig, die Anzahl der Tiles jeweils in X- und Y-Richtung zu kennen:
var tile_count_x = 5; var tile_count_y = 1;
Die Breite und Höhe des Bildes, in der die Tiles enthalten sind, können wir dem Image-Objekt entnehmen und es ergibt sich folgende Berechnung:
var tile_pixel_width = 0; var tile_pixel_height = 0; function init() { // ... var tileset = document.getElementById("tileset"); tile_pixel_width = tileset.width / tile_count_x; tile_pixel_height = tileset.height / tile_count_y; // ... }
Alle weiteren Berechnungen beziehen sich auf die ermittelten Werte für tile_pixel_width und tile_pixel_height. So besteht die Möglichkeit, die Größe der Tiles nachträglich zu ändern, ohne eine einzige Änderung am Programm vornehmen zu müssen.
Canvas-Größe
Die Breite und Höhe des sichtbaren Bereichs kann im Canvas festgelegt werden. Leider muss sie direkt als width="xx" height="yy" im <canvas>-Element festgelegt werden. Wird eine Größe im Style für das Canvas definiert führt das zu einer Skalierung und nicht zu einer Erhöhung der Pixelanzahl. Deshalb ist es leider nicht möglich, die Pixel-Dimensionen eines Canvas über ein Stylesheet zu ändern.
Dennoch ist es sinnvoll, die Größe des Canvas aus den Angaben im canvas-Tag zu entnehmen:
var display_pixel_width = 0; var display_pixel_height = 0; var display_tile_width = 0; var display_tile_height = 0; function init() { //... display_pixel_width = canvas.width; display_pixel_height = canvas.height; display_tile_width = Math.floor( display_pixel_width / tile_pixel_width )+1; display_tile_height = Math.floor( display_pixel_height / tile_pixel_height )+1; //... }
Spielfeld-Größe
Die Größe des gesamten Spielfelds hängt von der Level-Definition und der Tile-Größe ab. Die Dimensionen des Arrays lassen sich mit dem length-Attribut ermitteln. Wir gehen von der Annahme aus, dass alle Zeilen gleich lang sind und ermitteln nur die Länge der ersten Zeile:
var map_tile_width = 0; var map_tile_height = 0; var map_pixel_width = 0; var map_pixel_height = 0; var level = new Array( new Array( 0,4,0,0,0,0 ), new Array( 2,1,1,1,1,1 ), new Array( 2,0,3,0,0,0 ), new Array( 2,0,3,0,0,0 ), new Array( 2,0,3,2,1,1 ) ); function init() { //.. map_tile_width = level[0].length; map_tile_height = level.length; map_pixel_width = map_tile_width * tile_pixel_width; map_pixel_height = map_tile_height * tile_pixel_height; //.. }