UltimateZoneBuilder/Source/Plugins/BuilderModes/VisualModes/EffectUDMFVertexOffset.cs

83 lines
2.2 KiB
C#
Raw Normal View History

using CodeImp.DoomBuilder.Map;
using CodeImp.DoomBuilder.Geometry;
namespace CodeImp.DoomBuilder.BuilderModes
{
internal class EffectUDMFVertexOffset : SectorEffect
{
public EffectUDMFVertexOffset(SectorData data) : base(data)
{
2013-03-18 13:52:27 +00:00
// New effect added: This sector needs an update!
if(data.Mode.VisualSectorExists(data.Sector))
{
2013-03-18 13:52:27 +00:00
BaseVisualSector vs = (BaseVisualSector)data.Mode.GetVisualSector(data.Sector);
vs.UpdateSectorGeometry(true);
}
}
public override void Update()
{
// Create vertices in clockwise order
Vector3D[] floorVerts = new Vector3D[3];
Vector3D[] ceilingVerts = new Vector3D[3];
bool floorChanged = false;
bool ceilingChanged = false;
int index = 0;
//check vertices
foreach(Sidedef sd in data.Sector.Sidedefs)
{
Vertex v = sd.IsFront ? sd.Line.End : sd.Line.Start;
//create "normal" vertices
floorVerts[index] = new Vector3D(v.Position);
ceilingVerts[index] = new Vector3D(v.Position);
//check ceiling
2020-05-21 12:20:02 +00:00
if(!double.IsNaN(v.ZCeiling))
{
2013-03-18 13:52:27 +00:00
//vertex offset is absolute
ceilingVerts[index].z = v.ZCeiling;
2013-03-18 13:52:27 +00:00
ceilingChanged = true;
}
else
{
2013-03-18 13:52:27 +00:00
ceilingVerts[index].z = data.Ceiling.plane.GetZ(v.Position);
}
//and floor
2020-05-21 12:20:02 +00:00
if(!double.IsNaN(v.ZFloor))
{
2013-03-18 13:52:27 +00:00
//vertex offset is absolute
floorVerts[index].z = v.ZFloor;
2013-03-18 13:52:27 +00:00
floorChanged = true;
}
else
{
2013-03-18 13:52:27 +00:00
floorVerts[index].z = data.Floor.plane.GetZ(v.Position);
}
2013-03-18 13:52:27 +00:00
VertexData vd = data.Mode.GetVertexData(v);
foreach(Linedef line in v.Linedefs)
{
if(line.Front != null && line.Front.Sector != null)
vd.AddUpdateSector(line.Front.Sector, false);
if(line.Back != null && line.Back.Sector != null)
vd.AddUpdateSector(line.Back.Sector, false);
}
2013-03-18 13:52:27 +00:00
data.Mode.UpdateVertexHandle(v);
index++;
}
//apply changes
if(ceilingChanged)
data.Ceiling.plane = new Plane(ceilingVerts[0], ceilingVerts[2], ceilingVerts[1], false);
if(floorChanged)
data.Floor.plane = new Plane(floorVerts[0], floorVerts[1], floorVerts[2], true);
}
}
}