mirror of
https://github.com/Ryujinx/Opentk.git
synced 2025-01-26 04:11:05 +00:00
Added a work around for the "stuck cursor" issue, where the mouse cursor would stay at the resize state when entering the GameWindow.
This commit is contained in:
parent
2813f262a2
commit
a2335092c9
|
@ -59,15 +59,24 @@ namespace OpenTK.Platform.Windows
|
||||||
|
|
||||||
#region protected override void WndProc(ref Message msg)
|
#region protected override void WndProc(ref Message msg)
|
||||||
|
|
||||||
|
bool mouse_about_to_enter = false;
|
||||||
protected override void WndProc(ref Message msg)
|
protected override void WndProc(ref Message msg)
|
||||||
{
|
{
|
||||||
switch ((WindowMessage)msg.Msg)
|
switch ((WindowMessage)msg.Msg)
|
||||||
{
|
{
|
||||||
// Mouse events:
|
// Mouse events:
|
||||||
|
case WindowMessage.NCMOUSEMOVE:
|
||||||
|
mouse_about_to_enter = true; // Used to simulate a mouse enter event.
|
||||||
|
break;
|
||||||
|
|
||||||
case WindowMessage.MOUSEMOVE:
|
case WindowMessage.MOUSEMOVE:
|
||||||
//case WindowMessage.NCMOUSEMOVE:
|
|
||||||
mouse.Position = new System.Drawing.Point(msg.LParam.ToInt32() & 0x0000FFFF,
|
mouse.Position = new System.Drawing.Point(msg.LParam.ToInt32() & 0x0000FFFF,
|
||||||
(int)(msg.LParam.ToInt32() & 0xFFFF0000) >> 16);
|
(int)(msg.LParam.ToInt32() & 0xFFFF0000) >> 16);
|
||||||
|
if (mouse_about_to_enter)
|
||||||
|
{
|
||||||
|
Cursor.Current = Cursors.Default;
|
||||||
|
mouse_about_to_enter = false;
|
||||||
|
}
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case WindowMessage.MOUSEWHEEL:
|
case WindowMessage.MOUSEWHEEL:
|
||||||
|
|
|
@ -369,6 +369,8 @@ namespace OpenTK.Platform.Windows
|
||||||
|
|
||||||
context = new GraphicsContext(mode, window);
|
context = new GraphicsContext(mode, window);
|
||||||
|
|
||||||
|
Cursor.Current = Cursors.Default;
|
||||||
|
|
||||||
Debug.Unindent();
|
Debug.Unindent();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue