From fe5807cd0972e015182a5e64d9ed8e7c77c4f271 Mon Sep 17 00:00:00 2001
From: UbitUmarov
Date: Sun, 20 Sep 2015 15:31:38 +0100
Subject: fix terrain save greyscale mapping to 1:1 suporting standard 0-255m
range and not only 0-127m. Jpeg format still using a non standard color
encoded heightmap
---
.../Terrain/FileLoaders/GenericSystemDrawing.cs | 70 +++++-----------------
1 file changed, 16 insertions(+), 54 deletions(-)
(limited to 'OpenSim')
diff --git a/OpenSim/Region/CoreModules/World/Terrain/FileLoaders/GenericSystemDrawing.cs b/OpenSim/Region/CoreModules/World/Terrain/FileLoaders/GenericSystemDrawing.cs
index d5c77ec..c0b276a 100644
--- a/OpenSim/Region/CoreModules/World/Terrain/FileLoaders/GenericSystemDrawing.cs
+++ b/OpenSim/Region/CoreModules/World/Terrain/FileLoaders/GenericSystemDrawing.cs
@@ -128,7 +128,7 @@ namespace OpenSim.Region.CoreModules.World.Terrain.FileLoaders
colours.Save(stream, ImageFormat.Png);
}
- public virtual void SaveFile(ITerrainChannel m_channel, string filename,
+ public virtual void SaveFile(ITerrainChannel m_channel, string filename,
int offsetX, int offsetY,
int fileWidth, int fileHeight,
int regionSizeX, int regionSizeY)
@@ -162,13 +162,13 @@ namespace OpenSim.Region.CoreModules.World.Terrain.FileLoaders
{
newBitmap = new Bitmap(fileWidth * regionSizeX, fileHeight * regionSizeY);
}
-
+
thisBitmap = CreateGrayscaleBitmapFromMap(m_channel);
- // Console.WriteLine("offsetX=" + offsetX + " offsetY=" + offsetY);
+ // Console.WriteLine("offsetX=" + offsetX + " offsetY=" + offsetY);
for (int x = 0; x < regionSizeX; x++)
for (int y = 0; y < regionSizeY; y++)
newBitmap.SetPixel(x + offsetX * regionSizeX, y + (fileHeight - 1 - offsetY) * regionSizeY, thisBitmap.GetPixel(x, y));
-
+
Save(newBitmap, filename);
}
finally
@@ -227,59 +227,21 @@ namespace OpenSim.Region.CoreModules.World.Terrain.FileLoaders
{
for (int x = 0; x < map.Width; x++)
{
- // 512 is the largest possible height before colours clamp
- int colorindex = (int) (Math.Max(Math.Min(1.0, map[x, y] / 128.0), 0.0) * (pallete - 1));
-
- // Handle error conditions
- if (colorindex > pallete - 1 || colorindex < 0)
- bmp.SetPixel(x, map.Height - y - 1, Color.Red);
- else
- bmp.SetPixel(x, map.Height - y - 1, grays[colorindex]);
- }
- }
- return bmp;
- }
-
- ///
- /// Protected method, generates a coloured bitmap
- /// image from a specified terrain channel.
- ///
- /// The terrain channel to export to bitmap
- /// A System.Drawing.Bitmap containing a coloured image
- protected static Bitmap CreateBitmapFromMap(ITerrainChannel map)
- {
- int pallete;
- Bitmap bmp;
- Color[] colours;
-
- using (Bitmap gradientmapLd = new Bitmap("defaultstripe.png"))
- {
- pallete = gradientmapLd.Height;
-
- bmp = new Bitmap(map.Width, map.Height);
- colours = new Color[pallete];
-
- for (int i = 0; i < pallete; i++)
- {
- colours[i] = gradientmapLd.GetPixel(0, i);
- }
- }
-
- for (int y = 0; y < map.Height; y++)
- {
- for (int x = 0; x < map.Width; x++)
- {
- // 512 is the largest possible height before colours clamp
- int colorindex = (int) (Math.Max(Math.Min(1.0, map[x, y] / 512.0), 0.0) * (pallete - 1));
-
- // Handle error conditions
- if (colorindex > pallete - 1 || colorindex < 0)
- bmp.SetPixel(x, map.Height - y - 1, Color.Red);
- else
- bmp.SetPixel(x, map.Height - y - 1, colours[colorindex]);
+ int colorindex = (int)map[x, y]; // one to one conversion as seems apparent on sl docs
+ // or 0-511 range?
+ // int colorindex = (int)map[x, y]/2; // 0-511
+
+ // clamp it not adding the red warning
+ if (colorindex < 0)
+ colorindex = 0;
+ else if (colorindex >= pallete)
+ colorindex = pallete - 1;
+ bmp.SetPixel(x, map.Height - y - 1, grays[colorindex]);
}
}
return bmp;
}
}
}
+
+
--
cgit v1.1