Changed GUIMessageBox.MessageBoxes from a queue to a list to make it easier to remove messageboxes that aren't currently visible, fixed clients creating multiple "permissions changed" messageboxes if there's another messagebox on the screen

This commit is contained in:
Regalis
2017-02-18 15:58:46 +02:00
parent 6c8f5b8999
commit 04f86865f7
7 changed files with 27 additions and 51 deletions
+9 -18
View File
@@ -480,11 +480,10 @@ namespace Barotrauma
DrawMessages(spriteBatch, (float)deltaTime);
if (GUIMessageBox.MessageBoxes.Count>0)
if (GUIMessageBox.VisibleBox != null)
{
var messageBox = GUIMessageBox.MessageBoxes.Peek();
if (messageBox != null) messageBox.Draw(spriteBatch);
}
GUIMessageBox.VisibleBox.Draw(spriteBatch);
}
if (pauseMenuOpen)
{
@@ -516,14 +515,10 @@ namespace Barotrauma
GameMain.Config.SettingsFrame.AddToGUIUpdateList();
}
if (GUIMessageBox.MessageBoxes.Count > 0)
if (GUIMessageBox.VisibleBox != null)
{
var messageBox = GUIMessageBox.MessageBoxes.Peek();
if (messageBox != null)
{
messageBox.AddToGUIUpdateList();
}
}
GUIMessageBox.VisibleBox.AddToGUIUpdateList();
}
}
public static void Update(float deltaTime)
@@ -538,14 +533,10 @@ namespace Barotrauma
GameMain.Config.SettingsFrame.Update(deltaTime);
}
if (GUIMessageBox.MessageBoxes.Count > 0)
if (GUIMessageBox.VisibleBox != null)
{
var messageBox = GUIMessageBox.MessageBoxes.Peek();
if (messageBox != null)
{
messageBox.Update(deltaTime);
}
}
GUIMessageBox.VisibleBox.Update(deltaTime);
}
}
public static void AddMessage(string message, Color color, float lifeTime = 3.0f, bool playSound = true)
+4 -4
View File
@@ -5,7 +5,7 @@ namespace Barotrauma
{
public class GUIMessageBox : GUIFrame
{
public static Queue<GUIComponent> MessageBoxes = new Queue<GUIComponent>();
public static List<GUIComponent> MessageBoxes = new List<GUIComponent>();
const int DefaultWidth=400, DefaultHeight=250;
@@ -17,7 +17,7 @@ namespace Barotrauma
public static GUIComponent VisibleBox
{
get { return MessageBoxes.Count==0 ? null : MessageBoxes.Peek(); }
get { return MessageBoxes.Count == 0 ? null : MessageBoxes[0]; }
}
public string Text
@@ -60,7 +60,7 @@ namespace Barotrauma
x += this.Buttons[i].Rect.Width + 20;
}
MessageBoxes.Enqueue(this);
MessageBoxes.Add(this);
}
@@ -68,7 +68,7 @@ namespace Barotrauma
public bool Close(GUIButton button, object obj)
{
if (parent != null) parent.RemoveChild(this);
if (MessageBoxes.Contains(this)) MessageBoxes.Dequeue();
if (MessageBoxes.Contains(this)) MessageBoxes.Remove(this);
return true;
}