From 4eb8ca49a901b09ce4bc3130f76f53b910391bbc Mon Sep 17 00:00:00 2001
From: Adam Frisby
Date: Sat, 21 Jul 2007 22:20:22 +0000
Subject: * Renamed terrain functions to match OpenSim naming styles. * Added
capability to support minimum/maximum terrain limits (from the last 'bake')
---
.../Region/ClientStack/RegionApplicationBase.cs | 2 +-
OpenSim/Region/Environment/LandManagement/Land.cs | 4 +-
.../Environment/Scenes/Scene.PacketHandlers.cs | 12 +-
OpenSim/Region/Environment/Scenes/Scene.cs | 30 ++---
OpenSim/Region/Environment/Scenes/SceneBase.cs | 4 +-
OpenSim/Region/Examples/SimpleApp/MyWorld.cs | 2 +-
.../Region/Terrain.BasicTerrain/TerrainEngine.cs | 136 +++++++++++++--------
7 files changed, 113 insertions(+), 77 deletions(-)
diff --git a/OpenSim/Region/ClientStack/RegionApplicationBase.cs b/OpenSim/Region/ClientStack/RegionApplicationBase.cs
index 4a1fd99..1651ec2 100644
--- a/OpenSim/Region/ClientStack/RegionApplicationBase.cs
+++ b/OpenSim/Region/ClientStack/RegionApplicationBase.cs
@@ -113,7 +113,7 @@ namespace OpenSim.Region.ClientStack
scene.LoadWorldMap();
scene.PhysScene = GetPhysicsScene( );
- scene.PhysScene.SetTerrain(scene.Terrain.getHeights1D());
+ scene.PhysScene.SetTerrain(scene.Terrain.GetHeights1D());
scene.LoadPrimsFromStorage();
//Master Avatar Setup
diff --git a/OpenSim/Region/Environment/LandManagement/Land.cs b/OpenSim/Region/Environment/LandManagement/Land.cs
index b333f36..bae3b0e 100644
--- a/OpenSim/Region/Environment/LandManagement/Land.cs
+++ b/OpenSim/Region/Environment/LandManagement/Land.cs
@@ -219,8 +219,8 @@ namespace OpenSim.Region.Environment.LandManagement
}
}
}
- landData.AABBMin = new LLVector3((float)(min_x * 4), (float)(min_y * 4), (float)m_world.Terrain.get((min_x * 4), (min_y * 4)));
- landData.AABBMax = new LLVector3((float)(max_x * 4), (float)(max_y * 4), (float)m_world.Terrain.get((max_x * 4), (max_y * 4)));
+ landData.AABBMin = new LLVector3((float)(min_x * 4), (float)(min_y * 4), (float)m_world.Terrain.GetHeight((min_x * 4), (min_y * 4)));
+ landData.AABBMax = new LLVector3((float)(max_x * 4), (float)(max_y * 4), (float)m_world.Terrain.GetHeight((max_x * 4), (max_y * 4)));
landData.area = tempArea;
}
diff --git a/OpenSim/Region/Environment/Scenes/Scene.PacketHandlers.cs b/OpenSim/Region/Environment/Scenes/Scene.PacketHandlers.cs
index 9a81a5f..e963737 100644
--- a/OpenSim/Region/Environment/Scenes/Scene.PacketHandlers.cs
+++ b/OpenSim/Region/Environment/Scenes/Scene.PacketHandlers.cs
@@ -54,32 +54,32 @@ namespace OpenSim.Region.Environment.Scenes
{
case 0:
// flatten terrain
- Terrain.flatten(north, west, size, (double)seconds / 5.0);
+ Terrain.FlattenTerrain(north, west, size, (double)seconds / 5.0);
RegenerateTerrain(true, (int)north, (int)west);
break;
case 1:
// raise terrain
- Terrain.raise(north, west, size, (double)seconds / 5.0);
+ Terrain.RaiseTerrain(north, west, size, (double)seconds / 5.0);
RegenerateTerrain(true, (int)north, (int)west);
break;
case 2:
//lower terrain
- Terrain.lower(north, west, size, (double)seconds / 5.0);
+ Terrain.LowerTerrain(north, west, size, (double)seconds / 5.0);
RegenerateTerrain(true, (int)north, (int)west);
break;
case 3:
// smooth terrain
- Terrain.smooth(north, west, size, (double)seconds / 5.0);
+ Terrain.SmoothTerrain(north, west, size, (double)seconds / 5.0);
RegenerateTerrain(true, (int)north, (int)west);
break;
case 4:
// noise
- Terrain.noise(north, west, size, (double)seconds / 5.0);
+ Terrain.NoiseTerrain(north, west, size, (double)seconds / 5.0);
RegenerateTerrain(true, (int)north, (int)west);
break;
case 5:
// revert
- Terrain.revert(north, west, size, (double)seconds / 5.0);
+ Terrain.RevertTerrain(north, west, size, (double)seconds / 5.0);
RegenerateTerrain(true, (int)north, (int)west);
break;
diff --git a/OpenSim/Region/Environment/Scenes/Scene.cs b/OpenSim/Region/Environment/Scenes/Scene.cs
index acd7f3f..64676f0 100644
--- a/OpenSim/Region/Environment/Scenes/Scene.cs
+++ b/OpenSim/Region/Environment/Scenes/Scene.cs
@@ -239,10 +239,10 @@ namespace OpenSim.Region.Environment.Scenes
{
lock (m_syncRoot)
{
- phyScene.SetTerrain(Terrain.getHeights1D());
+ phyScene.SetTerrain(Terrain.GetHeights1D());
}
- storageManager.DataStore.StoreTerrain(Terrain.getHeights2DD());
+ storageManager.DataStore.StoreTerrain(Terrain.GetHeights2DD());
ForEachScenePresence(delegate(ScenePresence presence)
{
@@ -295,14 +295,14 @@ namespace OpenSim.Region.Environment.Scenes
{
try
{
- Terrain.hills();
+ Terrain.HillsGenerator();
lock (m_syncRoot)
{
- phyScene.SetTerrain(Terrain.getHeights1D());
+ phyScene.SetTerrain(Terrain.GetHeights1D());
}
- storageManager.DataStore.StoreTerrain(Terrain.getHeights2DD());
+ storageManager.DataStore.StoreTerrain(Terrain.GetHeights2DD());
ForEachScenePresence(delegate(ScenePresence presence)
{
@@ -328,12 +328,12 @@ namespace OpenSim.Region.Environment.Scenes
{
try
{
- Terrain.setHeights2D(newMap);
+ Terrain.SetHeights2D(newMap);
lock (m_syncRoot)
{
- phyScene.SetTerrain(Terrain.getHeights1D());
+ phyScene.SetTerrain(Terrain.GetHeights1D());
}
- storageManager.DataStore.StoreTerrain(Terrain.getHeights2DD());
+ storageManager.DataStore.StoreTerrain(Terrain.GetHeights2DD());
ForEachScenePresence(delegate(ScenePresence presence)
{
@@ -395,28 +395,28 @@ namespace OpenSim.Region.Environment.Scenes
if (string.IsNullOrEmpty(m_regInfo.estateSettings.terrainFile))
{
Console.WriteLine("No default terrain, procedurally generating...");
- Terrain.hills();
+ Terrain.HillsGenerator();
- storageManager.DataStore.StoreTerrain(Terrain.getHeights2DD());
+ storageManager.DataStore.StoreTerrain(Terrain.GetHeights2DD());
}
else
{
try
{
- Terrain.loadFromFileF32(m_regInfo.estateSettings.terrainFile);
+ Terrain.LoadFromFileF32(m_regInfo.estateSettings.terrainFile);
Terrain *= m_regInfo.estateSettings.terrainMultiplier;
}
catch
{
Console.WriteLine("Unable to load default terrain, procedurally generating instead...");
- Terrain.hills();
+ Terrain.HillsGenerator();
}
- storageManager.DataStore.StoreTerrain(Terrain.getHeights2DD());
+ storageManager.DataStore.StoreTerrain(Terrain.GetHeights2DD());
}
}
else
{
- Terrain.setHeights2D(map);
+ Terrain.SetHeights2D(map);
}
CreateTerrainTexture();
@@ -433,7 +433,7 @@ namespace OpenSim.Region.Environment.Scenes
public void CreateTerrainTexture()
{
//create a texture asset of the terrain
- byte[] data = Terrain.exportJpegImage("defaultstripe.png");
+ byte[] data = Terrain.ExportJpegImage("defaultstripe.png");
m_regInfo.estateSettings.terrainImageID = LLUUID.Random();
AssetBase asset = new AssetBase();
asset.FullID = m_regInfo.estateSettings.terrainImageID;
diff --git a/OpenSim/Region/Environment/Scenes/SceneBase.cs b/OpenSim/Region/Environment/Scenes/SceneBase.cs
index f3db9e2..c91c654 100644
--- a/OpenSim/Region/Environment/Scenes/SceneBase.cs
+++ b/OpenSim/Region/Environment/Scenes/SceneBase.cs
@@ -81,7 +81,7 @@ namespace OpenSim.Region.Environment.Scenes
/// Client to send to
public virtual void SendLayerData(IClientAPI RemoteClient)
{
- RemoteClient.SendLayerData(Terrain.getHeights1D());
+ RemoteClient.SendLayerData(Terrain.GetHeights1D());
}
///
@@ -92,7 +92,7 @@ namespace OpenSim.Region.Environment.Scenes
/// The client to send to
public virtual void SendLayerData(int px, int py, IClientAPI RemoteClient)
{
- RemoteClient.SendLayerData(px, py, Terrain.getHeights1D());
+ RemoteClient.SendLayerData(px, py, Terrain.GetHeights1D());
}
#endregion
diff --git a/OpenSim/Region/Examples/SimpleApp/MyWorld.cs b/OpenSim/Region/Examples/SimpleApp/MyWorld.cs
index 9749e22..6704a19 100644
--- a/OpenSim/Region/Examples/SimpleApp/MyWorld.cs
+++ b/OpenSim/Region/Examples/SimpleApp/MyWorld.cs
@@ -36,7 +36,7 @@ namespace SimpleApp
map[i] = 25f;
}
- this.Terrain.setHeights1D(map);
+ this.Terrain.GetHeights1D(map);
this.CreateTerrainTexture();
}
diff --git a/OpenSim/Region/Terrain.BasicTerrain/TerrainEngine.cs b/OpenSim/Region/Terrain.BasicTerrain/TerrainEngine.cs
index 686b35d..f965c41 100644
--- a/OpenSim/Region/Terrain.BasicTerrain/TerrainEngine.cs
+++ b/OpenSim/Region/Terrain.BasicTerrain/TerrainEngine.cs
@@ -69,6 +69,17 @@ namespace OpenSim.Region.Terrain
public Channel watermap;
///
+ /// Max amount the terrain can be raised from the revert parameters
+ ///
+ public double maxRaise = 500.0;
+
+ ///
+ /// Min amount the terrain can be lowered from the revert parameters
+ ///
+ public double minLower = 500.0;
+
+
+ ///
/// Whether or not the terrain has been modified since it was last saved and sent to the Physics engine.
/// Counts the number of modifications since the last save. (0 = Untainted)
///
@@ -89,10 +100,33 @@ namespace OpenSim.Region.Terrain
}
///
+ /// Checks to make sure the terrain is within baked values +/- maxRaise/minLower
+ ///
+ public void CheckHeightValues()
+ {
+ int x, y;
+ for (x = 0; x < w; x++)
+ {
+ for (y = 0; y < h; y++)
+ {
+ if ((heightmap.get(x, y) > revertmap.get(x, y) + maxRaise))
+ {
+ heightmap.map[x, y] = revertmap(x, y) + maxRaise;
+ }
+ if ((heightmap.get(x, y) > revertmap.get(x, y) - minLower))
+ {
+ heightmap.map[x, y] = revertmap(x, y) - minLower;
+ }
+ }
+ }
+ }
+
+
+ ///
/// Converts the heightmap to a 65536 value 1D floating point array
///
/// A float[65536] array containing the heightmap
- public float[] getHeights1D()
+ public float[] GetHeights1D()
{
float[] heights = new float[w * h];
int i;
@@ -109,7 +143,7 @@ namespace OpenSim.Region.Terrain
/// Converts the heightmap to a 256x256 value 2D floating point array.
///
/// An array of 256,256 values containing the heightmap
- public float[,] getHeights2D()
+ public float[,] GetHeights2D()
{
float[,] heights = new float[w, h];
int x, y;
@@ -127,7 +161,7 @@ namespace OpenSim.Region.Terrain
/// Converts the heightmap to a 256x256 value 2D floating point array. Double precision version.
///
/// An array of 256,256 values containing the heightmap
- public double[,] getHeights2DD()
+ public double[,] GetHeights2DD()
{
return heightmap.map;
}
@@ -136,7 +170,7 @@ namespace OpenSim.Region.Terrain
/// Imports a 1D floating point array into the 2D heightmap array
///
/// The array to import (must have 65536 members)
- public void setHeights1D(float[] heights)
+ public void GetHeights1D(float[] heights)
{
int i;
for (i = 0; i < w * h; i++)
@@ -151,7 +185,7 @@ namespace OpenSim.Region.Terrain
/// Loads a 2D array of values into the heightmap
///
/// An array of 256,256 float values
- public void setHeights2D(float[,] heights)
+ public void SetHeights2D(float[,] heights)
{
int x, y;
for (x = 0; x < w; x++)
@@ -161,6 +195,7 @@ namespace OpenSim.Region.Terrain
heightmap.set(x, y, (double)heights[x, y]);
}
}
+ SaveRevertMap();
tainted++;
}
@@ -168,7 +203,7 @@ namespace OpenSim.Region.Terrain
/// Loads a 2D array of values into the heightmap (Double Precision Version)
///
/// An array of 256,256 float values
- public void setHeights2D(double[,] heights)
+ public void SetHeights2D(double[,] heights)
{
int x, y;
for (x = 0; x < w; x++)
@@ -178,13 +213,14 @@ namespace OpenSim.Region.Terrain
heightmap.set(x, y, heights[x, y]);
}
}
+ SaveRevertMap();
tainted++;
}
///
/// Swaps the two heightmap buffers (the 'revert map' and the heightmap)
///
- public void swapRevertMaps()
+ public void SwapRevertMaps()
{
Channel backup = heightmap.copy();
heightmap = revertmap;
@@ -194,7 +230,7 @@ namespace OpenSim.Region.Terrain
///
/// Saves the current heightmap into the revertmap
///
- public void saveRevertMap()
+ public void SaveRevertMap()
{
revertmap = heightmap.copy();
}
@@ -239,20 +275,20 @@ namespace OpenSim.Region.Terrain
return false;
case "revert":
- swapRevertMaps();
- saveRevertMap();
+ SwapRevertMaps();
+ SaveRevertMap();
break;
case "bake":
- saveRevertMap();
+ SaveRevertMap();
break;
case "seed":
- setSeed(Convert.ToInt32(args[1]));
+ SetSeed(Convert.ToInt32(args[1]));
break;
case "erode":
- return consoleErosion(args, ref resultText);
+ return ConsoleErosion(args, ref resultText);
case "voronoi":
double[] c = new double[2];
@@ -262,14 +298,14 @@ namespace OpenSim.Region.Terrain
break;
case "hills":
- return consoleHills(args, ref resultText);
+ return ConsoleHills(args, ref resultText);
case "regenerate":
- hills();
+ HillsGenerator();
break;
case "rescale":
- setRange(Convert.ToSingle(args[1]), Convert.ToSingle(args[2]));
+ SetRange(Convert.ToSingle(args[1]), Convert.ToSingle(args[2]));
break;
case "multiply":
@@ -282,15 +318,15 @@ namespace OpenSim.Region.Terrain
switch (args[1].ToLower())
{
case "f32":
- loadFromFileF32(args[2]);
+ LoadFromFileF32(args[2]);
break;
case "f64":
- loadFromFileF64(args[2]);
+ LoadFromFileF64(args[2]);
break;
case "raw":
- loadFromFileSLRAW(args[2]);
+ LoadFromFileSLRAW(args[2]);
break;
case "img":
@@ -308,15 +344,15 @@ namespace OpenSim.Region.Terrain
switch (args[1].ToLower())
{
case "f32":
- writeToFileF32(args[2]);
+ WriteToFileF32(args[2]);
break;
case "f64":
- writeToFileF64(args[2]);
+ WriteToFileF64(args[2]);
break;
case "grdmap":
- exportImage(args[2], args[3]);
+ ExportImage(args[2], args[3]);
break;
case "png":
@@ -324,11 +360,11 @@ namespace OpenSim.Region.Terrain
break;
case "raw":
- writeToFileRAW(args[2]);
+ WriteToFileRAW(args[2]);
break;
case "hiraw":
- writeToFileHiRAW(args[2]);
+ WriteToFileHiRAW(args[2]);
break;
default:
@@ -366,7 +402,7 @@ namespace OpenSim.Region.Terrain
}
}
- private bool consoleErosion(string[] args, ref string resultText)
+ private bool ConsoleErosion(string[] args, ref string resultText)
{
switch (args[1].ToLower())
{
@@ -384,10 +420,10 @@ namespace OpenSim.Region.Terrain
return true;
}
- private bool consoleHills(string[] args, ref string resultText)
+ private bool ConsoleHills(string[] args, ref string resultText)
{
Random RandomClass = new Random();
- setSeed(RandomClass.Next());
+ SetSeed(RandomClass.Next());
int count;
double sizeMin;
double sizeRange;
@@ -441,7 +477,7 @@ namespace OpenSim.Region.Terrain
///
/// Minimum value of the new array
/// Maximum value of the new array
- public void setRange(float min, float max)
+ public void SetRange(float min, float max)
{
heightmap.normalise((double)min, (double)max);
tainted++;
@@ -452,7 +488,7 @@ namespace OpenSim.Region.Terrain
///
/// TODO: Move this to libTerrain itself
/// The filename of the double array to import
- public void loadFromFileF64(string filename)
+ public void LoadFromFileF64(string filename)
{
FileInfo file = new FileInfo(filename);
FileStream s = file.Open(FileMode.Open, FileAccess.Read);
@@ -477,7 +513,7 @@ namespace OpenSim.Region.Terrain
///
/// TODO: Move this to libTerrain itself
/// The filename of the float array to import
- public void loadFromFileF32(string filename)
+ public void LoadFromFileF32(string filename)
{
FileInfo file = new FileInfo(filename);
FileStream s = file.Open(FileMode.Open, FileAccess.Read);
@@ -502,7 +538,7 @@ namespace OpenSim.Region.Terrain
///
/// This file format stinks and is best avoided.
/// A path to the .RAW format
- public void loadFromFileSLRAW(string filename)
+ public void LoadFromFileSLRAW(string filename)
{
FileInfo file = new FileInfo(filename);
FileStream s = file.Open(FileMode.Open, FileAccess.Read);
@@ -527,7 +563,7 @@ namespace OpenSim.Region.Terrain
/// Writes the current terrain heightmap to disk, in the format of a 65536 entry double[] array.
///
/// The desired output filename
- public void writeToFileF64(string filename)
+ public void WriteToFileF64(string filename)
{
FileInfo file = new FileInfo(filename);
FileStream s = file.Open(FileMode.CreateNew, FileAccess.Write);
@@ -550,7 +586,7 @@ namespace OpenSim.Region.Terrain
/// Writes the current terrain heightmap to disk, in the format of a 65536 entry float[] array
///
/// The desired output filename
- public void writeToFileF32(string filename)
+ public void WriteToFileF32(string filename)
{
FileInfo file = new FileInfo(filename);
FileStream s = file.Open(FileMode.CreateNew, FileAccess.Write);
@@ -574,7 +610,7 @@ namespace OpenSim.Region.Terrain
/// (is also editable in an image application)
///
/// Filename to write to
- public void writeToFileRAW(string filename)
+ public void WriteToFileRAW(string filename)
{
FileInfo file = new FileInfo(filename);
FileStream s = file.Open(FileMode.CreateNew, FileAccess.Write);
@@ -639,7 +675,7 @@ namespace OpenSim.Region.Terrain
///
/// Does not calculate the revert map
/// The filename to output to
- public void writeToFileHiRAW(string filename)
+ public void WriteToFileHiRAW(string filename)
{
FileInfo file = new FileInfo(filename);
FileStream s = file.Open(FileMode.CreateNew, FileAccess.Write);
@@ -712,7 +748,7 @@ namespace OpenSim.Region.Terrain
/// Sets the random seed to be used by procedural functions which involve random numbers.
///
/// The desired seed
- public void setSeed(int val)
+ public void SetSeed(int val)
{
heightmap.seed = val;
}
@@ -724,7 +760,7 @@ namespace OpenSim.Region.Terrain
/// Center of the sphere on the Y axis
/// The radius of the sphere
/// Scale the height of the sphere by this amount (recommended 0..2)
- public void raise(double rx, double ry, double size, double amount)
+ public void RaiseTerrain(double rx, double ry, double size, double amount)
{
lock (heightmap)
{
@@ -741,7 +777,7 @@ namespace OpenSim.Region.Terrain
/// The center of the sphere at the Y axis
/// The radius of the sphere in meters
/// Scale the height of the sphere by this amount (recommended 0..2)
- public void lower(double rx, double ry, double size, double amount)
+ public void LowerTerrain(double rx, double ry, double size, double amount)
{
lock (heightmap)
{
@@ -758,7 +794,7 @@ namespace OpenSim.Region.Terrain
/// Center of sphere
/// Radius of the sphere
/// Thickness of the mask (0..2 recommended)
- public void flatten(double rx, double ry, double size, double amount)
+ public void FlattenTerrain(double rx, double ry, double size, double amount)
{
lock (heightmap)
{
@@ -775,7 +811,7 @@ namespace OpenSim.Region.Terrain
/// Center of the bounding sphere
/// The radius of the sphere
/// Strength of the mask (0..2) recommended
- public void noise(double rx, double ry, double size, double amount)
+ public void NoiseTerrain(double rx, double ry, double size, double amount)
{
lock (heightmap)
{
@@ -798,7 +834,7 @@ namespace OpenSim.Region.Terrain
/// Center of the bounding sphere
/// The radius of the sphere
/// Strength of the mask (0..2) recommended
- public void revert(double rx, double ry, double size, double amount)
+ public void RevertTerrain(double rx, double ry, double size, double amount)
{
lock (heightmap)
{
@@ -818,7 +854,7 @@ namespace OpenSim.Region.Terrain
/// Center of the sphere
/// Radius of the sphere
/// Thickness of the mask (0..2 recommended)
- public void smooth(double rx, double ry, double size, double amount)
+ public void SmoothTerrain(double rx, double ry, double size, double amount)
{
lock (heightmap)
{
@@ -837,7 +873,7 @@ namespace OpenSim.Region.Terrain
///
/// Generates a simple set of hills in the shape of an island
///
- public void hills()
+ public void HillsGenerator()
{
lock (heightmap)
{
@@ -855,7 +891,7 @@ namespace OpenSim.Region.Terrain
/// X coord
/// Y coord
/// Height at specified coordinates
- public double get(int x, int y)
+ public double GetHeight(int x, int y)
{
return heightmap.get(x, y);
}
@@ -866,11 +902,11 @@ namespace OpenSim.Region.Terrain
/// The heightfield
/// The multiplier
///
- public static TerrainEngine operator *(TerrainEngine meep, Double val)
+ public static TerrainEngine operator *(TerrainEngine terrain, Double val)
{
- meep.heightmap *= val;
- meep.tainted++;
- return meep;
+ terrain.heightmap *= val;
+ terrain.tainted++;
+ return terrain;
}
///
@@ -878,7 +914,7 @@ namespace OpenSim.Region.Terrain
///
/// The destination filename for the image
/// A 1x*height* image which contains the colour gradient to export with. Must be at least 1x2 pixels, 1x256 or more is ideal.
- public void exportImage(string filename, string gradientmap)
+ public void ExportImage(string filename, string gradientmap)
{
try
{
@@ -917,7 +953,7 @@ namespace OpenSim.Region.Terrain
/// Exports the current heightmap in Jpeg2000 format to a byte[]
///
/// A 1x*height* image which contains the colour gradient to export with. Must be at least 1x2 pixels, 1x256 or more is ideal.
- public byte[] exportJpegImage(string gradientmap)
+ public byte[] ExportJpegImage(string gradientmap)
{
byte[] imageData = null;
try
--
cgit v1.1