mirror of
https://git.do.srb2.org/STJr/UltimateZoneBuilder.git
synced 2025-01-18 22:41:46 +00:00
Added, Tag Explorer plugin, UDMF: added multiple tags support.
Changed, cosmetic: elapsed time is now displayed after resources loading finishes. Changed, internal: changed Clock.CurrentTime type to long. Fixed, Tag Statistics window: in some cases the map view was not updated after selecting items in Sectors/Linedefs/Things columns. Fixed, cosmetic: Draw Curve mode icon was missing a shadow.
This commit is contained in:
parent
96fa507e9e
commit
5fde78a2c9
18 changed files with 125 additions and 166 deletions
|
@ -100,7 +100,7 @@ namespace CodeImp.DoomBuilder.Compilers
|
||||||
if(!isdisposed)
|
if(!isdisposed)
|
||||||
{
|
{
|
||||||
Exception deleteerror;
|
Exception deleteerror;
|
||||||
float starttime = Clock.CurrentTime;
|
long starttime = Clock.CurrentTime;
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
|
|
|
@ -22,6 +22,7 @@ using System.Drawing;
|
||||||
using System.Drawing.Drawing2D;
|
using System.Drawing.Drawing2D;
|
||||||
using System.Drawing.Imaging;
|
using System.Drawing.Imaging;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
|
using System.Runtime.InteropServices;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Windows.Forms;
|
using System.Windows.Forms;
|
||||||
using CodeImp.DoomBuilder.Config;
|
using CodeImp.DoomBuilder.Config;
|
||||||
|
@ -136,8 +137,8 @@ namespace CodeImp.DoomBuilder.Data
|
||||||
private Dictionary<int, ThingTypeInfo> thingtypes;
|
private Dictionary<int, ThingTypeInfo> thingtypes;
|
||||||
|
|
||||||
// Timing
|
// Timing
|
||||||
private float loadstarttime;
|
private long loadstarttime;
|
||||||
private float loadfinishtime;
|
private long loadfinishtime;
|
||||||
|
|
||||||
// Disposing
|
// Disposing
|
||||||
private bool isdisposed;
|
private bool isdisposed;
|
||||||
|
@ -766,12 +767,6 @@ namespace CodeImp.DoomBuilder.Data
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if(notifiedbusy)
|
|
||||||
{
|
|
||||||
notifiedbusy = false;
|
|
||||||
General.SendMessage(General.MainWindow.Handle, (int)MainForm.ThreadMessages.UpdateStatus, 0, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Timing
|
// Timing
|
||||||
if(loadfinishtime == 0)
|
if(loadfinishtime == 0)
|
||||||
{
|
{
|
||||||
|
@ -782,8 +777,21 @@ namespace CodeImp.DoomBuilder.Data
|
||||||
}
|
}
|
||||||
|
|
||||||
loadfinishtime = Clock.CurrentTime;
|
loadfinishtime = Clock.CurrentTime;
|
||||||
float deltatimesec = (loadfinishtime - loadstarttime) / 1000.0f;
|
string deltatimesec = ((loadfinishtime - loadstarttime) / 1000.0f).ToString("########0.00");
|
||||||
General.WriteLogLine("Resources loading took " + deltatimesec.ToString("########0.00") + " seconds");
|
General.WriteLogLine("Resources loading took " + deltatimesec + " seconds");
|
||||||
|
|
||||||
|
//mxd. Show more detailed message
|
||||||
|
if(notifiedbusy)
|
||||||
|
{
|
||||||
|
notifiedbusy = false;
|
||||||
|
IntPtr strptr = Marshal.StringToCoTaskMemAuto(deltatimesec);
|
||||||
|
General.SendMessage(General.MainWindow.Handle, (int)MainForm.ThreadMessages.ResourcesLoaded, strptr.ToInt32(), 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(notifiedbusy) //mxd. Sould never happen (?)
|
||||||
|
{
|
||||||
|
notifiedbusy = false;
|
||||||
|
General.SendMessage(General.MainWindow.Handle, (int)MainForm.ThreadMessages.UpdateStatus, 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Wait longer to release CPU resources
|
// Wait longer to release CPU resources
|
||||||
|
|
|
@ -461,7 +461,8 @@ namespace CodeImp.DoomBuilder.Editing
|
||||||
#region ================== Processing
|
#region ================== Processing
|
||||||
|
|
||||||
// Processing
|
// Processing
|
||||||
public override void OnProcess(float deltatime)
|
public override void OnProcess(float deltatime) { OnProcess((long)deltatime); } //mxd. DB2 compatibility
|
||||||
|
public override void OnProcess(long deltatime)
|
||||||
{
|
{
|
||||||
base.OnProcess(deltatime);
|
base.OnProcess(deltatime);
|
||||||
|
|
||||||
|
|
|
@ -245,7 +245,8 @@ namespace CodeImp.DoomBuilder.Editing
|
||||||
public virtual void OnPresentDisplay() { }
|
public virtual void OnPresentDisplay() { }
|
||||||
|
|
||||||
// Processing events
|
// Processing events
|
||||||
public virtual void OnProcess(float deltatime) { }
|
public virtual void OnProcess(long deltatime) { }
|
||||||
|
public virtual void OnProcess(float deltatime) { OnProcess((long)deltatime); } //mxd. DB2 compatibility
|
||||||
|
|
||||||
// Generic events
|
// Generic events
|
||||||
public virtual void OnReloadResources() { }
|
public virtual void OnReloadResources() { }
|
||||||
|
|
|
@ -84,7 +84,6 @@
|
||||||
this.dataGridView.Size = new System.Drawing.Size(477, 256);
|
this.dataGridView.Size = new System.Drawing.Size(477, 256);
|
||||||
this.dataGridView.TabIndex = 3;
|
this.dataGridView.TabIndex = 3;
|
||||||
this.dataGridView.CellMouseClick += new System.Windows.Forms.DataGridViewCellMouseEventHandler(this.dataGridView_CellMouseClick);
|
this.dataGridView.CellMouseClick += new System.Windows.Forms.DataGridViewCellMouseEventHandler(this.dataGridView_CellMouseClick);
|
||||||
this.dataGridView.CellMouseDoubleClick += new System.Windows.Forms.DataGridViewCellMouseEventHandler(this.dataGridView_CellMouseDoubleClick);
|
|
||||||
//
|
//
|
||||||
// TagColumn
|
// TagColumn
|
||||||
//
|
//
|
||||||
|
|
|
@ -168,7 +168,7 @@ namespace CodeImp.DoomBuilder.GZBuilder.Windows
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void ShowSelection(List<Vector2D> points)
|
private static void ShowSelection(IEnumerable<Vector2D> points)
|
||||||
{
|
{
|
||||||
RectangleF area = MapSet.CreateEmptyArea();
|
RectangleF area = MapSet.CreateEmptyArea();
|
||||||
|
|
||||||
|
@ -235,13 +235,13 @@ namespace CodeImp.DoomBuilder.GZBuilder.Windows
|
||||||
int tag = (int)dataGridView.Rows[e.RowIndex].Cells[0].Value;
|
int tag = (int)dataGridView.Rows[e.RowIndex].Cells[0].Value;
|
||||||
|
|
||||||
if(e.ColumnIndex == 2) //sectors
|
if(e.ColumnIndex == 2) //sectors
|
||||||
{
|
{
|
||||||
|
// Deselect everything
|
||||||
|
General.Map.Map.ClearAllSelected();
|
||||||
|
|
||||||
List<Sector> list = GetSectorsWithTag(tag, (int)dataGridView.Rows[e.RowIndex].Cells[2].Value);
|
List<Sector> list = GetSectorsWithTag(tag, (int)dataGridView.Rows[e.RowIndex].Cells[2].Value);
|
||||||
if(list.Count > 0)
|
if(list.Count > 0)
|
||||||
{
|
{
|
||||||
General.Map.Map.ClearSelectedSectors();
|
|
||||||
General.Map.Map.ClearSelectedLinedefs();
|
|
||||||
|
|
||||||
List<Vector2D> points = new List<Vector2D>();
|
List<Vector2D> points = new List<Vector2D>();
|
||||||
General.Editing.ChangeMode("SectorsMode");
|
General.Editing.ChangeMode("SectorsMode");
|
||||||
ClassicMode mode = (ClassicMode)General.Editing.Mode;
|
ClassicMode mode = (ClassicMode)General.Editing.Mode;
|
||||||
|
@ -259,15 +259,20 @@ namespace CodeImp.DoomBuilder.GZBuilder.Windows
|
||||||
|
|
||||||
ShowSelection(points);
|
ShowSelection(points);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
General.Interface.RedrawDisplay();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if(e.ColumnIndex == 3) //linedefs
|
else if(e.ColumnIndex == 3) //linedefs
|
||||||
{
|
{
|
||||||
|
// Deselect everything
|
||||||
|
General.Map.Map.ClearAllSelected();
|
||||||
|
|
||||||
List<Linedef> list = GetLinedefsWithTag(tag, (int)dataGridView.Rows[e.RowIndex].Cells[3].Value);
|
List<Linedef> list = GetLinedefsWithTag(tag, (int)dataGridView.Rows[e.RowIndex].Cells[3].Value);
|
||||||
if(list.Count > 0)
|
if(list.Count > 0)
|
||||||
{
|
{
|
||||||
General.Map.Map.ClearSelectedSectors();
|
General.Editing.ChangeMode("LinedefsMode");
|
||||||
General.Map.Map.ClearSelectedLinedefs();
|
|
||||||
|
|
||||||
List<Vector2D> points = new List<Vector2D>();
|
List<Vector2D> points = new List<Vector2D>();
|
||||||
foreach(Linedef l in list)
|
foreach(Linedef l in list)
|
||||||
{
|
{
|
||||||
|
@ -277,19 +282,24 @@ namespace CodeImp.DoomBuilder.GZBuilder.Windows
|
||||||
}
|
}
|
||||||
|
|
||||||
General.Map.Map.Update();
|
General.Map.Map.Update();
|
||||||
General.Editing.ChangeMode("LinedefsMode");
|
|
||||||
ShowSelection(points);
|
ShowSelection(points);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
General.Interface.RedrawDisplay();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if(e.ColumnIndex == 4) //things
|
else if(e.ColumnIndex == 4) //things
|
||||||
{
|
{
|
||||||
|
// Deselect everything
|
||||||
|
General.Map.Map.ClearAllSelected();
|
||||||
|
|
||||||
List<Thing> list = GetThingsWithTag(tag, (int)dataGridView.Rows[e.RowIndex].Cells[4].Value);
|
List<Thing> list = GetThingsWithTag(tag, (int)dataGridView.Rows[e.RowIndex].Cells[4].Value);
|
||||||
if(list.Count > 0)
|
if(list.Count > 0)
|
||||||
{
|
{
|
||||||
General.Map.Map.ClearSelectedThings();
|
General.Editing.ChangeMode("ThingsMode");
|
||||||
|
|
||||||
List<Vector2D> points = new List<Vector2D>();
|
List<Vector2D> points = new List<Vector2D>();
|
||||||
foreach(Thing t in list)
|
foreach(Thing t in list)
|
||||||
{
|
{
|
||||||
t.Selected = true;
|
t.Selected = true;
|
||||||
|
|
||||||
|
@ -302,12 +312,13 @@ namespace CodeImp.DoomBuilder.GZBuilder.Windows
|
||||||
}
|
}
|
||||||
|
|
||||||
General.Map.Map.Update();
|
General.Map.Map.Update();
|
||||||
General.Editing.ChangeMode("ThingsMode");
|
|
||||||
ShowSelection(points);
|
ShowSelection(points);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
General.Interface.RedrawDisplay();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
else if(e.Button == MouseButtons.Right) //open properties window
|
else if(e.Button == MouseButtons.Right) //open properties window
|
||||||
{
|
{
|
||||||
|
@ -347,84 +358,6 @@ namespace CodeImp.DoomBuilder.GZBuilder.Windows
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void dataGridView_CellMouseDoubleClick(object sender, DataGridViewCellMouseEventArgs e)
|
|
||||||
{
|
|
||||||
if(e.ColumnIndex < 2 || e.RowIndex == -1) return;
|
|
||||||
int tag = (int)dataGridView.Rows[e.RowIndex].Cells[0].Value;
|
|
||||||
|
|
||||||
if(e.ColumnIndex == 2) //sectors
|
|
||||||
{
|
|
||||||
List<Sector> list = GetSectorsWithTag(tag, (int)dataGridView.Rows[e.RowIndex].Cells[2].Value);
|
|
||||||
if(list.Count > 0)
|
|
||||||
{
|
|
||||||
General.Map.Map.ClearSelectedSectors();
|
|
||||||
General.Map.Map.ClearSelectedLinedefs();
|
|
||||||
|
|
||||||
List<Vector2D> points = new List<Vector2D>();
|
|
||||||
foreach(Sector s in list)
|
|
||||||
{
|
|
||||||
s.Selected = true;
|
|
||||||
|
|
||||||
foreach(Sidedef sd in s.Sidedefs)
|
|
||||||
{
|
|
||||||
points.Add(sd.Line.Start.Position);
|
|
||||||
points.Add(sd.Line.End.Position);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
General.Map.Map.Update();
|
|
||||||
General.Editing.ChangeMode("SectorsMode");
|
|
||||||
ShowSelection(points);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if(e.ColumnIndex == 3) //linedefs
|
|
||||||
{
|
|
||||||
List<Linedef> list = GetLinedefsWithTag(tag, (int)dataGridView.Rows[e.RowIndex].Cells[3].Value);
|
|
||||||
if(list.Count > 0)
|
|
||||||
{
|
|
||||||
General.Map.Map.ClearSelectedSectors();
|
|
||||||
General.Map.Map.ClearSelectedLinedefs();
|
|
||||||
|
|
||||||
List<Vector2D> points = new List<Vector2D>();
|
|
||||||
foreach(Linedef l in list)
|
|
||||||
{
|
|
||||||
l.Selected = true;
|
|
||||||
points.Add(l.Start.Position);
|
|
||||||
points.Add(l.End.Position);
|
|
||||||
}
|
|
||||||
|
|
||||||
General.Map.Map.Update();
|
|
||||||
General.Editing.ChangeMode("LinedefsMode");
|
|
||||||
ShowSelection(points);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if(e.ColumnIndex == 4) //things
|
|
||||||
{
|
|
||||||
List<Thing> list = GetThingsWithTag(tag, (int)dataGridView.Rows[e.RowIndex].Cells[4].Value);
|
|
||||||
if(list.Count > 0)
|
|
||||||
{
|
|
||||||
General.Map.Map.ClearSelectedThings();
|
|
||||||
|
|
||||||
List<Vector2D> points = new List<Vector2D>();
|
|
||||||
foreach(Thing t in list)
|
|
||||||
{
|
|
||||||
t.Selected = true;
|
|
||||||
|
|
||||||
Vector2D p = t.Position;
|
|
||||||
points.Add(p);
|
|
||||||
points.Add(p + new Vector2D(t.Size * 2.0f, t.Size * 2.0f));
|
|
||||||
points.Add(p + new Vector2D(t.Size * 2.0f, -t.Size * 2.0f));
|
|
||||||
points.Add(p + new Vector2D(-t.Size * 2.0f, t.Size * 2.0f));
|
|
||||||
points.Add(p + new Vector2D(-t.Size * 2.0f, -t.Size * 2.0f));
|
|
||||||
}
|
|
||||||
|
|
||||||
General.Map.Map.Update();
|
|
||||||
General.Editing.ChangeMode("ThingsMode");
|
|
||||||
ShowSelection(points);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void TagStatisticsForm_FormClosing(object sender, FormClosingEventArgs e)
|
private void TagStatisticsForm_FormClosing(object sender, FormClosingEventArgs e)
|
||||||
{
|
{
|
||||||
size = this.Size;
|
size = this.Size;
|
||||||
|
|
|
@ -21,6 +21,6 @@ namespace CodeImp.DoomBuilder
|
||||||
public static class Clock
|
public static class Clock
|
||||||
{
|
{
|
||||||
// This queries the system for the current time
|
// This queries the system for the current time
|
||||||
public static float CurrentTime { get { return Configuration.Timer.ElapsedMilliseconds; } }
|
public static long CurrentTime { get { return Configuration.Timer.ElapsedMilliseconds; } }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3155,7 +3155,7 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
{
|
{
|
||||||
Dictionary<uint, List<Sidedef>> storedsides = new Dictionary<uint, List<Sidedef>>(numsidedefs);
|
Dictionary<uint, List<Sidedef>> storedsides = new Dictionary<uint, List<Sidedef>>(numsidedefs);
|
||||||
int originalsidescount = numsidedefs;
|
int originalsidescount = numsidedefs;
|
||||||
float starttime = Clock.CurrentTime;
|
long starttime = Clock.CurrentTime;
|
||||||
|
|
||||||
BeginAddRemove();
|
BeginAddRemove();
|
||||||
|
|
||||||
|
@ -3242,7 +3242,7 @@ namespace CodeImp.DoomBuilder.Map
|
||||||
EndAddRemove();
|
EndAddRemove();
|
||||||
|
|
||||||
// Output info
|
// Output info
|
||||||
float endtime = Clock.CurrentTime;
|
long endtime = Clock.CurrentTime;
|
||||||
float deltatimesec = (endtime - starttime) / 1000.0f;
|
float deltatimesec = (endtime - starttime) / 1000.0f;
|
||||||
float ratio = 100.0f - ((numsidedefs / (float)originalsidescount) * 100.0f);
|
float ratio = 100.0f - ((numsidedefs / (float)originalsidescount) * 100.0f);
|
||||||
General.WriteLogLine("Sidedefs compressed: " + numsidedefs + " remaining out of " + originalsidescount + " (" + ratio.ToString("########0.00") + "%) in " + deltatimesec.ToString("########0.00") + " seconds");
|
General.WriteLogLine("Sidedefs compressed: " + numsidedefs + " remaining out of " + originalsidescount + " (" + ratio.ToString("########0.00") + "%) in " + deltatimesec.ToString("########0.00") + " seconds");
|
||||||
|
|
|
@ -338,7 +338,7 @@ namespace CodeImp.DoomBuilder.Rendering
|
||||||
// Highlight
|
// Highlight
|
||||||
if(General.Settings.AnimateVisualSelection)
|
if(General.Settings.AnimateVisualSelection)
|
||||||
{
|
{
|
||||||
float time = Clock.CurrentTime;
|
long time = Clock.CurrentTime;
|
||||||
highlightglow = (float)Math.Sin(time / 100.0f) * 0.1f + 0.4f;
|
highlightglow = (float)Math.Sin(time / 100.0f) * 0.1f + 0.4f;
|
||||||
highlightglowinv = -highlightglow + 0.8f;
|
highlightglowinv = -highlightglow + 0.8f;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1099,10 +1099,9 @@ namespace CodeImp.DoomBuilder.VisualModes
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// While this mode is active, this is called continuously to process whatever needs processing.
|
/// While this mode is active, this is called continuously to process whatever needs processing.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public override void OnProcess(float deltatime)
|
public override void OnProcess(float deltatime) { OnProcess((long)deltatime); } //mxd. DB2 compatibility
|
||||||
|
public override void OnProcess(long deltatime)
|
||||||
{
|
{
|
||||||
float multiplier;
|
|
||||||
|
|
||||||
base.OnProcess(deltatime);
|
base.OnProcess(deltatime);
|
||||||
|
|
||||||
// Camera vectors
|
// Camera vectors
|
||||||
|
@ -1113,6 +1112,7 @@ namespace CodeImp.DoomBuilder.VisualModes
|
||||||
Vector3D upvec = new Vector3D(0.0f, 0.0f, 1.0f);
|
Vector3D upvec = new Vector3D(0.0f, 0.0f, 1.0f);
|
||||||
|
|
||||||
// Move the camera
|
// Move the camera
|
||||||
|
float multiplier;
|
||||||
if(General.Interface.ShiftState) multiplier = MOVE_SPEED_MULTIPLIER * 2.0f; else multiplier = MOVE_SPEED_MULTIPLIER;
|
if(General.Interface.ShiftState) multiplier = MOVE_SPEED_MULTIPLIER * 2.0f; else multiplier = MOVE_SPEED_MULTIPLIER;
|
||||||
if(keyforward) camdeltapos += camvec * cammovemul * General.Settings.MoveSpeed * multiplier * deltatime;
|
if(keyforward) camdeltapos += camvec * cammovemul * General.Settings.MoveSpeed * multiplier * deltatime;
|
||||||
if(keybackward) camdeltapos -= camvec * cammovemul * General.Settings.MoveSpeed * multiplier * deltatime;
|
if(keybackward) camdeltapos -= camvec * cammovemul * General.Settings.MoveSpeed * multiplier * deltatime;
|
||||||
|
|
|
@ -653,7 +653,7 @@ namespace CodeImp.DoomBuilder.VisualModes
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
float time = Clock.CurrentTime;
|
long time = Clock.CurrentTime;
|
||||||
float rMin = Math.Min(lightPrimaryRadius, lightSecondaryRadius);
|
float rMin = Math.Min(lightPrimaryRadius, lightSecondaryRadius);
|
||||||
float rMax = Math.Max(lightPrimaryRadius, lightSecondaryRadius);
|
float rMax = Math.Max(lightPrimaryRadius, lightSecondaryRadius);
|
||||||
float diff = rMax - rMin;
|
float diff = rMax - rMin;
|
||||||
|
|
|
@ -90,6 +90,9 @@ namespace CodeImp.DoomBuilder.Windows
|
||||||
|
|
||||||
//mxd. This is sent by the background thread when sprites are loaded
|
//mxd. This is sent by the background thread when sprites are loaded
|
||||||
SpriteDataLoaded = General.WM_USER + 3,
|
SpriteDataLoaded = General.WM_USER + 3,
|
||||||
|
|
||||||
|
//mxd. This is sent by the background thread when all resources are loaded
|
||||||
|
ResourcesLoaded = General.WM_USER + 4,
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
@ -156,7 +159,7 @@ namespace CodeImp.DoomBuilder.Windows
|
||||||
|
|
||||||
// Processing
|
// Processing
|
||||||
private int processingcount;
|
private int processingcount;
|
||||||
private float lastupdatetime;
|
private long lastupdatetime;
|
||||||
|
|
||||||
// Updating
|
// Updating
|
||||||
private int lockupdatecount;
|
private int lockupdatecount;
|
||||||
|
@ -3900,6 +3903,12 @@ namespace CodeImp.DoomBuilder.Windows
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case (int)ThreadMessages.ResourcesLoaded: //mxd
|
||||||
|
string loadtime = Marshal.PtrToStringAuto(m.WParam);
|
||||||
|
Marshal.FreeCoTaskMem(m.WParam);
|
||||||
|
DisplayStatus(StatusType.Info, "Resources loaded in " + loadtime + " seconds");
|
||||||
|
break;
|
||||||
|
|
||||||
case General.WM_SYSCOMMAND:
|
case General.WM_SYSCOMMAND:
|
||||||
// We don't want to open a menu when ALT is pressed
|
// We don't want to open a menu when ALT is pressed
|
||||||
if(m.WParam.ToInt32() != General.SC_KEYMENU)
|
if(m.WParam.ToInt32() != General.SC_KEYMENU)
|
||||||
|
@ -4034,8 +4043,8 @@ namespace CodeImp.DoomBuilder.Windows
|
||||||
// Processor event
|
// Processor event
|
||||||
private void processor_Tick(object sender, EventArgs e)
|
private void processor_Tick(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
float curtime = Clock.CurrentTime;
|
long curtime = Clock.CurrentTime;
|
||||||
float deltatime = curtime - lastupdatetime;
|
long deltatime = curtime - lastupdatetime;
|
||||||
lastupdatetime = curtime;
|
lastupdatetime = curtime;
|
||||||
|
|
||||||
if((General.Map != null) && (General.Editing.Mode != null))
|
if((General.Map != null) && (General.Editing.Mode != null))
|
||||||
|
|
|
@ -54,7 +54,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
|
||||||
// Flash polygon
|
// Flash polygon
|
||||||
private FlatVertex[] flashpolygon;
|
private FlatVertex[] flashpolygon;
|
||||||
private float flashintensity;
|
private float flashintensity;
|
||||||
private float flashstarttime;
|
private long flashstarttime;
|
||||||
|
|
||||||
// Interface
|
// Interface
|
||||||
protected bool editpressed;
|
protected bool editpressed;
|
||||||
|
@ -498,7 +498,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
|
||||||
}
|
}
|
||||||
|
|
||||||
// Processing
|
// Processing
|
||||||
public override void OnProcess(float deltatime)
|
public override void OnProcess(long deltatime)
|
||||||
{
|
{
|
||||||
base.OnProcess(deltatime);
|
base.OnProcess(deltatime);
|
||||||
|
|
||||||
|
@ -506,7 +506,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
|
||||||
if(flashpolygon != null)
|
if(flashpolygon != null)
|
||||||
{
|
{
|
||||||
// Determine the intensity of the flash by time elapsed
|
// Determine the intensity of the flash by time elapsed
|
||||||
float curtime = Clock.CurrentTime;
|
long curtime = Clock.CurrentTime;
|
||||||
flashintensity = 1f - ((curtime - flashstarttime) / FLASH_DURATION);
|
flashintensity = 1f - ((curtime - flashstarttime) / FLASH_DURATION);
|
||||||
if(flashintensity > 0.0f)
|
if(flashintensity > 0.0f)
|
||||||
{
|
{
|
||||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 3 KiB After Width: | Height: | Size: 1.4 KiB |
|
@ -48,7 +48,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
|
||||||
{
|
{
|
||||||
#region ================== Constants
|
#region ================== Constants
|
||||||
// Object picking
|
// Object picking
|
||||||
private const float PICK_INTERVAL = 80.0f;
|
private const long PICK_INTERVAL = 80;
|
||||||
private const float PICK_RANGE = 0.98f;
|
private const float PICK_RANGE = 0.98f;
|
||||||
|
|
||||||
// Gravity
|
// Gravity
|
||||||
|
@ -65,7 +65,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
|
||||||
|
|
||||||
// Object picking
|
// Object picking
|
||||||
private VisualPickResult target;
|
private VisualPickResult target;
|
||||||
private float lastpicktime;
|
private long lastpicktime;
|
||||||
private bool locktarget;
|
private bool locktarget;
|
||||||
private bool useSelectionFromClassicMode;//mxd
|
private bool useSelectionFromClassicMode;//mxd
|
||||||
private readonly Timer selectioninfoupdatetimer; //mxd
|
private readonly Timer selectioninfoupdatetimer; //mxd
|
||||||
|
@ -1111,7 +1111,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
|
||||||
}
|
}
|
||||||
|
|
||||||
// Processing
|
// Processing
|
||||||
public override void OnProcess(float deltatime)
|
public override void OnProcess(long deltatime)
|
||||||
{
|
{
|
||||||
// Process things?
|
// Process things?
|
||||||
base.ProcessThings = (BuilderPlug.Me.ShowVisualThings != 0);
|
base.ProcessThings = (BuilderPlug.Me.ShowVisualThings != 0);
|
||||||
|
|
|
@ -144,9 +144,9 @@ namespace CodeImp.DoomBuilder.TagExplorer
|
||||||
string comment = "";
|
string comment = "";
|
||||||
string serachStr = tbSearch.Text.ToLowerInvariant();
|
string serachStr = tbSearch.Text.ToLowerInvariant();
|
||||||
|
|
||||||
List<int> filteredtags = new List<int>();
|
HashSet<int> filteredtags = new HashSet<int>();
|
||||||
List<int> filteredactions = new List<int>();
|
HashSet<int> filteredactions = new HashSet<int>();
|
||||||
List<int> filteredpolyobjects = new List<int>();
|
HashSet<int> filteredpolyobjects = new HashSet<int>();
|
||||||
GetSpecialValues(serachStr, ref filteredtags, ref filteredactions, ref filteredpolyobjects);
|
GetSpecialValues(serachStr, ref filteredtags, ref filteredactions, ref filteredpolyobjects);
|
||||||
|
|
||||||
if(!udmf || filteredtags.Count > 0 || filteredactions.Count > 0 || filteredpolyobjects.Count > 0)
|
if(!udmf || filteredtags.Count > 0 || filteredactions.Count > 0 || filteredpolyobjects.Count > 0)
|
||||||
|
@ -333,23 +333,25 @@ namespace CodeImp.DoomBuilder.TagExplorer
|
||||||
{
|
{
|
||||||
if((showTags && s.Tag != 0) || (showActions && s.Effect > 0))
|
if((showTags && s.Tag != 0) || (showActions && s.Effect > 0))
|
||||||
{
|
{
|
||||||
if(filteredtags.Count > 0 && !filteredtags.Contains(s.Tag)) continue;
|
|
||||||
if(filteredactions.Count > 0 && !filteredactions.Contains(s.Effect)) continue;
|
if(filteredactions.Count > 0 && !filteredactions.Contains(s.Effect)) continue;
|
||||||
|
for(int i = 0; i < s.Tags.Count; i++)
|
||||||
NodeInfo info = new NodeInfo(s);
|
|
||||||
string name = info.GetName(ref comment, currentSortMode);
|
|
||||||
hasComment = comment.Length > 0;
|
|
||||||
|
|
||||||
if(!hasComment && cbCommentsOnly.Checked) continue;
|
|
||||||
|
|
||||||
if(!udmf || serachStr.Length == 0 || (hasComment && comment.ToLowerInvariant().IndexOf(serachStr) != -1))
|
|
||||||
{
|
{
|
||||||
TreeNode node = new TreeNode(name, 3, 3) { Tag = info, ToolTipText = nodetooltip };
|
if(filteredtags.Count > 0 && !filteredtags.Contains(s.Tags[i])) continue;
|
||||||
if(hasComment) node.ForeColor = commentColor;
|
|
||||||
nodes.Add(node);
|
|
||||||
|
|
||||||
if(info.Index == selection.Index && info.Type == selection.Type)
|
NodeInfo info = new NodeInfo(s, i);
|
||||||
selectedNode = node;
|
string name = info.GetName(ref comment, currentSortMode);
|
||||||
|
hasComment = comment.Length > 0;
|
||||||
|
|
||||||
|
if(!hasComment && cbCommentsOnly.Checked) continue;
|
||||||
|
if(!udmf || serachStr.Length == 0 || (hasComment && comment.ToLowerInvariant().IndexOf(serachStr) != -1))
|
||||||
|
{
|
||||||
|
TreeNode node = new TreeNode(name, 3, 3) { Tag = info, ToolTipText = nodetooltip };
|
||||||
|
if(hasComment) node.ForeColor = commentColor;
|
||||||
|
nodes.Add(node);
|
||||||
|
|
||||||
|
if(info.Index == selection.Index && info.Type == selection.Type)
|
||||||
|
selectedNode = node;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -449,31 +451,34 @@ namespace CodeImp.DoomBuilder.TagExplorer
|
||||||
{
|
{
|
||||||
if((showTags && l.Tag != 0) || (showActions && l.Action > 0))
|
if((showTags && l.Tag != 0) || (showActions && l.Action > 0))
|
||||||
{
|
{
|
||||||
if(filteredtags.Count > 0 && !filteredtags.Contains(l.Tag)) continue;
|
|
||||||
if(filteredactions.Count > 0 && !filteredactions.Contains(l.Action)) continue;
|
if(filteredactions.Count > 0 && !filteredactions.Contains(l.Action)) continue;
|
||||||
|
|
||||||
NodeInfo info = new NodeInfo(l);
|
NodeInfo firstinfo = new NodeInfo(l, 0);
|
||||||
if(filteredpolyobjects.Count > 0 && !filteredpolyobjects.Contains(info.PolyobjectNumber))
|
if(filteredpolyobjects.Count > 0 && !filteredpolyobjects.Contains(firstinfo.PolyobjectNumber)) continue;
|
||||||
continue;
|
|
||||||
|
|
||||||
string name = info.GetName(ref comment, currentSortMode);
|
for(int i = 0; i < l.Tags.Count; i++)
|
||||||
hasComment = comment.Length > 0;
|
|
||||||
|
|
||||||
if(!hasComment && cbCommentsOnly.Checked) continue;
|
|
||||||
|
|
||||||
if(!udmf || serachStr.Length == 0 || (hasComment && comment.ToLowerInvariant().IndexOf(serachStr) != -1))
|
|
||||||
{
|
{
|
||||||
TreeNode node = new TreeNode(name, 5, 5) { Tag = info, ToolTipText = nodetooltip };
|
if(filteredtags.Count > 0 && !filteredtags.Contains(l.Tags[i])) continue;
|
||||||
if(hasComment) node.ForeColor = commentColor;
|
|
||||||
nodes.Add(node);
|
|
||||||
|
|
||||||
if(info.Index == selection.Index && info.Type == selection.Type)
|
NodeInfo info = new NodeInfo(l, i);
|
||||||
selectedNode = node;
|
string name = info.GetName(ref comment, currentSortMode);
|
||||||
|
hasComment = comment.Length > 0;
|
||||||
|
|
||||||
|
if(!hasComment && cbCommentsOnly.Checked) continue;
|
||||||
|
if(!udmf || serachStr.Length == 0 || (hasComment && comment.ToLowerInvariant().IndexOf(serachStr) != -1))
|
||||||
|
{
|
||||||
|
TreeNode node = new TreeNode(name, 5, 5) { Tag = info, ToolTipText = nodetooltip };
|
||||||
|
if(hasComment) node.ForeColor = commentColor;
|
||||||
|
nodes.Add(node);
|
||||||
|
|
||||||
|
if(info.Index == selection.Index && info.Type == selection.Type)
|
||||||
|
selectedNode = node;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(currentDisplayMode == DISPLAY_POLYOBJECTS)
|
else if(currentDisplayMode == DISPLAY_POLYOBJECTS)
|
||||||
{
|
{
|
||||||
NodeInfo info = new NodeInfo(l);
|
NodeInfo info = new NodeInfo(l, 0);
|
||||||
if(info.PolyobjectNumber != int.MinValue && (filteredpolyobjects.Count == 0 || filteredpolyobjects.Contains(info.PolyobjectNumber)))
|
if(info.PolyobjectNumber != int.MinValue && (filteredpolyobjects.Count == 0 || filteredpolyobjects.Contains(info.PolyobjectNumber)))
|
||||||
{
|
{
|
||||||
string name = info.GetName(ref comment, SortMode.SORT_BY_POLYOBJ_NUMBER);
|
string name = info.GetName(ref comment, SortMode.SORT_BY_POLYOBJ_NUMBER);
|
||||||
|
@ -584,7 +589,7 @@ namespace CodeImp.DoomBuilder.TagExplorer
|
||||||
}
|
}
|
||||||
|
|
||||||
//tag/action search
|
//tag/action search
|
||||||
private static void GetSpecialValues(string serachstr, ref List<int> filteredtags, ref List<int> filteredactions, ref List<int> filteredpolyobjects)
|
private static void GetSpecialValues(string serachstr, ref HashSet<int> filteredtags, ref HashSet<int> filteredactions, ref HashSet<int> filteredpolyobjects)
|
||||||
{
|
{
|
||||||
if(serachstr.Length == 0) return;
|
if(serachstr.Length == 0) return;
|
||||||
|
|
||||||
|
@ -916,6 +921,9 @@ namespace CodeImp.DoomBuilder.TagExplorer
|
||||||
if(e.Label != null) info.Comment = e.Label;
|
if(e.Label != null) info.Comment = e.Label;
|
||||||
e.Node.Text = info.GetName(ref comment, currentSortMode);
|
e.Node.Text = info.GetName(ref comment, currentSortMode);
|
||||||
e.Node.ForeColor = string.IsNullOrEmpty(info.Comment) ? Color.Black : commentColor;
|
e.Node.ForeColor = string.IsNullOrEmpty(info.Comment) ? Color.Black : commentColor;
|
||||||
|
|
||||||
|
// Because of multiple tags, several nodes can link to the same sector/linedef
|
||||||
|
UpdateTree(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
//It is called every time a dialog window closes.
|
//It is called every time a dialog window closes.
|
||||||
|
|
|
@ -34,12 +34,12 @@ namespace CodeImp.DoomBuilder.TagExplorer
|
||||||
defaultName = (tti != null ? tti.Title : "Thing");
|
defaultName = (tti != null ? tti.Title : "Thing");
|
||||||
}
|
}
|
||||||
|
|
||||||
public NodeInfo(Sector s)
|
public NodeInfo(Sector s, int tagindex)
|
||||||
{
|
{
|
||||||
type = NodeInfoType.SECTOR;
|
type = NodeInfoType.SECTOR;
|
||||||
index = s.Index;
|
index = s.Index;
|
||||||
action = s.Effect;
|
action = s.Effect;
|
||||||
tag = s.Tag;
|
tag = s.Tags[tagindex];
|
||||||
|
|
||||||
if(General.Map.Config.SectorEffects.ContainsKey(action))
|
if(General.Map.Config.SectorEffects.ContainsKey(action))
|
||||||
{
|
{
|
||||||
|
@ -51,12 +51,12 @@ namespace CodeImp.DoomBuilder.TagExplorer
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public NodeInfo(Linedef l)
|
public NodeInfo(Linedef l, int tagindex)
|
||||||
{
|
{
|
||||||
type = NodeInfoType.LINEDEF;
|
type = NodeInfoType.LINEDEF;
|
||||||
index = l.Index;
|
index = l.Index;
|
||||||
action = l.Action;
|
action = l.Action;
|
||||||
tag = l.Tag;
|
tag = l.Tags[tagindex];
|
||||||
polyobjnumber = ((l.Action > 0 && l.Action < 9) ? l.Args[0] : int.MinValue);
|
polyobjnumber = ((l.Action > 0 && l.Action < 9) ? l.Args[0] : int.MinValue);
|
||||||
|
|
||||||
if(General.Map.Config.LinedefActions.ContainsKey(l.Action))
|
if(General.Map.Config.LinedefActions.ContainsKey(l.Action))
|
||||||
|
|
|
@ -380,7 +380,7 @@ namespace CodeImp.DoomBuilder.Plugins.VisplaneExplorer
|
||||||
}
|
}
|
||||||
|
|
||||||
// Processing
|
// Processing
|
||||||
public override void OnProcess(float deltatime)
|
public override void OnProcess(long deltatime)
|
||||||
{
|
{
|
||||||
base.OnProcess(deltatime);
|
base.OnProcess(deltatime);
|
||||||
if(DateTime.Now >= nextupdate)
|
if(DateTime.Now >= nextupdate)
|
||||||
|
|
Loading…
Reference in a new issue