From 2bdf2e9828eb6e63a69626a34f490d5508709528 Mon Sep 17 00:00:00 2001 From: the_fiddler Date: Sat, 30 May 2009 17:35:42 +0000 Subject: [PATCH] Added workaround for broken Mono GDI+ text offset. Commented-out unused code. --- Source/Examples/ExampleBrowser.cs | 2 +- .../Graphics/Text/GdiPlusGlyphRasterizer.cs | 16 ++++++++++++++++ 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/Source/Examples/ExampleBrowser.cs b/Source/Examples/ExampleBrowser.cs index 5196342a..5edd3f7a 100644 --- a/Source/Examples/ExampleBrowser.cs +++ b/Source/Examples/ExampleBrowser.cs @@ -12,7 +12,7 @@ namespace Examples { #region Fields - PrivateFontCollection font_collection = new PrivateFontCollection(); + //PrivateFontCollection font_collection = new PrivateFontCollection(); #endregion diff --git a/Source/Utilities/Graphics/Text/GdiPlusGlyphRasterizer.cs b/Source/Utilities/Graphics/Text/GdiPlusGlyphRasterizer.cs index 1f0ab25b..aa9fc60d 100644 --- a/Source/Utilities/Graphics/Text/GdiPlusGlyphRasterizer.cs +++ b/Source/Utilities/Graphics/Text/GdiPlusGlyphRasterizer.cs @@ -385,6 +385,22 @@ namespace OpenTK.Graphics.Text } } + // Mono's GDI+ implementation suffers from an issue where the specified layoutRect is not taken into + // account. We will try to improve the situation by moving text to the correct location on this + // error condition. This will not help word wrapping, but it is better than nothing. + // Todo: Mono 2.8 is supposed to ship with a Pango-based GDI+ text renderer, which should not + // suffer from this bug. Verify that this is the case and remove the hack. + if (Configuration.RunningOnMono && (layoutRect.X != 0 || layoutRect.Y != 0) && measured_glyphs.Count > 0) + { + for (int i = 0; i < measured_glyphs.Count; i++) + { + RectangleF rect = measured_glyphs[i]; + rect.X += layoutRect.X; + rect.Y += layoutRect.Y; + measured_glyphs[i] = rect; + } + } + return measured_glyphs; }