Perf debug as widgets
This commit is contained in:
@@ -162,18 +162,6 @@ namespace OpenRA
|
||||
|
||||
renderer.Device.DisableScissor();
|
||||
|
||||
if (Game.Settings.PerfText)
|
||||
renderer.RegularFont.DrawText( rgbaRenderer, "RenderFrame {0} ({2:F1} ms)\nTick {4}/ Net{1} ({3:F1} ms)\n".F(
|
||||
Game.RenderFrame,
|
||||
Game.orderManager.FrameNumber,
|
||||
PerfHistory.items["render"].LastValue,
|
||||
PerfHistory.items["tick_time"].LastValue,
|
||||
Game.LocalTick),
|
||||
new int2(140, 15), Color.White);
|
||||
|
||||
if (Game.Settings.PerfGraph)
|
||||
PerfHistory.Render(renderer, world.WorldRenderer.lineRenderer);
|
||||
|
||||
DrawRadar( world );
|
||||
DrawPower( world );
|
||||
rgbaRenderer.DrawSprite(ChromeProvider.GetImage(renderer, chromeCollection, "moneybin"), new float2(Game.viewport.Width - 320, 0), "chrome");
|
||||
|
||||
@@ -297,6 +297,7 @@
|
||||
<Compile Include="Widgets\Delegates\IngameChromeDelegate.cs" />
|
||||
<Compile Include="Widgets\SpecialPowerBinWidget.cs" />
|
||||
<Compile Include="Widgets\Delegates\MusicPlayerDelegate.cs" />
|
||||
<Compile Include="Widgets\PerfGraphWidget.cs" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\OpenRA.FileFormats\OpenRA.FileFormats.csproj">
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
#region Copyright & License Information
|
||||
#region Copyright & License Information
|
||||
/*
|
||||
* Copyright 2007,2009,2010 Chris Forbes, Robert Pepperell, Matthew Bowra-Dean, Paul Chote, Alli Witheford.
|
||||
* This file is part of OpenRA.
|
||||
@@ -55,31 +55,6 @@ namespace OpenRA.Support
|
||||
if (item.hasNormalTick)
|
||||
item.Tick();
|
||||
}
|
||||
|
||||
public static void Render(Renderer r, LineRenderer lr)
|
||||
{
|
||||
float2 origin = Game.viewport.Location + new float2(330, Game.viewport.Height - 30);
|
||||
float2 basis = new float2(-3, -3);
|
||||
|
||||
lr.DrawLine(origin, origin + new float2(100, 0) * basis, Color.White, Color.White);
|
||||
lr.DrawLine(origin + new float2(100,0) * basis, origin + new float2(100,70) * basis, Color.White, Color.White);
|
||||
|
||||
foreach (var item in items.Values)
|
||||
{
|
||||
int n = 0;
|
||||
item.Samples().Aggregate((a, b) =>
|
||||
{
|
||||
lr.DrawLine(
|
||||
origin + new float2(n, (float)a) * basis,
|
||||
origin + new float2(n+1, (float)b) * basis,
|
||||
item.c, item.c);
|
||||
++n;
|
||||
return b;
|
||||
});
|
||||
}
|
||||
|
||||
lr.Flush();
|
||||
}
|
||||
}
|
||||
|
||||
class PerfItem
|
||||
|
||||
@@ -19,6 +19,8 @@
|
||||
#endregion
|
||||
using System;
|
||||
using OpenRA.FileFormats;
|
||||
using OpenRA.Support;
|
||||
|
||||
namespace OpenRA.Widgets.Delegates
|
||||
{
|
||||
public class IngameChromeDelegate : IWidgetDelegate
|
||||
@@ -26,7 +28,8 @@ namespace OpenRA.Widgets.Delegates
|
||||
public IngameChromeDelegate()
|
||||
{
|
||||
var r = Chrome.rootWidget;
|
||||
var optionsBG = r.GetWidget("INGAME_OPTIONS_BG");
|
||||
var gameRoot = r.GetWidget("INGAME_ROOT");
|
||||
var optionsBG = gameRoot.GetWidget("INGAME_OPTIONS_BG");
|
||||
r.GetWidget("INGAME_OPTIONS_BUTTON").OnMouseUp = mi => {
|
||||
optionsBG.Visible = !optionsBG.Visible;
|
||||
return true;
|
||||
@@ -49,6 +52,21 @@ namespace OpenRA.Widgets.Delegates
|
||||
return true;
|
||||
};
|
||||
|
||||
// Perf text
|
||||
var perfText = gameRoot.GetWidget<LabelWidget>("PERFTEXT");
|
||||
perfText.GetText = () => {
|
||||
return "RenderFrame {0} ({2:F1} ms)\nTick {4}/ Net{1} ({3:F1} ms)".F(
|
||||
Game.RenderFrame,
|
||||
Game.orderManager.FrameNumber,
|
||||
PerfHistory.items["render"].LastValue,
|
||||
PerfHistory.items["tick_time"].LastValue,
|
||||
Game.LocalTick);
|
||||
};
|
||||
perfText.IsVisible = () => {return (perfText.Visible && Game.Settings.PerfText);};
|
||||
|
||||
// Perf graph
|
||||
var perfGraph = gameRoot.GetWidget("PERFGRAPH");
|
||||
perfGraph.IsVisible = () => {return (perfGraph.Visible && Game.Settings.PerfGraph);};
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -19,6 +19,7 @@
|
||||
#endregion
|
||||
|
||||
using System.Drawing;
|
||||
using System;
|
||||
|
||||
namespace OpenRA.Widgets
|
||||
{
|
||||
@@ -26,26 +27,35 @@ namespace OpenRA.Widgets
|
||||
{
|
||||
public string Text = "";
|
||||
public string Align = "Left";
|
||||
public bool Bold = true;
|
||||
public Func<string> GetText;
|
||||
|
||||
public override void Initialize()
|
||||
{
|
||||
base.Initialize();
|
||||
GetText = () => {return Text;};
|
||||
}
|
||||
|
||||
public override void Draw(World world)
|
||||
{
|
||||
if (!Visible)
|
||||
if (!IsVisible())
|
||||
{
|
||||
base.Draw(world);
|
||||
return;
|
||||
}
|
||||
|
||||
Rectangle r = Bounds;
|
||||
Game.chrome.renderer.Device.EnableScissor(r.Left, r.Top, r.Width, r.Height);
|
||||
|
||||
int2 textSize = Game.chrome.renderer.BoldFont.Measure(Text);
|
||||
var font = (Bold) ? Game.chrome.renderer.BoldFont : Game.chrome.renderer.RegularFont;
|
||||
var text = GetText();
|
||||
Rectangle r = Bounds;
|
||||
Game.chrome.renderer.Device.EnableScissor(r.Left,r.Top,r.Width,r.Height);
|
||||
int2 textSize = font.Measure(text);
|
||||
int2 position = new int2(Bounds.X,Bounds.Y);
|
||||
|
||||
if (Align == "Center")
|
||||
position = new int2(Bounds.X+Bounds.Width/2, Bounds.Y+Bounds.Height/2)
|
||||
- new int2(textSize.X / 2, textSize.Y/2);
|
||||
|
||||
Game.chrome.renderer.BoldFont.DrawText(Game.chrome.rgbaRenderer, Text, position, Color.White);
|
||||
font.DrawText(Game.chrome.rgbaRenderer, text, position, Color.White);
|
||||
Game.chrome.rgbaRenderer.Flush();
|
||||
Game.chrome.renderer.Device.DisableScissor();
|
||||
base.Draw(world);
|
||||
|
||||
62
OpenRA.Game/Widgets/PerfGraphWidget.cs
Normal file
62
OpenRA.Game/Widgets/PerfGraphWidget.cs
Normal file
@@ -0,0 +1,62 @@
|
||||
#region Copyright & License Information
|
||||
/*
|
||||
* Copyright 2007,2009,2010 Chris Forbes, Robert Pepperell, Matthew Bowra-Dean, Paul Chote, Alli Witheford.
|
||||
* This file is part of OpenRA.
|
||||
*
|
||||
* OpenRA is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation, either version 3 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* OpenRA is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with OpenRA. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
#endregion
|
||||
using System.Drawing;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using OpenRA.Support;
|
||||
|
||||
namespace OpenRA.Widgets
|
||||
{
|
||||
class PerfGraphWidget : Widget
|
||||
{
|
||||
public override void Draw(World world)
|
||||
{
|
||||
if (!IsVisible())
|
||||
{
|
||||
base.Draw(world);
|
||||
return;
|
||||
}
|
||||
|
||||
float2 origin = Game.viewport.Location + new float2(Bounds.Right,Bounds.Bottom);
|
||||
float2 basis = new float2(-Bounds.Width/100,-Bounds.Height/100);
|
||||
|
||||
Game.chrome.lineRenderer.DrawLine(origin, origin + new float2(100, 0) * basis, Color.White, Color.White);
|
||||
Game.chrome.lineRenderer.DrawLine(origin + new float2(100,0) * basis, origin + new float2(100,70) * basis, Color.White, Color.White);
|
||||
|
||||
foreach (var item in PerfHistory.items.Values)
|
||||
{
|
||||
int n = 0;
|
||||
item.Samples().Aggregate((a, b) =>
|
||||
{
|
||||
Game.chrome.lineRenderer.DrawLine(
|
||||
origin + new float2(n, (float)a) * basis,
|
||||
origin + new float2(n+1, (float)b) * basis,
|
||||
item.c, item.c);
|
||||
++n;
|
||||
return b;
|
||||
});
|
||||
}
|
||||
|
||||
Game.chrome.lineRenderer.Flush();
|
||||
|
||||
base.Draw(world);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -48,6 +48,12 @@ namespace OpenRA.Widgets
|
||||
|
||||
public Widget() { InputHandler = Lazy.New(() => BindHandler(Delegate)); }
|
||||
|
||||
// Common Funcs that most widgets will want
|
||||
public Func<MouseInput,bool> OnMouseDown = mi => {return false;};
|
||||
public Func<MouseInput,bool> OnMouseUp = mi => {return false;};
|
||||
public Func<MouseInput,bool> OnMouseMove = mi => {return false;};
|
||||
public Func<bool> IsVisible;
|
||||
|
||||
public virtual void Initialize()
|
||||
{
|
||||
// Parse the YAML equations to find the widget bounds
|
||||
@@ -69,6 +75,8 @@ namespace OpenRA.Widgets
|
||||
width,
|
||||
height);
|
||||
|
||||
// Non-static func definitions
|
||||
IsVisible = () => {return Visible;};
|
||||
|
||||
foreach (var child in Children)
|
||||
child.Initialize();
|
||||
@@ -87,13 +95,7 @@ namespace OpenRA.Widgets
|
||||
if (name == null) return null;
|
||||
return Game.CreateObject<IWidgetDelegate>(name);
|
||||
}
|
||||
|
||||
// Common Funcs that most widgets will want
|
||||
public Func<MouseInput,bool> OnMouseDown = mi => {return false;};
|
||||
public Func<MouseInput,bool> OnMouseUp = mi => {return false;};
|
||||
public Func<MouseInput,bool> OnMouseMove = mi => {return false;};
|
||||
|
||||
|
||||
|
||||
public virtual bool HandleInput(MouseInput mi)
|
||||
{
|
||||
// Are we able to handle this event?
|
||||
|
||||
@@ -261,6 +261,21 @@ Container:
|
||||
Id:INGAME_ROOT
|
||||
Visible:false
|
||||
Children:
|
||||
PerfGraph@PERFGRAPH:
|
||||
Id:PERFGRAPH
|
||||
X:10
|
||||
Y:WINDOW_BOTTOM - 250
|
||||
Width:200
|
||||
Height:200
|
||||
Delegate:IngameChromeDelegate
|
||||
Label@PERFTEXT:
|
||||
Id:PERFTEXT
|
||||
Bold: false
|
||||
X:10
|
||||
Y:WINDOW_BOTTOM - 40
|
||||
Width:200
|
||||
Height:100
|
||||
Delegate:IngameChromeDelegate
|
||||
SpecialPowerBin@INGAME_POWERS_BIN:
|
||||
Id:INGAME_POWERS_BIN
|
||||
X:0
|
||||
|
||||
Reference in New Issue
Block a user