From 967eb64ed6f859fad6062ec7e271acf5bf1f731f Mon Sep 17 00:00:00 2001 From: the_fiddler Date: Mon, 30 May 2011 09:20:12 +0000 Subject: [PATCH] Added fix for issue [#2506]: "GLControl inside a user control crashes during design time". --- Source/GLControl/GLControl.cs | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/Source/GLControl/GLControl.cs b/Source/GLControl/GLControl.cs index 743d4bdd..094dc28d 100644 --- a/Source/GLControl/GLControl.cs +++ b/Source/GLControl/GLControl.cs @@ -56,6 +56,10 @@ namespace OpenTK // the premature Resize event and raise it as soon as the handle // is ready. bool resize_event_suppressed; + // Indicates whether the control is in design mode. Due to issues + // wiith the DesignMode property and nested controls,we need to + // evaluate this in the constructor. + readonly bool design_mode; #region --- Constructors --- @@ -96,6 +100,13 @@ namespace OpenTK this.minor = minor; this.flags = flags; + // Note: the DesignMode property may be incorrect when nesting controls. + // We use LicenseManager.UsageMode as a workaround (this only works in + // the constructor). + design_mode = + DesignMode || + LicenseManager.UsageMode == LicenseUsageMode.Designtime; + InitializeComponent(); } @@ -139,7 +150,7 @@ namespace OpenTK if (implementation != null) implementation.WindowInfo.Dispose(); - if (DesignMode) + if (design_mode) implementation = new DummyGLControl(); else implementation = new GLControlFactory().CreateGLControl(format, this); @@ -147,7 +158,7 @@ namespace OpenTK context = implementation.CreateContext(major, minor, flags); MakeCurrent(); - if (!DesignMode) + if (!design_mode) ((IGraphicsContextInternal)Context).LoadAll(); // Deferred setting of vsync mode. See VSync property for more information. @@ -193,7 +204,7 @@ namespace OpenTK { ValidateState(); - if (DesignMode) + if (design_mode) e.Graphics.Clear(BackColor); base.OnPaint(e);