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:
MaxED 2016-03-14 00:01:21 +00:00
parent 96fa507e9e
commit 5fde78a2c9
18 changed files with 125 additions and 166 deletions

View file

@ -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
{ {

View file

@ -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

View file

@ -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);

View file

@ -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() { }

View file

@ -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
// //

View file

@ -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;

View file

@ -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; } }
} }
} }

View file

@ -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");

View file

@ -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;
} }

View file

@ -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;

View file

@ -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;

View file

@ -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))

View file

@ -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

View file

@ -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);

View file

@ -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.

View file

@ -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))

View file

@ -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)