소스 검색

Changes to GLFW

pull/4665/head
asdqwe 1 주 전
부모
커밋
3c7c276019
4개의 변경된 파일36개의 추가작업 그리고 8개의 파일을 삭제
  1. +3
    -0
      src/external/glfw/src/win32_platform.h
  2. +15
    -4
      src/external/glfw/src/win32_window.c
  3. +3
    -0
      src/external/glfw/src/x11_platform.h
  4. +15
    -4
      src/external/glfw/src/x11_window.c

+ 3
- 0
src/external/glfw/src/win32_platform.h 파일 보기

@ -625,3 +625,6 @@ GLFWbool _glfwCreateContextWGL(_GLFWwindow* window,
const _GLFWctxconfig* ctxconfig,
const _GLFWfbconfig* fbconfig);
// Workaround for raylib to call disableCursor() earlier
void raylibFixEarlyDisableCursor(_GLFWwindow* window);

+ 15
- 4
src/external/glfw/src/win32_window.c 파일 보기

@ -2174,11 +2174,11 @@ void _glfwPollEventsWin32(void)
// NOTE: Re-center the cursor only if it has moved since the last call,
// to avoid breaking glfwWaitEvents with WM_MOUSEMOVE
// The re-center is required in order to prevent the mouse cursor stopping at the edges of the screen.
if (window->win32.lastCursorPosX != width / 2 ||
window->win32.lastCursorPosY != height / 2)
{
// if (window->win32.lastCursorPosX != width / 2 ||
// window->win32.lastCursorPosY != height / 2)
// {
_glfwSetCursorPosWin32(window, width / 2, height / 2);
}
// }
}
}
@ -2590,5 +2590,16 @@ GLFWAPI HWND glfwGetWin32Window(GLFWwindow* handle)
return window->win32.handle;
}
// Workaround for raylib to call disableCursor() earlier
void raylibFixEarlyDisableCursor(_GLFWwindow* window)
{
_glfw.win32.disabledCursorWindow = window;
_glfwGetCursorPosWin32(window, &_glfw.win32.restoreCursorPosX, &_glfw.win32.restoreCursorPosY);
updateCursorImage(window);
_glfwCenterCursorInContentArea(window);
captureCursor(window);
if (window->rawMouseMotion) enableRawMouseMotion(window);
}
#endif // _GLFW_WIN32

+ 3
- 0
src/external/glfw/src/x11_platform.h 파일 보기

@ -1002,3 +1002,6 @@ GLFWbool _glfwChooseVisualGLX(const _GLFWwndconfig* wndconfig,
const _GLFWfbconfig* fbconfig,
Visual** visual, int* depth);
// Workaround for raylib to call disableCursor() earlier
void raylibFixEarlyDisableCursor(_GLFWwindow* window);

+ 15
- 4
src/external/glfw/src/x11_window.c 파일 보기

@ -2805,11 +2805,11 @@ void _glfwPollEventsX11(void)
// NOTE: Re-center the cursor only if it has moved since the last call,
// to avoid breaking glfwWaitEvents with MotionNotify
if (window->x11.lastCursorPosX != width / 2 ||
window->x11.lastCursorPosY != height / 2)
{
// if (window->x11.lastCursorPosX != width / 2 ||
// window->x11.lastCursorPosY != height / 2)
// {
_glfwSetCursorPosX11(window, width / 2, height / 2);
}
// }
}
XFlush(_glfw.x11.display);
@ -3354,5 +3354,16 @@ GLFWAPI const char* glfwGetX11SelectionString(void)
return getSelectionString(_glfw.x11.PRIMARY);
}
// Workaround for raylib to call disableCursor() earlier
void raylibFixEarlyDisableCursor(_GLFWwindow* window)
{
if (window->rawMouseMotion) enableRawMouseMotion(window);
_glfw.x11.disabledCursorWindow = window;
_glfwGetCursorPosX11(window, &_glfw.x11.restoreCursorPosX, &_glfw.x11.restoreCursorPosY);
updateCursorImage(window);
_glfwCenterCursorInContentArea(window);
captureCursor(window);
}
#endif // _GLFW_X11

불러오는 중...
취소
저장