2019-12-30 23:08:17 +00:00
|
|
|
|
using System;
|
|
|
|
|
using CodeImp.DoomBuilder.Geometry;
|
2020-02-16 19:51:16 +00:00
|
|
|
|
using CodeImp.DoomBuilder.Map;
|
2019-12-30 23:08:17 +00:00
|
|
|
|
using CodeImp.DoomBuilder.Rendering;
|
|
|
|
|
|
|
|
|
|
namespace CodeImp.DoomBuilder.VisualModes
|
|
|
|
|
{
|
2021-01-30 21:01:55 +00:00
|
|
|
|
public enum VisualSlopeType
|
|
|
|
|
{
|
|
|
|
|
Line,
|
|
|
|
|
Vertex
|
|
|
|
|
}
|
|
|
|
|
|
2020-02-16 21:07:20 +00:00
|
|
|
|
public abstract class VisualSlope : IVisualPickable
|
2019-12-30 23:08:17 +00:00
|
|
|
|
{
|
|
|
|
|
#region ================== Variables
|
|
|
|
|
|
|
|
|
|
// Disposing
|
|
|
|
|
private bool isdisposed;
|
|
|
|
|
|
|
|
|
|
// Selected?
|
|
|
|
|
protected bool selected;
|
|
|
|
|
|
|
|
|
|
// Pivot?
|
|
|
|
|
protected bool pivot;
|
|
|
|
|
|
|
|
|
|
// Smart Pivot?
|
|
|
|
|
protected bool smartpivot;
|
|
|
|
|
|
|
|
|
|
// Was changed?
|
|
|
|
|
private bool changed;
|
|
|
|
|
|
2021-01-30 21:01:55 +00:00
|
|
|
|
protected VisualSlopeType type;
|
2020-05-21 12:20:02 +00:00
|
|
|
|
protected double length;
|
2019-12-30 23:08:17 +00:00
|
|
|
|
|
|
|
|
|
private Matrix position;
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
#region ================== Properties
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Selected or not? This is only used by the core to determine what color to draw it with.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public bool Selected { get { return selected; } set { selected = value; } }
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Pivot or not? This is only used by the core to determine what color to draw it with.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public bool Pivot { get { return pivot; } set { pivot = value; } }
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Disposed or not?
|
|
|
|
|
/// </summary>
|
|
|
|
|
public bool IsDisposed { get { return isdisposed; } }
|
|
|
|
|
|
|
|
|
|
public bool SmartPivot { get { return smartpivot; } set { smartpivot = value; } }
|
|
|
|
|
|
|
|
|
|
public bool Changed { get { return changed; } set { changed = value; } }
|
|
|
|
|
|
2021-01-30 21:01:55 +00:00
|
|
|
|
public VisualSlopeType Type { get { return type; } }
|
|
|
|
|
|
2020-05-21 12:20:02 +00:00
|
|
|
|
public double Length { get { return length; } }
|
2019-12-30 23:08:17 +00:00
|
|
|
|
|
|
|
|
|
public Matrix Position { get { return position; } }
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
#region ================== Constructor / Destructor
|
|
|
|
|
|
|
|
|
|
public VisualSlope()
|
|
|
|
|
{
|
|
|
|
|
pivot = false;
|
|
|
|
|
smartpivot = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
#region ================== Methods
|
|
|
|
|
|
|
|
|
|
// This is called before a device is reset (when resized or display adapter was changed)
|
|
|
|
|
public void UnloadResource()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// This is called resets when the device is reset
|
|
|
|
|
// (when resized or display adapter was changed)
|
|
|
|
|
public void ReloadResource()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// This is called when the thing must be tested for line intersection. This should reject
|
|
|
|
|
/// as fast as possible to rule out all geometry that certainly does not touch the line.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public virtual bool PickFastReject(Vector3D from, Vector3D to, Vector3D dir)
|
|
|
|
|
{
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// This is called when the thing must be tested for line intersection. This should perform
|
|
|
|
|
/// accurate hit detection and set u_ray to the position on the ray where this hits the geometry.
|
|
|
|
|
/// </summary>
|
2020-05-21 12:20:02 +00:00
|
|
|
|
public virtual bool PickAccurate(Vector3D from, Vector3D to, Vector3D dir, ref double u_ray)
|
2019-12-30 23:08:17 +00:00
|
|
|
|
{
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
2020-01-01 20:47:33 +00:00
|
|
|
|
public virtual void Update() {}
|
2021-01-30 21:01:55 +00:00
|
|
|
|
public virtual Vector3D GetPivotPoint() { return new Vector3D(); }
|
2021-02-13 08:57:09 +00:00
|
|
|
|
public virtual VisualSlope GetSmartPivotHandle() { return null; }
|
2019-12-30 23:08:17 +00:00
|
|
|
|
|
2020-02-16 19:51:16 +00:00
|
|
|
|
public void SetPosition(Line2D line, Plane plane)
|
2019-12-30 23:08:17 +00:00
|
|
|
|
{
|
2020-02-22 18:45:12 +00:00
|
|
|
|
Line3D line3d = new Line3D(new Vector3D(line.v1, plane.GetZ(line.v1)), new Vector3D(line.v2, plane.GetZ(line.v2)));
|
|
|
|
|
|
2020-02-16 21:07:20 +00:00
|
|
|
|
// This vector is perpendicular to the line, with a 90° angle between it and the plane normal
|
2020-02-22 18:45:12 +00:00
|
|
|
|
Vector3D perpendicularvector = Vector3D.CrossProduct(line3d.GetDelta().GetNormal(), plane.Normal) * (-1);
|
2020-02-16 21:07:20 +00:00
|
|
|
|
|
|
|
|
|
// This vector is on the plane, with a 90° angle to the perpendicular vector (so effectively
|
|
|
|
|
// it's on the line, but in 3D
|
2020-02-22 18:45:12 +00:00
|
|
|
|
Vector3D linevector = Vector3D.CrossProduct(plane.Normal, perpendicularvector) * (-1);
|
2020-01-18 20:10:21 +00:00
|
|
|
|
|
2020-02-16 19:51:16 +00:00
|
|
|
|
Matrix m = Matrix.Null;
|
2020-01-18 20:10:21 +00:00
|
|
|
|
|
2020-05-21 12:20:02 +00:00
|
|
|
|
m.M11 = (float)linevector.x;
|
|
|
|
|
m.M12 = (float)linevector.y;
|
|
|
|
|
m.M13 = (float)linevector.z;
|
2020-01-18 20:10:21 +00:00
|
|
|
|
|
2020-05-21 12:20:02 +00:00
|
|
|
|
m.M21 = (float)perpendicularvector.x;
|
|
|
|
|
m.M22 = (float)perpendicularvector.y;
|
|
|
|
|
m.M23 = (float)perpendicularvector.z;
|
2020-01-18 20:10:21 +00:00
|
|
|
|
|
2020-05-21 12:20:02 +00:00
|
|
|
|
m.M31 = (float)plane.Normal.x;
|
|
|
|
|
m.M32 = (float)plane.Normal.y;
|
|
|
|
|
m.M33 = (float)plane.Normal.z;
|
2020-02-16 19:51:16 +00:00
|
|
|
|
|
2020-01-18 20:10:21 +00:00
|
|
|
|
m.M44 = 1.0f;
|
|
|
|
|
|
2020-02-16 21:07:20 +00:00
|
|
|
|
// The matrix is at the 0,0 origin, so move it to the start vertex of the line
|
2020-02-16 19:51:16 +00:00
|
|
|
|
Vector3D tp = new Vector3D(line.v1, plane.GetZ(line.v1));
|
2020-01-04 21:15:13 +00:00
|
|
|
|
|
2020-02-16 19:51:16 +00:00
|
|
|
|
position = Matrix.Multiply(m, Matrix.Translation(RenderDevice.V3(tp)));
|
2019-12-30 23:08:17 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
}
|
|
|
|
|
}
|