From 61017d10d8ec045883e0a80bc12388390c16f95f Mon Sep 17 00:00:00 2001 From: Adam Frisby Date: Wed, 1 Aug 2007 21:46:48 +0000 Subject: * F32 Terrain load function written to support loading tiles from a larger heightmap. --- .../Region/Terrain.BasicTerrain/TerrainEngine.cs | 42 ++++++++++++++++++++++ 1 file changed, 42 insertions(+) (limited to 'OpenSim/Region/Terrain.BasicTerrain') diff --git a/OpenSim/Region/Terrain.BasicTerrain/TerrainEngine.cs b/OpenSim/Region/Terrain.BasicTerrain/TerrainEngine.cs index b54f4fe..bfb4941 100644 --- a/OpenSim/Region/Terrain.BasicTerrain/TerrainEngine.cs +++ b/OpenSim/Region/Terrain.BasicTerrain/TerrainEngine.cs @@ -578,6 +578,48 @@ namespace OpenSim.Region.Terrain } /// + /// Loads a section of a larger heightmap (F32) + /// + /// File to load + /// Size of the file + /// Size of the file + /// Where do the region coords start for this terrain? + /// Where do the region coords start for this terrain? + public void LoadFromFileF32(string filename, int dimensionX, int dimensionY, int lowerboundX, int lowerboundY) + { + int sectionToLoadX = ((this.offsetX - lowerboundX) * this.w); + int sectionToLoadY = ((this.offsetY - lowerboundY) * this.h); + + double[,] tempMap = new double[dimensionX, dimensionY]; + + FileInfo file = new FileInfo(filename); + FileStream s = file.Open(FileMode.Open, FileAccess.Read); + BinaryReader bs = new BinaryReader(s); + + int x, y; + for (x = 0; x < dimensionX; x++) + { + for (y = 0; y < dimensionY; y++) + { + tempMap[x,y] = (double)bs.ReadSingle(); + } + } + + for (x = 0; x < w; x++) + { + for (y = 0; y < h; y++) + { + heightmap.Set(x, y, tempMap[x + sectionToLoadX, y + sectionToLoadY]); + } + } + + bs.Close(); + s.Close(); + + tainted++; + } + + /// /// Loads a file formatted in the SL .RAW Format used on the main grid /// /// This file format stinks and is best avoided. -- cgit v1.1