* Added some comments to terrain module.
* Fixed a range issue in the GenericSystemDrawing saving mechanism.0.6.0-stable
parent
e46454afa6
commit
17507404b5
|
@ -30,8 +30,19 @@ using OpenSim.Region.Environment.Interfaces;
|
||||||
|
|
||||||
namespace OpenSim.Region.Environment.Modules.Terrain.FileLoaders
|
namespace OpenSim.Region.Environment.Modules.Terrain.FileLoaders
|
||||||
{
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// A generic windows bitmap loader.
|
||||||
|
/// Should be capable of handling 24-bit RGB images.
|
||||||
|
///
|
||||||
|
/// Uses the System.Drawing filesystem loader.
|
||||||
|
/// </summary>
|
||||||
class BMP : GenericSystemDrawing
|
class BMP : GenericSystemDrawing
|
||||||
{
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Exports a file to a image on the disk using a System.Drawing exporter.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="filename">The target filename</param>
|
||||||
|
/// <param name="map">The terrain channel being saved</param>
|
||||||
public override void SaveFile(string filename, ITerrainChannel map)
|
public override void SaveFile(string filename, ITerrainChannel map)
|
||||||
{
|
{
|
||||||
Bitmap colours = CreateGrayscaleBitmapFromMap(map);
|
Bitmap colours = CreateGrayscaleBitmapFromMap(map);
|
||||||
|
@ -39,6 +50,10 @@ namespace OpenSim.Region.Environment.Modules.Terrain.FileLoaders
|
||||||
colours.Save(filename, System.Drawing.Imaging.ImageFormat.Bmp);
|
colours.Save(filename, System.Drawing.Imaging.ImageFormat.Bmp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The human readable version of the file format(s) this loader handles
|
||||||
|
/// </summary>
|
||||||
|
/// <returns></returns>
|
||||||
public override string ToString()
|
public override string ToString()
|
||||||
{
|
{
|
||||||
return "BMP";
|
return "BMP";
|
||||||
|
|
|
@ -31,10 +31,24 @@ using OpenSim.Region.Environment.Interfaces;
|
||||||
|
|
||||||
namespace OpenSim.Region.Environment.Modules.Terrain.FileLoaders
|
namespace OpenSim.Region.Environment.Modules.Terrain.FileLoaders
|
||||||
{
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// A virtual class designed to have methods overloaded,
|
||||||
|
/// this class provides an interface for a generic image
|
||||||
|
/// saving and loading mechanism, but does not specify the
|
||||||
|
/// format. It should not be insubstantiated directly.
|
||||||
|
/// </summary>
|
||||||
public class GenericSystemDrawing : ITerrainLoader
|
public class GenericSystemDrawing : ITerrainLoader
|
||||||
{
|
{
|
||||||
#region ITerrainLoader Members
|
#region ITerrainLoader Members
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Loads a file from a specified filename on the disk,
|
||||||
|
/// parses the image using the System.Drawing parsers
|
||||||
|
/// then returns a terrain channel. Values are
|
||||||
|
/// returned based on HSL brightness between 0m and 128m
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="filename">The target image to load</param>
|
||||||
|
/// <returns>A terrain channel generated from the image.</returns>
|
||||||
public virtual ITerrainChannel LoadFile(string filename)
|
public virtual ITerrainChannel LoadFile(string filename)
|
||||||
{
|
{
|
||||||
Bitmap file = new Bitmap(filename);
|
Bitmap file = new Bitmap(filename);
|
||||||
|
@ -63,6 +77,12 @@ namespace OpenSim.Region.Environment.Modules.Terrain.FileLoaders
|
||||||
return "SYS.DRAWING";
|
return "SYS.DRAWING";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Protected method, generates a grayscale bitmap
|
||||||
|
/// image from a specified terrain channel.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="map">The terrain channel to export to bitmap</param>
|
||||||
|
/// <returns>A System.Drawing.Bitmap containing a grayscale image</returns>
|
||||||
protected Bitmap CreateGrayscaleBitmapFromMap(ITerrainChannel map)
|
protected Bitmap CreateGrayscaleBitmapFromMap(ITerrainChannel map)
|
||||||
{
|
{
|
||||||
Bitmap bmp = new Bitmap(map.Width, map.Height);
|
Bitmap bmp = new Bitmap(map.Width, map.Height);
|
||||||
|
@ -82,13 +102,22 @@ namespace OpenSim.Region.Environment.Modules.Terrain.FileLoaders
|
||||||
// 512 is the largest possible height before colours clamp
|
// 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));
|
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]);
|
bmp.SetPixel(x, map.Height - y - 1, grays[colorindex]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return bmp;
|
return bmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Protected method, generates a coloured bitmap
|
||||||
|
/// image from a specified terrain channel.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="map">The terrain channel to export to bitmap</param>
|
||||||
|
/// <returns>A System.Drawing.Bitmap containing a coloured image</returns>
|
||||||
protected Bitmap CreateBitmapFromMap(ITerrainChannel map)
|
protected Bitmap CreateBitmapFromMap(ITerrainChannel map)
|
||||||
{
|
{
|
||||||
Bitmap gradientmapLd = new Bitmap("defaultstripe.png");
|
Bitmap gradientmapLd = new Bitmap("defaultstripe.png");
|
||||||
|
@ -109,12 +138,22 @@ namespace OpenSim.Region.Environment.Modules.Terrain.FileLoaders
|
||||||
{
|
{
|
||||||
// 512 is the largest possible height before colours clamp
|
// 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));
|
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]);
|
bmp.SetPixel(x, map.Height - y - 1, colours[colorindex]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return bmp;
|
return bmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Exports a file to a image on the disk using a System.Drawing exporter.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="filename">The target filename</param>
|
||||||
|
/// <param name="map">The terrain channel being saved</param>
|
||||||
public virtual void SaveFile(string filename, ITerrainChannel map)
|
public virtual void SaveFile(string filename, ITerrainChannel map)
|
||||||
{
|
{
|
||||||
Bitmap colours = CreateGrayscaleBitmapFromMap(map);
|
Bitmap colours = CreateGrayscaleBitmapFromMap(map);
|
||||||
|
|
Loading…
Reference in New Issue