Heightmap: Unterschied zwischen den Versionen

Aus DGL Wiki
Wechseln zu: Navigation, Suche
K (Ressourcenliste durch Kommas getrennt)
Zeile 18: Zeile 18:
  
 
==Ressourcen==
 
==Ressourcen==
[[Tutorial Terrain1]]
+
[[Tutorial Terrain1]], [[Tutorial Terrain2]], [[Tutorial Terrain3]]
[[Tutorial Terrain2]]
 
[[Tutorial Terrain3]]
 

Version vom 5. September 2008, 20:30 Uhr

Konzept

Eine Heightmap ist ein 2-dimensionales Array, dass Informationen über eine Landschaft enthält. Dazu wird einfach 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;
Info DGL.png 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, Heightmaps mit Algorithmen wie Perlin Noise zur Laufzeit zur erstellen. Desweiteren kann man LOD benutzen um das Rendern von Heightmaps zu beschleunigen.

Ressourcen

Tutorial Terrain1, Tutorial Terrain2, Tutorial Terrain3