diff --git a/OpenRa.Game/Graphics/Renderer.cs b/OpenRa.Game/Graphics/Renderer.cs
index 68a87b7ff6..281c37427d 100644
--- a/OpenRa.Game/Graphics/Renderer.cs
+++ b/OpenRa.Game/Graphics/Renderer.cs
@@ -3,6 +3,7 @@ using System.Windows.Forms;
using OpenRa.GlRenderer;
using OpenRa.FileFormats;
using OpenRa.Support;
+using System.Drawing.Drawing2D;
namespace OpenRa.Graphics
{
@@ -19,8 +20,11 @@ namespace OpenRa.Graphics
public Texture PaletteTexture;
- //readonly SpriteHelper sh;
- //readonly FontHelper fhDebug, fhTitle;
+ readonly Font fDebug, fTitle;
+
+ Sheet textSheet;
+ SpriteRenderer rgbaRenderer;
+ Sprite textSprite;
public Renderer(Control control, Size resolution, bool windowed)
{
@@ -36,9 +40,28 @@ namespace OpenRa.Graphics
WorldSpriteShader = new Shader(device, FileSystem.Open("chrome-shp.fx"));
WorldSpriteShader.Quality = ShaderQuality.High;
- //sh = new SpriteHelper(device);
- //fhDebug = new FontHelper(device, "Tahoma", 10, false);
- //fhTitle = new FontHelper(device, "Tahoma", 10, true);
+ fDebug = new Font("Tahoma", 10, FontStyle.Regular);
+ fTitle = new Font("Tahoma", 10, FontStyle.Bold);
+ textSheet = new Sheet(this, new Size(256, 256));
+ rgbaRenderer = new SpriteRenderer(this, true, RgbaSpriteShader);
+ textSprite = new Sprite(textSheet, new Rectangle(0, 0, 256, 256), TextureChannel.Alpha);
+ }
+
+ Bitmap RenderTextToBitmap(string s, Font f, Color c)
+ {
+ Bitmap b = new Bitmap(256, 256);
+ System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(b);
+ g.DrawString(s, f, new SolidBrush(c), 0, 0);
+ g.Flush();
+ g.Dispose();
+ return b;
+ }
+
+ int2 GetTextSize(string s, Font f)
+ {
+ Bitmap b = new Bitmap(1,1);
+ System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(b);
+ return new int2(g.MeasureString(s, f).ToSize());
}
public GraphicsDevice Device { get { return device; } }
@@ -101,26 +124,28 @@ namespace OpenRa.Graphics
public void DrawText(string text, int2 pos, Color c)
{
- //sh.Begin();
- //fhDebug.Draw(sh, text, pos.X, pos.Y, c.ToArgb());
- //sh.End();
+ Bitmap b = RenderTextToBitmap(text, fDebug, c);
+ textSheet.Texture.SetData(b);
+ rgbaRenderer.DrawSprite(textSprite, pos.ToFloat2(), "chrome");
+ rgbaRenderer.Flush();
}
public void DrawText2(string text, int2 pos, Color c)
{
- //sh.Begin();
- //fhTitle.Draw(sh, text, pos.X, pos.Y, c.ToArgb());
- //sh.End();
+ Bitmap b = RenderTextToBitmap(text, fTitle, c);
+ textSheet.Texture.SetData(b);
+ rgbaRenderer.DrawSprite(textSprite, pos.ToFloat2(), "chrome");
+ rgbaRenderer.Flush();
}
public int2 MeasureText(string text)
{
- return new int2(20,20);//fhDebug.MeasureText(sh, text));
+ return GetTextSize(text, fDebug);
}
public int2 MeasureText2(string text)
{
- return new int2(20,20);//fhTitle.MeasureText(sh, text));
+ return GetTextSize(text, fTitle);
}
}
}
diff --git a/OpenRa.Game/OpenRa.Game.csproj b/OpenRa.Game/OpenRa.Game.csproj
index dcd8c0dd58..a7f4c3375f 100644
--- a/OpenRa.Game/OpenRa.Game.csproj
+++ b/OpenRa.Game/OpenRa.Game.csproj
@@ -34,7 +34,7 @@
OpenRA.ico
-
+
true
bin\Debug\
TRACE;DEBUG;SANITY_CHECKS
@@ -44,13 +44,13 @@
false
prompt
-
+
bin\Release\
TRACE
true
true
pdbonly
- AnyCPU
+ x86
false
prompt
diff --git a/OpenRa.sln b/OpenRa.sln
index fa15da7fb8..3b35fb71cd 100644
--- a/OpenRa.sln
+++ b/OpenRa.sln
@@ -27,10 +27,9 @@ Global
{BDAEAB25-991E-46A7-AF1E-4F0E03358DAA}.Debug|Any CPU.Build.0 = Debug|Any CPU
{BDAEAB25-991E-46A7-AF1E-4F0E03358DAA}.Release|Any CPU.ActiveCfg = Release|Any CPU
{BDAEAB25-991E-46A7-AF1E-4F0E03358DAA}.Release|Any CPU.Build.0 = Release|Any CPU
- {0DFB103F-2962-400F-8C6D-E2C28CCBA633}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
- {0DFB103F-2962-400F-8C6D-E2C28CCBA633}.Debug|Any CPU.Build.0 = Debug|Any CPU
- {0DFB103F-2962-400F-8C6D-E2C28CCBA633}.Release|Any CPU.ActiveCfg = Release|Any CPU
- {0DFB103F-2962-400F-8C6D-E2C28CCBA633}.Release|Any CPU.Build.0 = Release|Any CPU
+ {0DFB103F-2962-400F-8C6D-E2C28CCBA633}.Debug|Any CPU.ActiveCfg = Debug|x86
+ {0DFB103F-2962-400F-8C6D-E2C28CCBA633}.Debug|Any CPU.Build.0 = Debug|x86
+ {0DFB103F-2962-400F-8C6D-E2C28CCBA633}.Release|Any CPU.ActiveCfg = Release|x86
{230F65CE-A6DE-4235-8B38-13A3D606C7F7}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{230F65CE-A6DE-4235-8B38-13A3D606C7F7}.Debug|Any CPU.Build.0 = Debug|Any CPU
{230F65CE-A6DE-4235-8B38-13A3D606C7F7}.Release|Any CPU.ActiveCfg = Release|Any CPU