mirror of
https://git.do.srb2.org/STJr/UltimateZoneBuilder.git
synced 2024-11-25 13:21:28 +00:00
added stuff
This commit is contained in:
parent
f7e6133848
commit
84a3749f6e
16 changed files with 724 additions and 27 deletions
BIN
Build/AxInterop.CodeSense.dll
Normal file
BIN
Build/AxInterop.CodeSense.dll
Normal file
Binary file not shown.
BIN
Build/Interop.CodeSense.dll
Normal file
BIN
Build/Interop.CodeSense.dll
Normal file
Binary file not shown.
BIN
Build/SlimDX.dll
Normal file
BIN
Build/SlimDX.dll
Normal file
Binary file not shown.
BIN
Build/cmcs21.dll
Normal file
BIN
Build/cmcs21.dll
Normal file
Binary file not shown.
BIN
Build/cmcs21.ocx
Normal file
BIN
Build/cmcs21.ocx
Normal file
Binary file not shown.
BIN
Resources/Icons/NewMap.ico
Normal file
BIN
Resources/Icons/NewMap.ico
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.4 KiB |
BIN
Resources/Icons/OpenMap.ico
Normal file
BIN
Resources/Icons/OpenMap.ico
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.4 KiB |
BIN
Resources/Icons/SaveMap.ico
Normal file
BIN
Resources/Icons/SaveMap.ico
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.4 KiB |
BIN
Resources/thingicon.cpt
Normal file
BIN
Resources/thingicon.cpt
Normal file
Binary file not shown.
|
@ -61,7 +61,9 @@
|
||||||
</Compile>
|
</Compile>
|
||||||
<Compile Include="Map\Linedef.cs" />
|
<Compile Include="Map\Linedef.cs" />
|
||||||
<Compile Include="Map\MapManager.cs" />
|
<Compile Include="Map\MapManager.cs" />
|
||||||
|
<Compile Include="Map\Sector.cs" />
|
||||||
<Compile Include="Map\Sidedef.cs" />
|
<Compile Include="Map\Sidedef.cs" />
|
||||||
|
<Compile Include="Map\Thing.cs" />
|
||||||
<Compile Include="Map\Vertex.cs" />
|
<Compile Include="Map\Vertex.cs" />
|
||||||
<Compile Include="Properties\Resources.Designer.cs">
|
<Compile Include="Properties\Resources.Designer.cs">
|
||||||
<AutoGen>True</AutoGen>
|
<AutoGen>True</AutoGen>
|
||||||
|
@ -70,6 +72,9 @@
|
||||||
</Compile>
|
</Compile>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
<Reference Include="SlimDX, Version=1.0.2721.819, Culture=neutral, processorArchitecture=x86">
|
||||||
|
<Aliases>global</Aliases>
|
||||||
|
</Reference>
|
||||||
<Reference Include="System" />
|
<Reference Include="System" />
|
||||||
<Reference Include="System.Drawing" />
|
<Reference Include="System.Drawing" />
|
||||||
<Reference Include="System.Windows.Forms" />
|
<Reference Include="System.Windows.Forms" />
|
||||||
|
@ -91,4 +96,30 @@
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<None Include="Resources\Splash2.png" />
|
<None Include="Resources\Splash2.png" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<COMReference Include="AxCodeSense">
|
||||||
|
<Guid>{665BF2B8-F41F-4EF4-A8D0-303FBFFC475E}</Guid>
|
||||||
|
<VersionMajor>2</VersionMajor>
|
||||||
|
<VersionMinor>0</VersionMinor>
|
||||||
|
<Lcid>0</Lcid>
|
||||||
|
<WrapperTool>aximp</WrapperTool>
|
||||||
|
<Isolated>False</Isolated>
|
||||||
|
</COMReference>
|
||||||
|
<COMReference Include="CodeSense">
|
||||||
|
<Guid>{665BF2B8-F41F-4EF4-A8D0-303FBFFC475E}</Guid>
|
||||||
|
<VersionMajor>2</VersionMajor>
|
||||||
|
<VersionMinor>0</VersionMinor>
|
||||||
|
<Lcid>0</Lcid>
|
||||||
|
<WrapperTool>tlbimp</WrapperTool>
|
||||||
|
<Isolated>False</Isolated>
|
||||||
|
</COMReference>
|
||||||
|
<COMReference Include="stdole">
|
||||||
|
<Guid>{00020430-0000-0000-C000-000000000046}</Guid>
|
||||||
|
<VersionMajor>2</VersionMajor>
|
||||||
|
<VersionMinor>0</VersionMinor>
|
||||||
|
<Lcid>0</Lcid>
|
||||||
|
<WrapperTool>primary</WrapperTool>
|
||||||
|
<Isolated>False</Isolated>
|
||||||
|
</COMReference>
|
||||||
|
</ItemGroup>
|
||||||
</Project>
|
</Project>
|
|
@ -15,6 +15,7 @@ using System.Collections;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
|
using CodeImp.DoomBuilder.Geometry;
|
||||||
|
|
||||||
namespace CodeImp.DoomBuilder.Map
|
namespace CodeImp.DoomBuilder.Map
|
||||||
{
|
{
|
||||||
|
@ -26,6 +27,14 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
|
|
||||||
#region ================== Variables
|
#region ================== Variables
|
||||||
|
|
||||||
|
// Map
|
||||||
|
private MapManager map;
|
||||||
|
|
||||||
|
// List items
|
||||||
|
private LinkedListNode<Linedef> mainlistitem;
|
||||||
|
private LinkedListNode<Linedef> startvertexlistitem;
|
||||||
|
private LinkedListNode<Linedef> endvertexlistitem;
|
||||||
|
|
||||||
// Vertices
|
// Vertices
|
||||||
private Vertex start;
|
private Vertex start;
|
||||||
private Vertex end;
|
private Vertex end;
|
||||||
|
@ -34,6 +43,11 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
private Sidedef front;
|
private Sidedef front;
|
||||||
private Sidedef back;
|
private Sidedef back;
|
||||||
|
|
||||||
|
// Cache
|
||||||
|
private float lengthsq;
|
||||||
|
private float length;
|
||||||
|
//private float angle;
|
||||||
|
|
||||||
// Properties
|
// Properties
|
||||||
private int flags;
|
private int flags;
|
||||||
private int action;
|
private int action;
|
||||||
|
@ -47,7 +61,8 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
|
|
||||||
#region ================== Properties
|
#region ================== Properties
|
||||||
|
|
||||||
// Disposing
|
public Sidedef Front { get { return front; } }
|
||||||
|
public Sidedef Back { get { return back; } }
|
||||||
public bool IsDisposed { get { return isdisposed; } }
|
public bool IsDisposed { get { return isdisposed; } }
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
@ -55,12 +70,21 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
#region ================== Constructor / Disposer
|
#region ================== Constructor / Disposer
|
||||||
|
|
||||||
// Constructor
|
// Constructor
|
||||||
public Linedef(Vertex start, Vertex end)
|
public Linedef(MapManager map, LinkedListNode<Linedef> listitem, Vertex start, Vertex end)
|
||||||
{
|
{
|
||||||
// Initialize
|
// Initialize
|
||||||
|
this.map = map;
|
||||||
|
this.mainlistitem = listitem;
|
||||||
this.start = start;
|
this.start = start;
|
||||||
this.end = end;
|
this.end = end;
|
||||||
|
|
||||||
|
// Attach to vertices
|
||||||
|
startvertexlistitem = start.AttachLinedef(this);
|
||||||
|
endvertexlistitem = end.AttachLinedef(this);
|
||||||
|
|
||||||
|
// Calculate values
|
||||||
|
Recalculate();
|
||||||
|
|
||||||
// We have no destructor
|
// We have no destructor
|
||||||
GC.SuppressFinalize(this);
|
GC.SuppressFinalize(this);
|
||||||
}
|
}
|
||||||
|
@ -71,28 +95,99 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
// Not already disposed?
|
// Not already disposed?
|
||||||
if(!isdisposed)
|
if(!isdisposed)
|
||||||
{
|
{
|
||||||
|
// Already set isdisposed so that changes can be prohibited
|
||||||
|
isdisposed = true;
|
||||||
|
|
||||||
|
// Remove from main list
|
||||||
|
mainlistitem.List.Remove(mainlistitem);
|
||||||
|
|
||||||
// Detach from vertices
|
// Detach from vertices
|
||||||
start.Detach(this);
|
start.DetachLinedef(startvertexlistitem);
|
||||||
end.Detach(this);
|
end.DetachLinedef(endvertexlistitem);
|
||||||
|
|
||||||
// Dispose sidedefs
|
// Dispose sidedefs
|
||||||
front.Dispose();
|
front.Dispose();
|
||||||
back.Dispose();
|
back.Dispose();
|
||||||
|
|
||||||
// Clean up
|
// Clean up
|
||||||
|
mainlistitem = null;
|
||||||
|
startvertexlistitem = null;
|
||||||
|
endvertexlistitem = null;
|
||||||
start = null;
|
start = null;
|
||||||
end = null;
|
end = null;
|
||||||
front = null;
|
front = null;
|
||||||
back = null;
|
back = null;
|
||||||
|
map = null;
|
||||||
// Done
|
|
||||||
isdisposed = true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region ================== Methods
|
#region ================== Management
|
||||||
|
|
||||||
|
// This attaches a sidedef on the front
|
||||||
|
public void AttachFront(Sidedef s) { if(front == null) front = s; else throw new Exception("Linedef already has a front Sidedef."); }
|
||||||
|
|
||||||
|
// This attaches a sidedef on the back
|
||||||
|
public void AttachBack(Sidedef s) { if(back == null) back = s; else throw new Exception("Linedef already has a back Sidedef."); }
|
||||||
|
|
||||||
|
// This detaches a sidedef from the front
|
||||||
|
public void DetachSidedef(Sidedef s) { if(front == s) front = null; else if(back == s) back = null; else throw new Exception("Specified Sidedef is not attached to this Linedef."); }
|
||||||
|
|
||||||
|
// This recalculates cached values
|
||||||
|
public void Recalculate()
|
||||||
|
{
|
||||||
|
// Delta vector
|
||||||
|
Vector2D delta = end.Position - start.Position;
|
||||||
|
|
||||||
|
// Recalculate values
|
||||||
|
lengthsq = delta.GetLengthSq();
|
||||||
|
length = (float)Math.Sqrt(lengthsq);
|
||||||
|
//angle = delta.GetAngle();
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region ================== Mathematics
|
||||||
|
|
||||||
|
// This returns the shortest distance from given coordinates to line
|
||||||
|
public float DistanceToSq(Vector2D p, bool bounded)
|
||||||
|
{
|
||||||
|
Vector2D v1 = start.Position;
|
||||||
|
Vector2D v2 = end.Position;
|
||||||
|
|
||||||
|
// Calculate intersection offset
|
||||||
|
float u = ((p.x - v1.x) * (v2.x - v1.x) + (p.y - v1.y) * (v2.y - v1.y)) / lengthsq;
|
||||||
|
|
||||||
|
// Limit intersection offset to the line
|
||||||
|
if(bounded) if(u < 0f) u = 0f; else if(u > 1f) u = 1f;
|
||||||
|
|
||||||
|
// Calculate intersection point
|
||||||
|
Vector2D i = v1 + u * (v2 - v1);
|
||||||
|
|
||||||
|
// Return distance between intersection and point
|
||||||
|
// which is the shortest distance to the line
|
||||||
|
float ldx = p.x - i.x;
|
||||||
|
float ldy = p.y - i.y;
|
||||||
|
return ldx * ldx + ldy * ldy;
|
||||||
|
}
|
||||||
|
|
||||||
|
// This returns the shortest distance from given coordinates to line
|
||||||
|
public float DistanceTo(Vector2D p, bool bounded)
|
||||||
|
{
|
||||||
|
return (float)Math.Sqrt(DistanceToSq(p, bounded));
|
||||||
|
}
|
||||||
|
|
||||||
|
// This tests on which side of the line the given coordinates are
|
||||||
|
// returns < 0 for front (right) side, > 0 for back (left) side and 0 if on the line
|
||||||
|
public float SideOfLine(Vector2D p)
|
||||||
|
{
|
||||||
|
Vector2D v1 = start.Position;
|
||||||
|
Vector2D v2 = end.Position;
|
||||||
|
|
||||||
|
// Calculate and return side information
|
||||||
|
return (p.y - v1.y) * (v2.x - v1.x) - (p.x - v1.x) * (v2.y - v1.y);
|
||||||
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,6 +15,7 @@ using System.Collections;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
|
using CodeImp.DoomBuilder.Geometry;
|
||||||
|
|
||||||
namespace CodeImp.DoomBuilder.Map
|
namespace CodeImp.DoomBuilder.Map
|
||||||
{
|
{
|
||||||
|
@ -26,6 +27,13 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
|
|
||||||
#region ================== Variables
|
#region ================== Variables
|
||||||
|
|
||||||
|
// Map structures
|
||||||
|
private LinkedList<Vertex> vertices;
|
||||||
|
private LinkedList<Linedef> linedefs;
|
||||||
|
private LinkedList<Sidedef> sidedefs;
|
||||||
|
private LinkedList<Sector> sectors;
|
||||||
|
private LinkedList<Thing> things;
|
||||||
|
|
||||||
// Disposing
|
// Disposing
|
||||||
private bool isdisposed = false;
|
private bool isdisposed = false;
|
||||||
|
|
||||||
|
@ -33,17 +41,26 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
|
|
||||||
#region ================== Properties
|
#region ================== Properties
|
||||||
|
|
||||||
// Disposing
|
public ICollection<Vertex> Vertices { get { return vertices; } }
|
||||||
|
public ICollection<Linedef> Linedefs { get { return linedefs; } }
|
||||||
|
public ICollection<Sidedef> Sidedefs { get { return sidedefs; } }
|
||||||
|
public ICollection<Sector> Sectors { get { return sectors; } }
|
||||||
|
public ICollection<Thing> Things { get { return things; } }
|
||||||
public bool IsDisposed { get { return isdisposed; } }
|
public bool IsDisposed { get { return isdisposed; } }
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region ================== Constructor / Disposer
|
#region ================== Constructor / Disposer
|
||||||
|
|
||||||
// Constructor
|
// Constructor for new empty map
|
||||||
public MapManager()
|
public MapManager()
|
||||||
{
|
{
|
||||||
// Initialize
|
// Initialize
|
||||||
|
vertices = new LinkedList<Vertex>();
|
||||||
|
linedefs = new LinkedList<Linedef>();
|
||||||
|
sidedefs = new LinkedList<Sidedef>();
|
||||||
|
sectors = new LinkedList<Sector>();
|
||||||
|
things = new LinkedList<Thing>();
|
||||||
|
|
||||||
// We have no destructor
|
// We have no destructor
|
||||||
GC.SuppressFinalize(this);
|
GC.SuppressFinalize(this);
|
||||||
|
@ -52,10 +69,40 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
// Diposer
|
// Diposer
|
||||||
public void Dispose()
|
public void Dispose()
|
||||||
{
|
{
|
||||||
|
ArrayList list;
|
||||||
|
|
||||||
// Not already disposed?
|
// Not already disposed?
|
||||||
if(!isdisposed)
|
if(!isdisposed)
|
||||||
{
|
{
|
||||||
|
// Already set isdisposed so that changes can be prohibited
|
||||||
|
isdisposed = true;
|
||||||
|
|
||||||
|
// Dispose all things
|
||||||
|
list = new ArrayList(things);
|
||||||
|
foreach(Thing t in list) t.Dispose();
|
||||||
|
|
||||||
|
// Dispose all sectors
|
||||||
|
list = new ArrayList(sectors);
|
||||||
|
foreach(Sector s in list) s.Dispose();
|
||||||
|
|
||||||
|
// Dispose all sidedefs
|
||||||
|
list = new ArrayList(sidedefs);
|
||||||
|
foreach(Sidedef sd in list) sd.Dispose();
|
||||||
|
|
||||||
|
// Dispose all linedefs
|
||||||
|
list = new ArrayList(linedefs);
|
||||||
|
foreach(Linedef l in list) l.Dispose();
|
||||||
|
|
||||||
|
// Dispose all vertices
|
||||||
|
list = new ArrayList(vertices);
|
||||||
|
foreach(Vertex v in list) v.Dispose();
|
||||||
|
|
||||||
// Clean up
|
// Clean up
|
||||||
|
vertices = null;
|
||||||
|
linedefs = null;
|
||||||
|
sidedefs = null;
|
||||||
|
sectors = null;
|
||||||
|
things = null;
|
||||||
|
|
||||||
// Done
|
// Done
|
||||||
isdisposed = true;
|
isdisposed = true;
|
||||||
|
@ -64,7 +111,169 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region ================== Methods
|
#region ================== Management
|
||||||
|
|
||||||
|
// This creates a new vertex
|
||||||
|
public Vertex CreateVertex(Vector2D pos)
|
||||||
|
{
|
||||||
|
LinkedListNode<Vertex> listitem;
|
||||||
|
Vertex v;
|
||||||
|
|
||||||
|
// Make a list item
|
||||||
|
listitem = new LinkedListNode<Vertex>(null);
|
||||||
|
|
||||||
|
// Make the vertex
|
||||||
|
v = new Vertex(this, listitem, pos);
|
||||||
|
listitem.Value = v;
|
||||||
|
|
||||||
|
// Add vertex to the list
|
||||||
|
vertices.AddLast(listitem);
|
||||||
|
|
||||||
|
// Return result
|
||||||
|
return v;
|
||||||
|
}
|
||||||
|
|
||||||
|
// This creates a new linedef
|
||||||
|
public Linedef CreateLinedef(Vertex start, Vertex end)
|
||||||
|
{
|
||||||
|
LinkedListNode<Linedef> listitem;
|
||||||
|
Linedef l;
|
||||||
|
|
||||||
|
// Make a list item
|
||||||
|
listitem = new LinkedListNode<Linedef>(null);
|
||||||
|
|
||||||
|
// Make the linedef
|
||||||
|
l = new Linedef(this, listitem, start, end);
|
||||||
|
listitem.Value = l;
|
||||||
|
|
||||||
|
// Add linedef to the list
|
||||||
|
linedefs.AddLast(listitem);
|
||||||
|
|
||||||
|
// Return result
|
||||||
|
return l;
|
||||||
|
}
|
||||||
|
|
||||||
|
// This creates a new sidedef
|
||||||
|
public Sidedef CreateSidedef(Linedef l, bool front, Sector s)
|
||||||
|
{
|
||||||
|
LinkedListNode<Sidedef> listitem;
|
||||||
|
Sidedef sd;
|
||||||
|
|
||||||
|
// Make a list item
|
||||||
|
listitem = new LinkedListNode<Sidedef>(null);
|
||||||
|
|
||||||
|
// Make the sidedef
|
||||||
|
sd = new Sidedef(this, listitem, l, front, s);
|
||||||
|
listitem.Value = sd;
|
||||||
|
|
||||||
|
// Add sidedef to the list
|
||||||
|
sidedefs.AddLast(listitem);
|
||||||
|
|
||||||
|
// Return result
|
||||||
|
return sd;
|
||||||
|
}
|
||||||
|
|
||||||
|
// This creates a new sector
|
||||||
|
public Sector CreateSector()
|
||||||
|
{
|
||||||
|
LinkedListNode<Sector> listitem;
|
||||||
|
Sector s;
|
||||||
|
|
||||||
|
// Make a list item
|
||||||
|
listitem = new LinkedListNode<Sector>(null);
|
||||||
|
|
||||||
|
// Make the sector
|
||||||
|
s = new Sector(this, listitem);
|
||||||
|
listitem.Value = s;
|
||||||
|
|
||||||
|
// Add sector to the list
|
||||||
|
sectors.AddLast(listitem);
|
||||||
|
|
||||||
|
// Return result
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
|
// This creates a new thing
|
||||||
|
public Thing CreateThing(int type, Vector2D pos)
|
||||||
|
{
|
||||||
|
LinkedListNode<Thing> listitem;
|
||||||
|
Thing t;
|
||||||
|
|
||||||
|
// Make a list item
|
||||||
|
listitem = new LinkedListNode<Thing>(null);
|
||||||
|
|
||||||
|
// Make the thing
|
||||||
|
t = new Thing(this, listitem, type, pos);
|
||||||
|
listitem.Value = t;
|
||||||
|
|
||||||
|
// Add thing to the list
|
||||||
|
things.AddLast(listitem);
|
||||||
|
|
||||||
|
// Return result
|
||||||
|
return t;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region ================== Static Tools
|
||||||
|
|
||||||
|
// This finds the line closest to the specified position
|
||||||
|
public static Linedef NearestLinedef(ICollection<Linedef> selection, Vector2D pos)
|
||||||
|
{
|
||||||
|
Linedef closest = null;
|
||||||
|
float distance = float.MaxValue;
|
||||||
|
float d;
|
||||||
|
|
||||||
|
// Go for all linedefs in selection
|
||||||
|
foreach(Linedef l in selection)
|
||||||
|
{
|
||||||
|
// Calculate distance and check if closer than previous find
|
||||||
|
d = l.DistanceToSq(pos, true);
|
||||||
|
if(d < distance)
|
||||||
|
{
|
||||||
|
// This one is closer
|
||||||
|
closest = l;
|
||||||
|
distance = d;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Return result
|
||||||
|
return closest;
|
||||||
|
}
|
||||||
|
|
||||||
|
// This finds the vertex closest to the specified position
|
||||||
|
public static Vertex NearestVertex(ICollection<Vertex> selection, Vector2D pos)
|
||||||
|
{
|
||||||
|
Vertex closest = null;
|
||||||
|
float distance = float.MaxValue;
|
||||||
|
float d;
|
||||||
|
|
||||||
|
// Go for all vertices in selection
|
||||||
|
foreach(Vertex v in selection)
|
||||||
|
{
|
||||||
|
// Calculate distance and check if closer than previous find
|
||||||
|
d = v.DistanceToSq(pos);
|
||||||
|
if(d < distance)
|
||||||
|
{
|
||||||
|
// This one is closer
|
||||||
|
closest = v;
|
||||||
|
distance = d;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Return result
|
||||||
|
return closest;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region ================== Tools
|
||||||
|
|
||||||
|
// This finds the line closest to the specified position
|
||||||
|
public Linedef NearestLinedef(Vector2D pos) { return MapManager.NearestLinedef(linedefs, pos); }
|
||||||
|
|
||||||
|
// This finds the vertex closest to the specified position
|
||||||
|
public Vertex NearestVertex(Vector2D pos) { return MapManager.NearestVertex(vertices, pos); }
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
}
|
}
|
||||||
|
|
124
Source/Map/Sector.cs
Normal file
124
Source/Map/Sector.cs
Normal file
|
@ -0,0 +1,124 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Globalization;
|
||||||
|
using System.Text;
|
||||||
|
|
||||||
|
namespace CodeImp.DoomBuilder.Map
|
||||||
|
{
|
||||||
|
internal class Sector : IDisposable
|
||||||
|
{
|
||||||
|
#region ================== Constants
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region ================== Variables
|
||||||
|
|
||||||
|
// Map
|
||||||
|
private MapManager map;
|
||||||
|
|
||||||
|
// List items
|
||||||
|
private LinkedListNode<Sector> mainlistitem;
|
||||||
|
|
||||||
|
// Sidedefs
|
||||||
|
private LinkedList<Sidedef> sidedefs;
|
||||||
|
|
||||||
|
// Things
|
||||||
|
private LinkedList<Thing> things;
|
||||||
|
|
||||||
|
// Properties
|
||||||
|
private int floorheight;
|
||||||
|
private int ceilheight;
|
||||||
|
private string floortexname;
|
||||||
|
private string ceiltexname;
|
||||||
|
private int special;
|
||||||
|
private int tag;
|
||||||
|
|
||||||
|
// Disposing
|
||||||
|
private bool isdisposed = false;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region ================== Properties
|
||||||
|
|
||||||
|
// Disposing
|
||||||
|
public bool IsDisposed { get { return isdisposed; } }
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region ================== Constructor / Disposer
|
||||||
|
|
||||||
|
// Constructor
|
||||||
|
public Sector(MapManager map, LinkedListNode<Sector> listitem)
|
||||||
|
{
|
||||||
|
// Initialize
|
||||||
|
this.map = map;
|
||||||
|
this.mainlistitem = listitem;
|
||||||
|
this.sidedefs = new LinkedList<Sidedef>();
|
||||||
|
this.things = new LinkedList<Thing>();
|
||||||
|
|
||||||
|
// We have no destructor
|
||||||
|
GC.SuppressFinalize(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Diposer
|
||||||
|
public void Dispose()
|
||||||
|
{
|
||||||
|
// Not already disposed?
|
||||||
|
if(!isdisposed)
|
||||||
|
{
|
||||||
|
// Already set isdisposed so that changes can be prohibited
|
||||||
|
isdisposed = true;
|
||||||
|
|
||||||
|
// Remove from main list
|
||||||
|
mainlistitem.List.Remove(mainlistitem);
|
||||||
|
|
||||||
|
// Dispose the sidedefs that are attached to this sector
|
||||||
|
// because a sidedef cannot exist without reference to its sector.
|
||||||
|
foreach(Sidedef sd in sidedefs) sd.Dispose();
|
||||||
|
|
||||||
|
// Determine new sector references on things
|
||||||
|
foreach(Thing t in things) t.DetermineSector();
|
||||||
|
|
||||||
|
// Clean up
|
||||||
|
mainlistitem = null;
|
||||||
|
sidedefs = null;
|
||||||
|
things = null;
|
||||||
|
map = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region ================== Management
|
||||||
|
|
||||||
|
// This attaches a sidedef and returns the listitem
|
||||||
|
public LinkedListNode<Sidedef> AttachSidedef(Sidedef sd) { return sidedefs.AddLast(sd); }
|
||||||
|
|
||||||
|
// This detaches a sidedef
|
||||||
|
public void DetachSidedef(LinkedListNode<Sidedef> l)
|
||||||
|
{
|
||||||
|
// Not disposing?
|
||||||
|
if(!isdisposed)
|
||||||
|
{
|
||||||
|
// Remove sidedef
|
||||||
|
sidedefs.Remove(l);
|
||||||
|
|
||||||
|
// No more sidedefs left?
|
||||||
|
if(sidedefs.Count == 0)
|
||||||
|
{
|
||||||
|
// This sector is now useless, dispose it
|
||||||
|
this.Dispose();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// This attaches a thing and returns the listitem
|
||||||
|
public LinkedListNode<Thing> AttachThing(Thing t) { return things.AddLast(t); }
|
||||||
|
|
||||||
|
// This detaches a thing
|
||||||
|
public void DetachThing(LinkedListNode<Thing> l) { if(!isdisposed) things.Remove(l); }
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
|
@ -14,6 +14,26 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
|
|
||||||
#region ================== Variables
|
#region ================== Variables
|
||||||
|
|
||||||
|
// Map
|
||||||
|
private MapManager map;
|
||||||
|
|
||||||
|
// List items
|
||||||
|
private LinkedListNode<Sidedef> mainlistitem;
|
||||||
|
private LinkedListNode<Sidedef> sectorlistitem;
|
||||||
|
|
||||||
|
// Owner
|
||||||
|
private Linedef linedef;
|
||||||
|
|
||||||
|
// Sector
|
||||||
|
private Sector sector;
|
||||||
|
|
||||||
|
// Properties
|
||||||
|
private int offsetx;
|
||||||
|
private int offsety;
|
||||||
|
private string texnamehigh;
|
||||||
|
private string texnamemid;
|
||||||
|
private string texnamelow;
|
||||||
|
|
||||||
// Disposing
|
// Disposing
|
||||||
private bool isdisposed = false;
|
private bool isdisposed = false;
|
||||||
|
|
||||||
|
@ -21,7 +41,8 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
|
|
||||||
#region ================== Properties
|
#region ================== Properties
|
||||||
|
|
||||||
// Disposing
|
public Sidedef Other { get { if(this == linedef.Front) return linedef.Back; else return linedef.Front; } }
|
||||||
|
public Sector Sector { get { return sector; } }
|
||||||
public bool IsDisposed { get { return isdisposed; } }
|
public bool IsDisposed { get { return isdisposed; } }
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
@ -29,9 +50,19 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
#region ================== Constructor / Disposer
|
#region ================== Constructor / Disposer
|
||||||
|
|
||||||
// Constructor
|
// Constructor
|
||||||
public Sidedef()
|
public Sidedef(MapManager map, LinkedListNode<Sidedef> listitem, Linedef l, bool front, Sector s)
|
||||||
{
|
{
|
||||||
// Initialize
|
// Initialize
|
||||||
|
this.map = map;
|
||||||
|
this.mainlistitem = listitem;
|
||||||
|
this.linedef = l;
|
||||||
|
this.sector = s;
|
||||||
|
|
||||||
|
// Attach to the linedef
|
||||||
|
if(front) l.AttachFront(this); else l.AttachBack(this);
|
||||||
|
|
||||||
|
// Attach to sector
|
||||||
|
sectorlistitem = s.AttachSidedef(this);
|
||||||
|
|
||||||
// We have no destructor
|
// We have no destructor
|
||||||
GC.SuppressFinalize(this);
|
GC.SuppressFinalize(this);
|
||||||
|
@ -43,10 +74,24 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
// Not already disposed?
|
// Not already disposed?
|
||||||
if(!isdisposed)
|
if(!isdisposed)
|
||||||
{
|
{
|
||||||
// Clean up
|
// Already set isdisposed so that changes can be prohibited
|
||||||
|
|
||||||
// Done
|
|
||||||
isdisposed = true;
|
isdisposed = true;
|
||||||
|
|
||||||
|
// Remove from main list
|
||||||
|
mainlistitem.List.Remove(mainlistitem);
|
||||||
|
|
||||||
|
// Detach from linedef
|
||||||
|
linedef.DetachSidedef(this);
|
||||||
|
|
||||||
|
// Detach from sector
|
||||||
|
sector.DetachSidedef(sectorlistitem);
|
||||||
|
|
||||||
|
// Clean up
|
||||||
|
mainlistitem = null;
|
||||||
|
sectorlistitem = null;
|
||||||
|
linedef = null;
|
||||||
|
map = null;
|
||||||
|
sector = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
139
Source/Map/Thing.cs
Normal file
139
Source/Map/Thing.cs
Normal file
|
@ -0,0 +1,139 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Globalization;
|
||||||
|
using System.Text;
|
||||||
|
using CodeImp.DoomBuilder.Geometry;
|
||||||
|
|
||||||
|
namespace CodeImp.DoomBuilder.Map
|
||||||
|
{
|
||||||
|
internal class Thing : IDisposable
|
||||||
|
{
|
||||||
|
#region ================== Constants
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region ================== Variables
|
||||||
|
|
||||||
|
// Map
|
||||||
|
private MapManager map;
|
||||||
|
|
||||||
|
// Sector
|
||||||
|
private Sector sector = null;
|
||||||
|
|
||||||
|
// List items
|
||||||
|
private LinkedListNode<Thing> mainlistitem;
|
||||||
|
private LinkedListNode<Thing> sectorlistitem;
|
||||||
|
|
||||||
|
// Properties
|
||||||
|
private int type;
|
||||||
|
private Vector2D pos;
|
||||||
|
private float angle;
|
||||||
|
|
||||||
|
// Disposing
|
||||||
|
private bool isdisposed = false;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region ================== Properties
|
||||||
|
|
||||||
|
// Disposing
|
||||||
|
public bool IsDisposed { get { return isdisposed; } }
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region ================== Constructor / Disposer
|
||||||
|
|
||||||
|
// Constructor
|
||||||
|
public Thing(MapManager map, LinkedListNode<Thing> listitem, int type, Vector2D pos)
|
||||||
|
{
|
||||||
|
// Initialize
|
||||||
|
this.map = map;
|
||||||
|
this.mainlistitem = listitem;
|
||||||
|
this.type = type;
|
||||||
|
this.pos = pos;
|
||||||
|
|
||||||
|
// Determine current sector
|
||||||
|
DetermineSector();
|
||||||
|
|
||||||
|
// We have no destructor
|
||||||
|
GC.SuppressFinalize(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Diposer
|
||||||
|
public void Dispose()
|
||||||
|
{
|
||||||
|
// Not already disposed?
|
||||||
|
if(!isdisposed)
|
||||||
|
{
|
||||||
|
// Already set isdisposed so that changes can be prohibited
|
||||||
|
isdisposed = true;
|
||||||
|
|
||||||
|
// Remove from main list
|
||||||
|
mainlistitem.List.Remove(mainlistitem);
|
||||||
|
|
||||||
|
// Remove from sector
|
||||||
|
if(sector != null) sector.DetachThing(sectorlistitem);
|
||||||
|
|
||||||
|
// Clean up
|
||||||
|
mainlistitem = null;
|
||||||
|
sectorlistitem = null;
|
||||||
|
map = null;
|
||||||
|
sector = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region ================== Management
|
||||||
|
|
||||||
|
// This determines which sector the thing is in and links it
|
||||||
|
public void DetermineSector()
|
||||||
|
{
|
||||||
|
Sector newsector = null;
|
||||||
|
Vertex nv;
|
||||||
|
Linedef nl;
|
||||||
|
|
||||||
|
// Find the nearest vertex on the map
|
||||||
|
nv = map.NearestVertex(pos);
|
||||||
|
if(nv != null)
|
||||||
|
{
|
||||||
|
// Find the nearest linedef on the vertex
|
||||||
|
nl = nv.NearestLinedef(pos);
|
||||||
|
if(nl != null)
|
||||||
|
{
|
||||||
|
// Check what side of line we are at
|
||||||
|
if(nl.SideOfLine(pos) < 0f)
|
||||||
|
{
|
||||||
|
// Front side
|
||||||
|
if(nl.Front != null) newsector = nl.Front.Sector;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Back side
|
||||||
|
if(nl.Back != null) newsector = nl.Back.Sector;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Currently attached to a sector and sector changes?
|
||||||
|
if((sector != null) && (newsector != sector))
|
||||||
|
{
|
||||||
|
// Remove from current sector
|
||||||
|
sector.DetachThing(sectorlistitem);
|
||||||
|
sectorlistitem = null;
|
||||||
|
sector = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Attach to new sector?
|
||||||
|
if((newsector != null) && (newsector != sector))
|
||||||
|
{
|
||||||
|
// Attach to new sector
|
||||||
|
sector = newsector;
|
||||||
|
sectorlistitem = sector.AttachThing(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
|
@ -27,11 +27,17 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
|
|
||||||
#region ================== Variables
|
#region ================== Variables
|
||||||
|
|
||||||
|
// Map
|
||||||
|
private MapManager map;
|
||||||
|
|
||||||
|
// List items
|
||||||
|
private LinkedListNode<Vertex> mainlistitem;
|
||||||
|
|
||||||
// Position
|
// Position
|
||||||
private Vector2D pos;
|
private Vector2D pos;
|
||||||
|
|
||||||
// References
|
// References
|
||||||
private List<Linedef> linedefs;
|
private LinkedList<Linedef> linedefs;
|
||||||
|
|
||||||
// Disposing
|
// Disposing
|
||||||
private bool isdisposed = false;
|
private bool isdisposed = false;
|
||||||
|
@ -40,7 +46,7 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
|
|
||||||
#region ================== Properties
|
#region ================== Properties
|
||||||
|
|
||||||
public List<Linedef> Linedefs { get { return linedefs; } }
|
public ICollection<Linedef> Linedefs { get { return linedefs; } }
|
||||||
public Vector2D Position { get { return pos; } }
|
public Vector2D Position { get { return pos; } }
|
||||||
public bool IsDisposed { get { return isdisposed; } }
|
public bool IsDisposed { get { return isdisposed; } }
|
||||||
|
|
||||||
|
@ -49,9 +55,12 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
#region ================== Constructor / Disposer
|
#region ================== Constructor / Disposer
|
||||||
|
|
||||||
// Constructor
|
// Constructor
|
||||||
public Vertex(Vector2D pos)
|
public Vertex(MapManager map, LinkedListNode<Vertex> listitem, Vector2D pos)
|
||||||
{
|
{
|
||||||
// Initialize
|
// Initialize
|
||||||
|
this.map = map;
|
||||||
|
this.linedefs = new LinkedList<Linedef>();
|
||||||
|
this.mainlistitem = listitem;
|
||||||
this.pos = pos;
|
this.pos = pos;
|
||||||
|
|
||||||
// We have no destructor
|
// We have no destructor
|
||||||
|
@ -64,27 +73,47 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
// Not already disposed?
|
// Not already disposed?
|
||||||
if(!isdisposed)
|
if(!isdisposed)
|
||||||
{
|
{
|
||||||
|
// Already set isdisposed so that changes can be prohibited
|
||||||
|
isdisposed = true;
|
||||||
|
|
||||||
|
// Remove from main list
|
||||||
|
mainlistitem.List.Remove(mainlistitem);
|
||||||
|
|
||||||
// Dispose the lines that are attached to this vertex
|
// Dispose the lines that are attached to this vertex
|
||||||
// because a linedef cannot exist without 2 vertices.
|
// because a linedef cannot exist without 2 vertices.
|
||||||
foreach(Linedef l in linedefs) l.Dispose();
|
foreach(Linedef l in linedefs) l.Dispose();
|
||||||
|
|
||||||
// Clean up
|
// Clean up
|
||||||
linedefs = null;
|
linedefs = null;
|
||||||
|
mainlistitem = null;
|
||||||
// Done
|
map = null;
|
||||||
isdisposed = true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region ================== Methods
|
#region ================== Management
|
||||||
|
|
||||||
// This attaches a linedef
|
// This attaches a linedef and returns the listitem
|
||||||
public void Attach(Linedef l) { linedefs.Add(l); }
|
public LinkedListNode<Linedef> AttachLinedef(Linedef l) { return linedefs.AddLast(l); }
|
||||||
|
|
||||||
// This detaches a linedef
|
// This detaches a linedef
|
||||||
public void Detach(Linedef l) { linedefs.Remove(l); }
|
public void DetachLinedef(LinkedListNode<Linedef> l)
|
||||||
|
{
|
||||||
|
// Not disposing?
|
||||||
|
if(!isdisposed)
|
||||||
|
{
|
||||||
|
// Remove linedef
|
||||||
|
linedefs.Remove(l);
|
||||||
|
|
||||||
|
// No more linedefs left?
|
||||||
|
if(linedefs.Count == 0)
|
||||||
|
{
|
||||||
|
// This vertex is now useless, dispose it
|
||||||
|
this.Dispose();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// This rounds the coordinates to integrals
|
// This rounds the coordinates to integrals
|
||||||
public void Round()
|
public void Round()
|
||||||
|
@ -95,5 +124,30 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region ================== Mathematics
|
||||||
|
|
||||||
|
// This returns the distance from given coordinates
|
||||||
|
public float DistanceToSq(Vector2D p)
|
||||||
|
{
|
||||||
|
Vector2D delta = p - pos;
|
||||||
|
return delta.GetLengthSq();
|
||||||
|
}
|
||||||
|
|
||||||
|
// This returns the distance from given coordinates
|
||||||
|
public float DistanceTo(Vector2D p)
|
||||||
|
{
|
||||||
|
Vector2D delta = p - pos;
|
||||||
|
return delta.GetLength();
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region ================== Tools
|
||||||
|
|
||||||
|
// This finds the line closest to the specified position
|
||||||
|
public Linedef NearestLinedef(Vector2D pos) { return MapManager.NearestLinedef(linedefs, pos); }
|
||||||
|
|
||||||
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue