mirror of
https://github.com/Ryujinx/Opentk.git
synced 2025-01-11 05:45:57 +00:00
Do not force control to create its handle in Resize event (the designer places code that raises this event before the rest of the events are hooked). Instead, suppress the event and raise it once the handle is actually created.
This commit is contained in:
parent
a7ccef9ae8
commit
823149b343
|
@ -51,6 +51,11 @@ namespace OpenTK
|
||||||
int major, minor;
|
int major, minor;
|
||||||
GraphicsContextFlags flags;
|
GraphicsContextFlags flags;
|
||||||
bool? initial_vsync_value;
|
bool? initial_vsync_value;
|
||||||
|
// Indicates that OnResize was called before OnHandleCreated.
|
||||||
|
// To avoid issues with missing OpenGL contexts, we suppress
|
||||||
|
// the premature Resize event and raise it as soon as the handle
|
||||||
|
// is ready.
|
||||||
|
bool resize_event_suppressed;
|
||||||
|
|
||||||
#region --- Constructors ---
|
#region --- Constructors ---
|
||||||
|
|
||||||
|
@ -153,6 +158,12 @@ namespace OpenTK
|
||||||
}
|
}
|
||||||
|
|
||||||
base.OnHandleCreated(e);
|
base.OnHandleCreated(e);
|
||||||
|
|
||||||
|
if (resize_event_suppressed)
|
||||||
|
{
|
||||||
|
OnResize(EventArgs.Empty);
|
||||||
|
resize_event_suppressed = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>Raises the HandleDestroyed event.</summary>
|
/// <summary>Raises the HandleDestroyed event.</summary>
|
||||||
|
@ -190,12 +201,18 @@ namespace OpenTK
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Raises the Resize event.
|
/// Raises the Resize event.
|
||||||
|
/// Note: this method may be called before the OpenGL context is ready.
|
||||||
|
/// Check that IsHandleCreated is true before using any OpenGL methods.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="e">A System.EventArgs that contains the event data.</param>
|
/// <param name="e">A System.EventArgs that contains the event data.</param>
|
||||||
protected override void OnResize(EventArgs e)
|
protected override void OnResize(EventArgs e)
|
||||||
{
|
{
|
||||||
if (IsHandleCreated == false)
|
// Do not raise OnResize event before the handle and context are created.
|
||||||
CreateHandle();
|
if (!IsHandleCreated)
|
||||||
|
{
|
||||||
|
resize_event_suppressed = true;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (context != null)
|
if (context != null)
|
||||||
context.Update(Implementation.WindowInfo);
|
context.Update(Implementation.WindowInfo);
|
||||||
|
|
Loading…
Reference in a new issue