Fix for mouse stalls at < 10 fps

git-svn-id: https://svn.eduke32.com/eduke32@1603 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
terminx 2010-03-02 22:44:12 +00:00
parent abee6af03e
commit e00aeef384

View file

@ -886,13 +886,10 @@ void setkeypresscallback(void (*callback)(int32_t, int32_t)) { keypresscallback
void setmousepresscallback(void (*callback)(int32_t, int32_t)) { mousepresscallback = callback; } void setmousepresscallback(void (*callback)(int32_t, int32_t)) { mousepresscallback = callback; }
void setjoypresscallback(void (*callback)(int32_t, int32_t)) { joypresscallback = callback; } void setjoypresscallback(void (*callback)(int32_t, int32_t)) { joypresscallback = callback; }
#define DINPUT_EVENTS 16
DWORD WINAPI ProcessMouse(LPVOID lpThreadParameter) DWORD WINAPI ProcessMouse(LPVOID lpThreadParameter)
{ {
int32_t result; int32_t i;
DIDEVICEOBJECTDATA didod[DINPUT_EVENTS]; DIMOUSESTATE2 mousestate;
DWORD dwElements;
UNREFERENCED_PARAMETER(lpThreadParameter); UNREFERENCED_PARAMETER(lpThreadParameter);
@ -907,63 +904,46 @@ DWORD WINAPI ProcessMouse(LPVOID lpThreadParameter)
if ((WaitForSingleObject(inputevt[MOUSE], INFINITE)) != WAIT_OBJECT_0) if ((WaitForSingleObject(inputevt[MOUSE], INFINITE)) != WAIT_OBJECT_0)
continue; continue;
dwElements = DINPUT_EVENTS; if (IDirectInputDevice7_GetDeviceState(lpDID[MOUSE], sizeof(DIMOUSESTATE2),
(LPDIMOUSESTATE2)&mousestate) != DI_OK)
continue;
result = IDirectInputDevice7_GetDeviceData(lpDID[MOUSE], sizeof(DIDEVICEOBJECTDATA), mousex += (int16_t)mousestate.lX;
(LPDIDEVICEOBJECTDATA)&didod[0], &dwElements, 0); mousey += (int16_t)mousestate.lY;
if (!dwElements || (result != DI_OK && result != DI_BUFFEROVERFLOW)) if (mousestate.lZ > 0) // wheel up
continue;
do
{ {
int32_t bit = 1<<(didod[dwElements-1].dwOfs - DIMOFS_BUTTON0); if (mousewheel[0] > 0 && mousepresscallback) mousepresscallback(5,0);
mousewheel[0] = getticks();
switch (didod[dwElements-1].dwOfs) mouseb |= 16;
{ if (mousepresscallback) mousepresscallback(5, 1);
case DIMOFS_X: }
mousex += (int16_t)didod[dwElements-1].dwData; else if (mousestate.lZ < 0) // wheel down
break; {
case DIMOFS_Y: if (mousewheel[1] > 0 && mousepresscallback) mousepresscallback(6,0);
mousey += (int16_t)didod[dwElements-1].dwData; mousewheel[1] = getticks();
break; mouseb |= 32;
case DIMOFS_Z: if (mousepresscallback) mousepresscallback(6, 1);
{ }
if ((int32_t)didod[dwElements-1].dwData > 0) // wheel up
{ for (i=0; i<4; i++)
if (mousewheel[0] > 0 && mousepresscallback) mousepresscallback(5,0); {
mousewheel[0] = getticks(); if (mousestate.rgbButtons[i] & 0x80) mouseb |= 1<<i;
mouseb |= 16; else mouseb &= ~(1<<i);
if (mousepresscallback) mousepresscallback(5, 1);
} if (mousepresscallback)
else if ((int32_t)didod[dwElements-1].dwData < 0) // wheel down mousepresscallback(i, mouseb & (1<<i));
{ }
if (mousewheel[1] > 0 && mousepresscallback) mousepresscallback(6,0);
mousewheel[1] = getticks(); // wheel up and down are sent to the game as buttons 5 and 6, so we offset these
mouseb |= 32; for (i=4; i<8; i++)
if (mousepresscallback) mousepresscallback(6, 1); {
} if (mousestate.rgbButtons[i] & 0x80) mouseb |= 1<<(i+2);
} else mouseb &= ~(1<<(i+2));
break;
if (mousepresscallback)
case DIMOFS_BUTTON4: mousepresscallback(i, mouseb & (1<<(i+2)));
case DIMOFS_BUTTON5:
case DIMOFS_BUTTON6:
case DIMOFS_BUTTON7:
didod[dwElements-1].dwOfs += 2; // skip mousewheel buttons
bit = 1<<(didod[dwElements-1].dwOfs - DIMOFS_BUTTON0);
case DIMOFS_BUTTON0:
case DIMOFS_BUTTON1:
case DIMOFS_BUTTON2:
case DIMOFS_BUTTON3:
if (didod[dwElements-1].dwData & 0x80) mouseb |= bit;
else mouseb &= ~bit;
if (mousepresscallback)
mousepresscallback(didod[dwElements-1].dwOfs - DIMOFS_BUTTON0 + 1, mouseb & bit);
break;
}
} }
while (--dwElements);
} }
return 0; return 0;
} }
@ -3409,6 +3389,7 @@ static int32_t SetupOpenGL(int32_t width, int32_t height, int32_t bitspp)
pr_ati_fboworkaround = 0; pr_ati_fboworkaround = 0;
#endif #endif
} }
if (!forcegl && err) if (!forcegl && err)
{ {
OSD_Printf("Unsupported OpenGL driver detected. GL modes will be unavailable. Use -forcegl to override.\n"); OSD_Printf("Unsupported OpenGL driver detected. GL modes will be unavailable. Use -forcegl to override.\n");