Heightmap: Unterschied zwischen den Versionen
Aus DGL Wiki
Wilson (Diskussion | Beiträge) K (Ressourcenliste durch Kommas getrennt) |
K (Orthografie, Kleinigkeiten) |
||
Zeile 1: | Zeile 1: | ||
==Konzept== | ==Konzept== | ||
− | Eine Heightmap ist ein 2-dimensionales Array, | + | Eine Heightmap ist ein 2-dimensionales Array, das Informationen über eine Landschaft enthält. Dazu wird an jedem Knoten der entsprechende Höhenwert gespeichert. Zum Beispiel eine zufällige Landschaft: |
<pascal> | <pascal> | ||
var | var | ||
Zeile 15: | Zeile 15: | ||
==Bewertung== | ==Bewertung== | ||
Der Vorteil von Heightmaps ist, dass sie sehr leicht zu implementieren sind. Ein Nachteil ist jedoch, dass immer nur ein Höhenwert pro Knoten gespeichert werden kann und man so keine Felsvorsprünge oder Höhlen realisieren kann. | Der Vorteil von Heightmaps ist, dass sie sehr leicht zu implementieren sind. Ein Nachteil ist jedoch, dass immer nur ein Höhenwert pro Knoten gespeichert werden kann und man so keine Felsvorsprünge oder Höhlen realisieren kann. | ||
− | Eine interessante Möglichkeit ist, Heightmaps mit Algorithmen wie [[Perlin Noise]] zur Laufzeit zur erstellen. Desweiteren kann man [[LOD]] benutzen um das Rendern von Heightmaps zu beschleunigen. | + | Eine interessante Möglichkeit ist, um Speicher oder Plattenplatz zu sparen, Heightmaps mit Algorithmen wie [[Perlin Noise]] oder den [[Hügel_Algorithmen|Hügel Algorithmus]] zur Laufzeit zur erstellen. Desweiteren kann man [[LOD]] benutzen um das Rendern von Heightmaps zu beschleunigen. |
==Ressourcen== | ==Ressourcen== | ||
[[Tutorial Terrain1]], [[Tutorial Terrain2]], [[Tutorial Terrain3]] | [[Tutorial Terrain1]], [[Tutorial Terrain2]], [[Tutorial Terrain3]] |
Version vom 9. September 2008, 07:21 Uhr
Konzept
Eine Heightmap ist ein 2-dimensionales Array, das Informationen über eine Landschaft enthält. Dazu wird an jedem Knoten der entsprechende Höhenwert gespeichert. Zum Beispiel eine zufällige Landschaft:
var i,j: integer; heightmap: array[0..width, 0..depth] of single; begin for i := 0 to width do for j := 0 to depth do heightmap[i,j] := PerlinNoise2D(i,j, octaves, persistence); end;
Es kann auch aus einem Graustufenbitmap geladen werden, z.B. je heller ein Punkt, desto höher die Landschaft an dieser Stelle |
Bewertung
Der Vorteil von Heightmaps ist, dass sie sehr leicht zu implementieren sind. Ein Nachteil ist jedoch, dass immer nur ein Höhenwert pro Knoten gespeichert werden kann und man so keine Felsvorsprünge oder Höhlen realisieren kann. Eine interessante Möglichkeit ist, um Speicher oder Plattenplatz zu sparen, Heightmaps mit Algorithmen wie Perlin Noise oder den Hügel Algorithmus zur Laufzeit zur erstellen. Desweiteren kann man LOD benutzen um das Rendern von Heightmaps zu beschleunigen.