now also closing menus when non-client area is pressed (thanks for
suggestions Ioannis!) git-svn-id: https://svn.code.sf.net/p/freeglut/code/trunk@1362 7f0cb862-5218-0410-a997-914c9d46530a
This commit is contained in:
parent
fc2ee24b1b
commit
dba5bb070e
@ -532,6 +532,18 @@ LRESULT CALLBACK fgPlatformWindowProc( HWND hWnd, UINT uMsg, WPARAM wParam,
|
|||||||
else if (!wnd->IsMenu && wnd!=menu->ParentWindow) /* Make sure we don't kill the menu when trying to enter a submenu */
|
else if (!wnd->IsMenu && wnd!=menu->ParentWindow) /* Make sure we don't kill the menu when trying to enter a submenu */
|
||||||
/* User switched to another FreeGLUT window */
|
/* User switched to another FreeGLUT window */
|
||||||
fgDeactivateMenu(menu->ParentWindow);
|
fgDeactivateMenu(menu->ParentWindow);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* Check if focus lost because non-client area of
|
||||||
|
* window was pressed (pressing on client area is
|
||||||
|
* handled in fgCheckActiveMenu)
|
||||||
|
*/
|
||||||
|
POINT mouse_pos;
|
||||||
|
RECT clientArea = fghGetClientArea(menu->ParentWindow, GL_FALSE);
|
||||||
|
GetCursorPos(&mouse_pos);
|
||||||
|
if ( !PtInRect( &clientArea, mouse_pos ) )
|
||||||
|
fgDeactivateMenu(menu->ParentWindow);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
Reference in New Issue
Block a user