2011-05-08 08:17:20 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
|
2011-06-29 02:58:34 +00:00
|
|
|
|
namespace Substrate.Core
|
2011-05-08 08:17:20 +00:00
|
|
|
|
{
|
|
|
|
|
public class ByteArray : ICopyable<ByteArray>
|
|
|
|
|
{
|
2011-07-04 03:45:36 +00:00
|
|
|
|
protected readonly byte[] dataArray;
|
2011-05-08 08:17:20 +00:00
|
|
|
|
|
|
|
|
|
public ByteArray (byte[] data)
|
|
|
|
|
{
|
2011-07-04 03:45:36 +00:00
|
|
|
|
dataArray = data;
|
2011-05-08 08:17:20 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public byte this[int i]
|
|
|
|
|
{
|
2011-07-04 03:45:36 +00:00
|
|
|
|
get { return dataArray[i]; }
|
|
|
|
|
set { dataArray[i] = value; }
|
2011-05-08 08:17:20 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public int Length
|
|
|
|
|
{
|
2011-07-04 03:45:36 +00:00
|
|
|
|
get { return dataArray.Length; }
|
2011-05-08 08:17:20 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void Clear ()
|
|
|
|
|
{
|
2011-07-04 03:45:36 +00:00
|
|
|
|
for (int i = 0; i < dataArray.Length; i++)
|
2011-05-08 08:17:20 +00:00
|
|
|
|
{
|
2011-07-04 03:45:36 +00:00
|
|
|
|
dataArray[i] = 0;
|
2011-05-08 08:17:20 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#region ICopyable<yteArray> Members
|
|
|
|
|
|
|
|
|
|
public virtual ByteArray Copy ()
|
|
|
|
|
{
|
2011-07-04 03:45:36 +00:00
|
|
|
|
byte[] data = new byte[dataArray.Length];
|
|
|
|
|
dataArray.CopyTo(data, 0);
|
2011-05-08 08:17:20 +00:00
|
|
|
|
|
|
|
|
|
return new ByteArray(data);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public sealed class XZYByteArray : ByteArray
|
|
|
|
|
{
|
|
|
|
|
private readonly int _xdim;
|
|
|
|
|
private readonly int _ydim;
|
|
|
|
|
private readonly int _zdim;
|
|
|
|
|
|
|
|
|
|
public XZYByteArray (int xdim, int ydim, int zdim, byte[] data)
|
|
|
|
|
: base(data)
|
|
|
|
|
{
|
|
|
|
|
_xdim = xdim;
|
|
|
|
|
_ydim = ydim;
|
|
|
|
|
_zdim = zdim;
|
|
|
|
|
|
|
|
|
|
if (xdim * ydim * zdim != data.Length)
|
|
|
|
|
{
|
|
|
|
|
throw new ArgumentException("Product of dimensions must equal length of data");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public byte this[int x, int y, int z]
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
int index = _ydim * (x * _zdim + z) + y;
|
2011-07-04 03:45:36 +00:00
|
|
|
|
return dataArray[index];
|
2011-05-08 08:17:20 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
int index = _ydim * (x * _zdim + z) + y;
|
2011-07-04 03:45:36 +00:00
|
|
|
|
dataArray[index] = value;
|
2011-05-08 08:17:20 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public int XDim
|
|
|
|
|
{
|
|
|
|
|
get { return _xdim; }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public int YDim
|
|
|
|
|
{
|
|
|
|
|
get { return _ydim; }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public int ZDim
|
|
|
|
|
{
|
|
|
|
|
get { return _zdim; }
|
|
|
|
|
}
|
|
|
|
|
|
2011-06-30 03:59:20 +00:00
|
|
|
|
public int GetIndex (int x, int y, int z)
|
|
|
|
|
{
|
|
|
|
|
return _ydim * (x * _zdim + z) + y;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void GetMultiIndex (int index, out int x, out int y, out int z)
|
|
|
|
|
{
|
|
|
|
|
int yzdim = _ydim * _zdim;
|
|
|
|
|
x = index / yzdim;
|
|
|
|
|
|
|
|
|
|
int zy = index - (x * yzdim);
|
|
|
|
|
z = zy / _ydim;
|
|
|
|
|
y = zy - (z * _ydim);
|
|
|
|
|
}
|
|
|
|
|
|
2011-05-08 08:17:20 +00:00
|
|
|
|
#region ICopyable<XZYByteArray> Members
|
|
|
|
|
|
|
|
|
|
public override ByteArray Copy ()
|
|
|
|
|
{
|
2011-07-04 03:45:36 +00:00
|
|
|
|
byte[] data = new byte[dataArray.Length];
|
|
|
|
|
dataArray.CopyTo(data, 0);
|
2011-05-08 08:17:20 +00:00
|
|
|
|
|
|
|
|
|
return new XZYByteArray(_xdim, _ydim, _zdim, data);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public sealed class ZXByteArray : ByteArray
|
|
|
|
|
{
|
|
|
|
|
private readonly int _xdim;
|
|
|
|
|
private readonly int _zdim;
|
|
|
|
|
|
|
|
|
|
public ZXByteArray (int xdim, int zdim, byte[] data)
|
|
|
|
|
: base(data)
|
|
|
|
|
{
|
|
|
|
|
_xdim = xdim;
|
|
|
|
|
_zdim = zdim;
|
|
|
|
|
|
|
|
|
|
if (xdim * zdim != data.Length)
|
|
|
|
|
{
|
|
|
|
|
throw new ArgumentException("Product of dimensions must equal length of data");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public byte this[int x, int z]
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
int index = z * _xdim + x;
|
2011-07-04 03:45:36 +00:00
|
|
|
|
return dataArray[index];
|
2011-05-08 08:17:20 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
int index = z * _xdim + x;
|
2011-07-04 03:45:36 +00:00
|
|
|
|
dataArray[index] = value;
|
2011-05-08 08:17:20 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public int XDim
|
|
|
|
|
{
|
|
|
|
|
get { return _xdim; }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public int ZDim
|
|
|
|
|
{
|
|
|
|
|
get { return _zdim; }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#region ICopyable<ZXByteArray> Members
|
|
|
|
|
|
|
|
|
|
public override ByteArray Copy ()
|
|
|
|
|
{
|
2011-07-04 03:45:36 +00:00
|
|
|
|
byte[] data = new byte[dataArray.Length];
|
|
|
|
|
dataArray.CopyTo(data, 0);
|
2011-05-08 08:17:20 +00:00
|
|
|
|
|
|
|
|
|
return new ZXByteArray(_xdim, _zdim, data);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
}
|
|
|
|
|
}
|