Update svn properties.
parent
a9ae5ab840
commit
f218e7e090
|
@ -1,43 +1,43 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using OpenSim.Region.Environment.Modules.Terrain;
|
using OpenSim.Region.Environment.Modules.Terrain;
|
||||||
using OpenSim.Region.Environment.Interfaces;
|
using OpenSim.Region.Environment.Interfaces;
|
||||||
|
|
||||||
namespace OpenSim.Region.Environment.Modules.Terrain.FileLoaders
|
namespace OpenSim.Region.Environment.Modules.Terrain.FileLoaders
|
||||||
{
|
{
|
||||||
public class RAW32 : ITerrainLoader
|
public class RAW32 : ITerrainLoader
|
||||||
{
|
{
|
||||||
#region ITerrainLoader Members
|
#region ITerrainLoader Members
|
||||||
|
|
||||||
public ITerrainChannel LoadFile(string filename)
|
public ITerrainChannel LoadFile(string filename)
|
||||||
{
|
{
|
||||||
TerrainChannel retval = new TerrainChannel();
|
TerrainChannel retval = new TerrainChannel();
|
||||||
|
|
||||||
FileInfo file = new FileInfo(filename);
|
FileInfo file = new FileInfo(filename);
|
||||||
FileStream s = file.Open(FileMode.Open, FileAccess.Read);
|
FileStream s = file.Open(FileMode.Open, FileAccess.Read);
|
||||||
BinaryReader bs = new BinaryReader(s);
|
BinaryReader bs = new BinaryReader(s);
|
||||||
int x, y;
|
int x, y;
|
||||||
for (y = 0; y < retval.Height; y++)
|
for (y = 0; y < retval.Height; y++)
|
||||||
{
|
{
|
||||||
for (x = 0; x < retval.Width; x++)
|
for (x = 0; x < retval.Width; x++)
|
||||||
{
|
{
|
||||||
retval[x, y] = bs.ReadSingle();
|
retval[x, y] = bs.ReadSingle();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bs.Close();
|
bs.Close();
|
||||||
s.Close();
|
s.Close();
|
||||||
|
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void SaveFile(string filename)
|
public void SaveFile(string filename)
|
||||||
{
|
{
|
||||||
throw new NotImplementedException();
|
throw new NotImplementedException();
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,89 +1,89 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using OpenSim.Region.Environment.Modules.Terrain;
|
using OpenSim.Region.Environment.Modules.Terrain;
|
||||||
using OpenSim.Region.Environment.Interfaces;
|
using OpenSim.Region.Environment.Interfaces;
|
||||||
|
|
||||||
namespace OpenSim.Region.Environment.Modules.Terrain.FileLoaders
|
namespace OpenSim.Region.Environment.Modules.Terrain.FileLoaders
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Terragen File Format Loader
|
/// Terragen File Format Loader
|
||||||
/// Built from specification at
|
/// Built from specification at
|
||||||
/// http://www.planetside.co.uk/terragen/dev/tgterrain.html
|
/// http://www.planetside.co.uk/terragen/dev/tgterrain.html
|
||||||
/// </summary>
|
/// </summary>
|
||||||
class Terragen : ITerrainLoader
|
class Terragen : ITerrainLoader
|
||||||
{
|
{
|
||||||
private static readonly log4net.ILog m_log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
|
private static readonly log4net.ILog m_log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
|
||||||
|
|
||||||
#region ITerrainLoader Members
|
#region ITerrainLoader Members
|
||||||
|
|
||||||
public ITerrainChannel LoadFile(string filename)
|
public ITerrainChannel LoadFile(string filename)
|
||||||
{
|
{
|
||||||
TerrainChannel retval = new TerrainChannel();
|
TerrainChannel retval = new TerrainChannel();
|
||||||
|
|
||||||
FileInfo file = new FileInfo(filename);
|
FileInfo file = new FileInfo(filename);
|
||||||
FileStream s = file.Open(FileMode.Open, FileAccess.Read);
|
FileStream s = file.Open(FileMode.Open, FileAccess.Read);
|
||||||
BinaryReader bs = new BinaryReader(s);
|
BinaryReader bs = new BinaryReader(s);
|
||||||
|
|
||||||
bool eof = false;
|
bool eof = false;
|
||||||
|
|
||||||
if (ASCIIEncoding.ASCII.GetString(bs.ReadBytes(16)) == "TERRAGENTERRAIN")
|
if (ASCIIEncoding.ASCII.GetString(bs.ReadBytes(16)) == "TERRAGENTERRAIN")
|
||||||
{
|
{
|
||||||
// Terragen file
|
// Terragen file
|
||||||
while (eof == false)
|
while (eof == false)
|
||||||
{
|
{
|
||||||
int w = 256;
|
int w = 256;
|
||||||
int h = 256;
|
int h = 256;
|
||||||
string tmp = ASCIIEncoding.ASCII.GetString(bs.ReadBytes(4));
|
string tmp = ASCIIEncoding.ASCII.GetString(bs.ReadBytes(4));
|
||||||
switch (tmp)
|
switch (tmp)
|
||||||
{
|
{
|
||||||
case "SIZE":
|
case "SIZE":
|
||||||
int sztmp = bs.ReadInt16() + 1;
|
int sztmp = bs.ReadInt16() + 1;
|
||||||
w = sztmp;
|
w = sztmp;
|
||||||
h = sztmp;
|
h = sztmp;
|
||||||
bs.ReadInt16();
|
bs.ReadInt16();
|
||||||
break;
|
break;
|
||||||
case "XPTS":
|
case "XPTS":
|
||||||
w = bs.ReadInt16();
|
w = bs.ReadInt16();
|
||||||
bs.ReadInt16();
|
bs.ReadInt16();
|
||||||
break;
|
break;
|
||||||
case "YPTS":
|
case "YPTS":
|
||||||
h = bs.ReadInt16();
|
h = bs.ReadInt16();
|
||||||
bs.ReadInt16();
|
bs.ReadInt16();
|
||||||
break;
|
break;
|
||||||
case "ALTW":
|
case "ALTW":
|
||||||
eof = true;
|
eof = true;
|
||||||
Int16 heightScale = bs.ReadInt16();
|
Int16 heightScale = bs.ReadInt16();
|
||||||
Int16 baseHeight = bs.ReadInt16();
|
Int16 baseHeight = bs.ReadInt16();
|
||||||
retval = new TerrainChannel(w, h);
|
retval = new TerrainChannel(w, h);
|
||||||
int x, y;
|
int x, y;
|
||||||
for (x = 0; x < w; x++)
|
for (x = 0; x < w; x++)
|
||||||
{
|
{
|
||||||
for (y = 0; y < h; y++)
|
for (y = 0; y < h; y++)
|
||||||
{
|
{
|
||||||
retval[x, y] = (double)baseHeight + (double)bs.ReadInt16() * (double)heightScale / 65536.0;
|
retval[x, y] = (double)baseHeight + (double)bs.ReadInt16() * (double)heightScale / 65536.0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
bs.ReadInt32();
|
bs.ReadInt32();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bs.Close();
|
bs.Close();
|
||||||
s.Close();
|
s.Close();
|
||||||
|
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void SaveFile(string filename)
|
public void SaveFile(string filename)
|
||||||
{
|
{
|
||||||
throw new NotImplementedException();
|
throw new NotImplementedException();
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue