Cxbx-Reloaded/Source/Win32/Cxbx/DlgControllerConfig.cpp

617 lines
24 KiB
C++
Raw Normal View History

2003-03-30 06:30:19 +00:00
// ******************************************************************
// *
// * .,-::::: .,:: .::::::::. .,:: .:
// * ,;;;'````' `;;;, .,;; ;;;'';;' `;;;, .,;;
// * [[[ '[[,,[[' [[[__[[\. '[[,,[['
// * $$$ Y$$$P $$""""Y$$ Y$$$P
// * `88bo,__,o, oP"``"Yo, _88o,,od8P oP"``"Yo,
// * "YUMMMMMP",m" "Mm,""YUMMMP" ,m" "Mm,
// *
// * Cxbx->Win32->Cxbx->DlgControllerConfig.cpp
// *
// * This file is part of the Cxbx project.
// *
// * Cxbx and Cxbe are free software; you can redistribute them
// * and/or modify them under the terms of the GNU General Public
// * License as published by the Free Software Foundation; either
// * version 2 of the license, or (at your option) any later version.
// *
// * This program is distributed in the hope that it will be useful,
// * but WITHOUT ANY WARRANTY; without even the implied warranty of
// * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// * GNU General Public License for more details.
// *
// * You should have recieved a copy of the GNU General Public License
// * along with this program; see the file COPYING.
// * If not, write to the Free Software Foundation, Inc.,
// * 59 Temple Place - Suite 330, Bostom, MA 02111-1307, USA.
// *
// * (c) 2002-2003 Aaron Robinson <caustik@caustik.com>
// *
// * All rights reserved
// *
// ******************************************************************
#include "DlgControllerConfig.h"
2003-04-02 02:23:30 +00:00
#include "ResCxbx.h"
#include "EmuShared.h"
2003-03-30 06:30:19 +00:00
#define DIRECTINPUT_VERSION 0x0800
#include <dinput.h>
2003-04-01 23:11:03 +00:00
#include <stdio.h>
2003-03-30 06:30:19 +00:00
// ******************************************************************
2003-04-02 22:57:26 +00:00
// * Exported Global(s)
2003-03-30 06:30:19 +00:00
// ******************************************************************
2003-04-01 23:11:03 +00:00
InputConfig g_InputConfig;
2003-03-30 06:30:19 +00:00
// ******************************************************************
2003-04-02 22:57:26 +00:00
// * Static Function(s)
2003-03-30 06:30:19 +00:00
// ******************************************************************
static INT_PTR CALLBACK DlgControllerConfigProc(HWND hWndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam);
static BOOL CALLBACK EnumGameCtrlCallback(LPCDIDEVICEINSTANCE lpddi, LPVOID pvRef);
static BOOL CALLBACK EnumObjectsCallback(LPCDIDEVICEOBJECTINSTANCE lpddoi, LPVOID pvRef);
2003-04-04 03:31:43 +00:00
static void ConfigureInput(HWND hWndDlg, HWND hWndButton, InputDeviceComponent idc);
2003-03-30 06:30:19 +00:00
2003-04-01 23:11:03 +00:00
// ******************************************************************
2003-04-02 22:57:26 +00:00
// * Static Variable(s)
2003-04-01 23:11:03 +00:00
// ******************************************************************
2003-04-02 22:57:26 +00:00
static LPDIRECTINPUT8 g_pDirectInput8 = NULL;
2003-04-04 03:31:43 +00:00
static LPDIRECTINPUTDEVICE8 g_pInputDev[MAX_INPUT_DEVICES] = {0};
2003-04-02 22:57:26 +00:00
static DWORD g_pInputDevFlags[MAX_INPUT_DEVICES] = {0};
2003-04-04 03:31:43 +00:00
static int g_pInputCur = 0;
2003-04-02 22:57:26 +00:00
static bool g_bConfigDone = true;
2003-04-01 23:11:03 +00:00
2003-03-30 06:30:19 +00:00
// ******************************************************************
2003-04-02 22:57:26 +00:00
// * Show Controller Configuration Dialog Window
2003-03-30 06:30:19 +00:00
// ******************************************************************
void ShowControllerConfig(HWND hwnd)
{
2003-04-04 03:31:43 +00:00
g_EmuShared->GetInputConfiguration(&g_InputConfig);
2003-03-30 06:30:19 +00:00
DialogBox
(
GetModuleHandle(NULL),
MAKEINTRESOURCE(IDD_CONTROLLER_CFG),
hwnd,
DlgControllerConfigProc
);
}
// ******************************************************************
2003-04-02 22:57:26 +00:00
// * Controller Configuration Dialog Procedure
// ******************************************************************
INT_PTR CALLBACK DlgControllerConfigProc(HWND hWndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
2003-04-04 03:31:43 +00:00
{
switch(uMsg)
{
case WM_INITDIALOG:
SetClassLong(hWndDlg, GCL_HICON, (LONG)LoadIcon(GetModuleHandle(NULL), MAKEINTRESOURCE(IDI_CXBX)));
2003-04-02 20:01:37 +00:00
SetFocus(GetDlgItem(hWndDlg, IDC_SET_X));
break;
case WM_CLOSE:
EndDialog(hWndDlg, wParam);
break;
case WM_COMMAND:
{
HWND hWndButton = GetDlgItem(hWndDlg, LOWORD(wParam));
switch(LOWORD(wParam))
{
case IDC_INPUT_CONFIG_CANCEL:
EndDialog(hWndDlg, wParam);
break;
case IDC_INPUT_CONFIG_ACCEPT:
2003-04-04 03:31:43 +00:00
g_EmuShared->SetInputConfiguration(&g_InputConfig);
2003-04-01 08:16:06 +00:00
EndDialog(hWndDlg, wParam);
break;
2003-04-13 02:39:16 +00:00
case IDC_SET_LEFT_POSY:
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_LTHUMBPOSY);
break;
2003-04-13 02:39:16 +00:00
case IDC_SET_LEFT_NEGY:
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_LTHUMBNEGY);
break;
2003-04-13 02:39:16 +00:00
case IDC_SET_LEFT_POSX:
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_LTHUMBPOSX);
break;
2003-04-13 02:39:16 +00:00
case IDC_SET_LEFT_NEGX:
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_LTHUMBNEGX);
break;
case IDC_SET_RIGHT_POSY:
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_RTHUMBPOSY);
break;
case IDC_SET_RIGHT_NEGY:
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_RTHUMBNEGY);
break;
case IDC_SET_RIGHT_POSX:
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_RTHUMBPOSX);
break;
case IDC_SET_RIGHT_NEGX:
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_RTHUMBNEGX);
break;
case IDC_SET_X:
2003-04-04 03:31:43 +00:00
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_X);
break;
case IDC_SET_Y:
2003-04-04 03:31:43 +00:00
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_Y);
break;
case IDC_SET_A:
2003-04-04 03:31:43 +00:00
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_A);
break;
case IDC_SET_B:
2003-04-04 03:31:43 +00:00
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_B);
break;
case IDC_SET_WHITE:
2003-04-04 03:31:43 +00:00
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_WHITE);
break;
case IDC_SET_BLACK:
2003-04-04 03:31:43 +00:00
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_BLACK);
break;
case IDC_SET_LTRIGGER:
2003-04-04 03:31:43 +00:00
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_LTRIGGER);
break;
case IDC_SET_RTRIGGER:
2003-04-04 03:31:43 +00:00
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_RTRIGGER);
break;
case IDC_SET_DPAD_UP:
2003-04-04 03:31:43 +00:00
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_DPADUP);
break;
case IDC_SET_DPAD_DOWN:
2003-04-04 03:31:43 +00:00
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_DPADDOWN);
break;
case IDC_SET_DPAD_LEFT:
2003-04-04 03:31:43 +00:00
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_DPADLEFT);
break;
case IDC_SET_DPAD_RIGHT:
2003-04-04 03:31:43 +00:00
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_DPADRIGHT);
break;
case IDC_SET_BACK:
2003-04-04 03:31:43 +00:00
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_BACK);
break;
case IDC_SET_START:
2003-04-04 03:31:43 +00:00
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_START);
break;
case IDC_SET_LTHUMB:
2003-04-04 03:31:43 +00:00
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_LTHUMB);
break;
case IDC_SET_RTHUMB:
2003-04-04 03:31:43 +00:00
ConfigureInput(hWndDlg, hWndButton, INPUT_DEVICE_COMPONENT_RTHUMB);
break;
}
}
break;
}
return FALSE;
}
// ******************************************************************
2003-04-02 22:57:26 +00:00
// * Enumerate Game Controller(s)
// ******************************************************************
BOOL CALLBACK EnumGameCtrlCallback(LPCDIDEVICEINSTANCE lpddi, LPVOID pvRef)
{
HRESULT hRet = g_pDirectInput8->CreateDevice(lpddi->guidInstance, &g_pInputDev[g_pInputCur], NULL);
2003-04-04 03:31:43 +00:00
if(!FAILED(hRet))
2003-04-02 22:57:26 +00:00
{
2003-04-04 03:31:43 +00:00
g_pInputDevFlags[g_pInputCur] = INPUT_MAPPING_JOYSTICK;
g_pInputDev[g_pInputCur++]->SetDataFormat(&c_dfDIJoystick);
2003-04-02 22:57:26 +00:00
}
return DIENUM_CONTINUE;
}
// ******************************************************************
2003-04-02 22:57:26 +00:00
// * Enumerate Game Controller Object(s)
// ******************************************************************
BOOL CALLBACK EnumObjectsCallback(LPCDIDEVICEOBJECTINSTANCE lpddoi, LPVOID pvRef)
{
if(lpddoi->dwType & DIDFT_AXIS)
{
DIPROPRANGE diprg;
diprg.diph.dwSize = sizeof(DIPROPRANGE);
diprg.diph.dwHeaderSize = sizeof(DIPROPHEADER);
diprg.diph.dwHow = DIPH_BYID;
diprg.diph.dwObj = lpddoi->dwType;
2003-04-02 22:57:26 +00:00
diprg.lMin = 0 - 32768;
diprg.lMax = 0 + 32767;
2003-04-04 03:31:43 +00:00
HRESULT hRet = g_pInputDev[(int)pvRef]->SetProperty(DIPROP_RANGE, &diprg.diph);
if(FAILED(hRet))
return DIENUM_STOP;
}
return DIENUM_CONTINUE;
}
2003-03-30 06:30:19 +00:00
// ******************************************************************
// * ConfigureInput
// ******************************************************************
2003-04-04 03:31:43 +00:00
void ConfigureInput(HWND hWndDlg, HWND hWndButton, InputDeviceComponent idc)
2003-03-30 06:30:19 +00:00
{
if(!g_bConfigDone)
return;
2003-04-04 03:31:43 +00:00
2003-03-30 06:30:19 +00:00
g_bConfigDone = false;
char szOrgText[32];
char szNewText[255] = "Recieved no user input, try again...";
SetWindowText(GetDlgItem(hWndDlg, IDC_CONFIG_STATUS), "Waiting for your input...");
GetWindowText(hWndButton, szOrgText, 32);
// ******************************************************************
// * Create DirectInput object
// ******************************************************************
{
DirectInput8Create
(
GetModuleHandle(NULL),
DIRECTINPUT_VERSION,
IID_IDirectInput8,
(void**)&g_pDirectInput8,
NULL
);
}
2003-04-04 03:31:43 +00:00
// ******************************************************************
// * Create all the devices available (well...most of them)
// ******************************************************************
2003-03-30 06:30:19 +00:00
if(g_pDirectInput8 != 0)
2003-04-04 03:31:43 +00:00
{
2003-04-02 22:57:26 +00:00
HRESULT hRet;
2003-04-04 03:31:43 +00:00
2003-04-02 22:57:26 +00:00
hRet = g_pDirectInput8->EnumDevices
2003-03-30 06:30:19 +00:00
(
DI8DEVCLASS_GAMECTRL,
EnumGameCtrlCallback,
NULL,
DIEDFL_ATTACHEDONLY
);
2003-04-04 03:31:43 +00:00
hRet = g_pDirectInput8->CreateDevice(GUID_SysKeyboard, &g_pInputDev[g_pInputCur], NULL);
if(!FAILED(hRet))
{
g_pInputDevFlags[g_pInputCur] = INPUT_MAPPING_KEYBOARD;
g_pInputDev[g_pInputCur++]->SetDataFormat(&c_dfDIKeyboard);
}
hRet = g_pDirectInput8->CreateDevice(GUID_SysMouse, &g_pInputDev[g_pInputCur], NULL);
if(!FAILED(hRet))
{
g_pInputDevFlags[g_pInputCur] = INPUT_MAPPING_MOUSE;
g_pInputDev[g_pInputCur++]->SetDataFormat(&c_dfDIMouse2);
}
2003-03-30 06:30:19 +00:00
}
2003-04-04 03:31:43 +00:00
2003-03-30 06:30:19 +00:00
// ******************************************************************
// * Set cooperative level and acquire
// ******************************************************************
{
for(int v=g_pInputCur-1;v>=0;v--)
{
2003-04-02 22:57:26 +00:00
g_pInputDev[v]->SetCooperativeLevel(hWndDlg, DISCL_NONEXCLUSIVE | DISCL_FOREGROUND);
2003-03-30 06:30:19 +00:00
g_pInputDev[v]->Acquire();
HRESULT hRet = g_pInputDev[v]->Poll();
if(FAILED(hRet))
{
hRet = g_pInputDev[v]->Acquire();
while(hRet == DIERR_INPUTLOST)
hRet = g_pInputDev[v]->Acquire();
if(hRet != DIERR_INPUTLOST)
break;
}
}
}
// ******************************************************************
// * Enumerate Controller objects
// ******************************************************************
{
for(int v=0;v<g_pInputCur;v++)
g_pInputDev[v]->EnumObjects(EnumObjectsCallback, (LPVOID)v, DIDFT_ALL);
}
2003-04-04 03:31:43 +00:00
// ******************************************************************
2003-04-04 04:35:00 +00:00
// * Last Mouse Input for Delta Calculations
2003-04-04 03:31:43 +00:00
// ******************************************************************
LONG LastMouse_lX = -1;
LONG LastMouse_lY = -1;
LONG LastMouse_lZ = -1;
2003-03-30 06:30:19 +00:00
// ******************************************************************
// * Wait for input, or 5 second timeout
// ******************************************************************
{
DIDEVICEINSTANCE DeviceInstance;
DIDEVICEOBJECTINSTANCE ObjectInstance;
DeviceInstance.dwSize = sizeof(DIDEVICEINSTANCE);
ObjectInstance.dwSize = sizeof(DIDEVICEOBJECTINSTANCE);
2003-04-02 22:57:26 +00:00
for(int v=100;v>0 && !g_bConfigDone;v--)
2003-03-30 06:30:19 +00:00
{
// ******************************************************************
// * Update the button text every second
// ******************************************************************
2003-04-02 22:57:26 +00:00
if(v%20 == 0)
2003-03-30 06:30:19 +00:00
{
char szBuffer[255];
2003-04-02 22:57:26 +00:00
sprintf(szBuffer, "%d", (v+19)/20);
2003-03-30 06:30:19 +00:00
SetWindowText(hWndButton, szBuffer);
}
// ******************************************************************
// * Monitor for significant device state changes
// ******************************************************************
for(int v=g_pInputCur-1;v>=0 && !g_bConfigDone;v--)
{
HRESULT hRet = g_pInputDev[v]->Poll();
if(FAILED(hRet))
{
hRet = g_pInputDev[v]->Acquire();
while(hRet == DIERR_INPUTLOST)
hRet = g_pInputDev[v]->Acquire();
return;
}
DWORD dwHow = -1;
2003-04-02 22:57:26 +00:00
DWORD dwFlags = g_pInputDevFlags[v];
2003-03-30 06:30:19 +00:00
2003-04-04 03:31:43 +00:00
// ******************************************************************
// * Detect Joystick Input
// ******************************************************************
2003-04-02 22:57:26 +00:00
if(g_pInputDevFlags[v] & INPUT_MAPPING_JOYSTICK)
2003-03-30 06:30:19 +00:00
{
2003-04-04 03:31:43 +00:00
DIJOYSTATE InputState = {0};
g_pInputDev[v]->GetDeviceState(sizeof(DIJOYSTATE), &InputState);
int b=0;
2003-03-30 06:30:19 +00:00
2003-04-05 09:03:02 +00:00
dwFlags = INPUT_MAPPING_JOYSTICK;
2003-04-02 22:57:26 +00:00
if(abs(InputState.lX) > JOYSTICK_DETECT_SENSITIVITY)
{
dwHow = FIELD_OFFSET(DIJOYSTATE, lX);
2003-04-02 22:57:26 +00:00
dwFlags |= (InputState.lX > 0) ? INPUT_MAPPING_AXIS_POSITIVE : INPUT_MAPPING_AXIS_NEGATIVE;
}
2003-04-02 22:57:26 +00:00
else if(abs(InputState.lY) > JOYSTICK_DETECT_SENSITIVITY)
{
2003-03-30 06:30:19 +00:00
dwHow = FIELD_OFFSET(DIJOYSTATE, lY);
2003-04-02 22:57:26 +00:00
dwFlags |= (InputState.lY > 0) ? INPUT_MAPPING_AXIS_POSITIVE : INPUT_MAPPING_AXIS_NEGATIVE;
}
2003-04-02 22:57:26 +00:00
else if(abs(InputState.lZ) > JOYSTICK_DETECT_SENSITIVITY)
{
2003-03-30 06:30:19 +00:00
dwHow = FIELD_OFFSET(DIJOYSTATE, lZ);
2003-04-02 22:57:26 +00:00
dwFlags |= (InputState.lZ > 0) ? INPUT_MAPPING_AXIS_POSITIVE : INPUT_MAPPING_AXIS_NEGATIVE;
}
2003-04-02 22:57:26 +00:00
else if(abs(InputState.lRx) > JOYSTICK_DETECT_SENSITIVITY)
{
2003-03-30 06:30:19 +00:00
dwHow = FIELD_OFFSET(DIJOYSTATE, lRx);
2003-04-02 22:57:26 +00:00
dwFlags |= (InputState.lRx > 0) ? INPUT_MAPPING_AXIS_POSITIVE : INPUT_MAPPING_AXIS_NEGATIVE;
}
2003-04-02 22:57:26 +00:00
else if(abs(InputState.lRy) > JOYSTICK_DETECT_SENSITIVITY)
{
2003-03-30 06:30:19 +00:00
dwHow = FIELD_OFFSET(DIJOYSTATE, lRy);
2003-04-02 22:57:26 +00:00
dwFlags |= (InputState.lRy > 0) ? INPUT_MAPPING_AXIS_POSITIVE : INPUT_MAPPING_AXIS_NEGATIVE;
}
2003-04-02 22:57:26 +00:00
else if(abs(InputState.lRz) > JOYSTICK_DETECT_SENSITIVITY)
{
2003-03-30 06:30:19 +00:00
dwHow = FIELD_OFFSET(DIJOYSTATE, lRz);
2003-04-02 22:57:26 +00:00
dwFlags |= (InputState.lRz > 0) ? INPUT_MAPPING_AXIS_POSITIVE : INPUT_MAPPING_AXIS_NEGATIVE;
}
2003-04-04 04:35:00 +00:00
else
for(b=0;b<2;b++)
2003-04-04 03:31:43 +00:00
if(abs(InputState.rglSlider[b]) > JOYSTICK_DETECT_SENSITIVITY)
dwHow = FIELD_OFFSET(DIJOYSTATE, rglSlider[b]);
2003-04-04 04:35:00 +00:00
else
for(b=0;b<4;b++)
2003-04-04 03:31:43 +00:00
if(abs(InputState.rgdwPOV[b]) > POV_DETECT_SENSITIVITY)
dwHow = FIELD_OFFSET(DIJOYSTATE, rgdwPOV[b]);
2003-04-04 04:35:00 +00:00
else
for(b=0;b<32;b++)
2003-04-04 03:31:43 +00:00
if(InputState.rgbButtons[b] > BUTTON_DETECT_SENSITIVITY)
dwHow = FIELD_OFFSET(DIJOYSTATE, rgbButtons[b]);
// ******************************************************************
// * Retrieve Object Info
// ******************************************************************
if(dwHow != -1)
{
g_pInputDev[v]->GetDeviceInfo(&DeviceInstance);
g_pInputDev[v]->GetObjectInfo(&ObjectInstance, dwHow, DIPH_BYOFFSET);
g_InputConfig.Map(idc, DeviceInstance.tszInstanceName, ObjectInstance.dwType, dwFlags);
2003-04-05 09:03:02 +00:00
printf("Cxbx: Detected %s on %s\n", ObjectInstance.tszName, DeviceInstance.tszInstanceName, ObjectInstance.dwType);
2003-04-04 03:31:43 +00:00
sprintf(szNewText, "%s Successfully Mapped To %s On %s!", szOrgText, ObjectInstance.tszName, DeviceInstance.tszInstanceName);
}
}
// ******************************************************************
// * Detect Keyboard Input
// ******************************************************************
else if(g_pInputDevFlags[v] & INPUT_MAPPING_KEYBOARD)
{
BYTE InputState[256];
g_pInputDev[v]->GetDeviceState(256, InputState);
2003-04-05 09:03:02 +00:00
dwFlags = INPUT_MAPPING_KEYBOARD;
2003-04-04 03:31:43 +00:00
for(int v=0;v<256;v++)
{
if(InputState[v] != 0)
{
dwHow = v;
break;
}
}
if(dwHow != -1)
{
g_InputConfig.Map(idc, "SysKeyboard", dwHow, dwFlags);
printf("Cxbx: Detected Key %d on SysKeyboard\n", dwHow);
sprintf(szNewText, "%s Successfully Mapped To Key %d On %s!", szOrgText, dwHow, "SysKeyboard");
}
}
// ******************************************************************
// * Detect Mouse Input
// ******************************************************************
else if(g_pInputDevFlags[v] & INPUT_MAPPING_MOUSE)
{
DIMOUSESTATE2 InputState = {0};
g_pInputDev[v]->GetDeviceState(sizeof(DIMOUSESTATE2), &InputState);
2003-04-05 09:03:02 +00:00
dwFlags = INPUT_MAPPING_MOUSE;
2003-04-04 03:31:43 +00:00
// detect button changes
for(int b=0;b<8;b++)
{
if(InputState.rgbButtons[b] & 0x80)
{
dwHow = b;
2003-04-05 09:03:02 +00:00
dwFlags |= INPUT_MAPPING_MOUSE_CLICK;
2003-04-04 03:31:43 +00:00
break;
}
}
// found a button change
if(dwHow != -1)
{
g_InputConfig.Map(idc, "SysMouse", dwHow, dwFlags);
printf("Cxbx: Detected Button %d on SysMouse\n", dwHow);
sprintf(szNewText, "%s Successfully Mapped To Button %d On %s!", szOrgText, dwHow, "SysMouse");
}
// no button changes
else
{
LONG delta_lX=0, delta_lY=0, delta_lZ=0;
LONG absd_lX=0, absd_lY=0, absd_lZ=0;
2003-04-05 09:03:02 +00:00
if(LastMouse_lY == -1 || LastMouse_lY == -1 || LastMouse_lZ == -1)
2003-04-04 03:31:43 +00:00
delta_lX = delta_lY = delta_lZ = 0;
else
{
delta_lX = InputState.lX - LastMouse_lX;
delta_lY = InputState.lY - LastMouse_lY;
delta_lZ = InputState.lZ - LastMouse_lZ;
absd_lX = abs(delta_lX);
absd_lY = abs(delta_lY);
absd_lZ = abs(delta_lZ);
}
int max = (absd_lX > absd_lY) ? absd_lX : absd_lY;
max = (max > absd_lZ) ? max : absd_lZ;
2003-04-05 09:03:02 +00:00
LastMouse_lX = InputState.lX;
LastMouse_lY = InputState.lY;
LastMouse_lZ = InputState.lZ;
2003-04-04 03:31:43 +00:00
if(max > MOUSE_DETECT_SENSITIVITY)
{
if(max == absd_lX && absd_lX > MOUSE_DETECT_SENSITIVITY)
{
2003-04-05 09:03:02 +00:00
dwHow = DIMOFS_X;
2003-04-04 03:31:43 +00:00
dwFlags |= (delta_lX > 0) ? INPUT_MAPPING_AXIS_POSITIVE : INPUT_MAPPING_AXIS_NEGATIVE;
}
else if(max == absd_lY && absd_lY > MOUSE_DETECT_SENSITIVITY)
{
2003-04-05 09:03:02 +00:00
dwHow = DIMOFS_Y;
2003-04-04 03:31:43 +00:00
dwFlags |= (delta_lY > 0) ? INPUT_MAPPING_AXIS_POSITIVE : INPUT_MAPPING_AXIS_NEGATIVE;
}
else if(max == absd_lZ && absd_lZ > MOUSE_DETECT_SENSITIVITY)
{
2003-04-05 09:03:02 +00:00
dwHow = DIMOFS_Z;
2003-04-04 03:31:43 +00:00
dwFlags |= (delta_lZ > 0) ? INPUT_MAPPING_AXIS_POSITIVE : INPUT_MAPPING_AXIS_NEGATIVE;
}
if(dwHow != -1)
{
g_InputConfig.Map(idc, "SysMouse", dwHow, dwFlags);
2003-04-05 09:03:02 +00:00
ObjectInstance.dwSize = sizeof(ObjectInstance);
char *szDirection = (dwFlags & INPUT_MAPPING_AXIS_POSITIVE) ? "Positive" : "Negative";
char *szObjName = "Unknown";
if(g_pInputDev[v]->GetObjectInfo(&ObjectInstance, dwHow, DIPH_BYOFFSET) == DI_OK)
szObjName = ObjectInstance.tszName;
printf("Cxbx: Detected Movement on the %s %s on SysMouse\n", szDirection, szObjName);
2003-04-04 03:31:43 +00:00
2003-04-05 09:03:02 +00:00
sprintf(szNewText, "%s Successfully Mapped To %s %s On %s!", szOrgText, szDirection, szObjName, "SysMouse");
2003-04-04 03:31:43 +00:00
}
}
}
}
if(dwHow != -1)
g_bConfigDone = true;
2003-03-30 06:30:19 +00:00
}
2003-04-02 22:57:26 +00:00
Sleep(50);
2003-03-30 06:30:19 +00:00
}
}
2003-04-04 03:31:43 +00:00
// ******************************************************************
// * Cleanup Devices
// ******************************************************************
2003-03-30 06:30:19 +00:00
{
for(int v=g_pInputCur-1;v>=0;v--)
{
g_pInputDev[v]->Unacquire();
g_pInputDev[v]->Release();
g_pInputDev[v] = 0;
}
g_pInputCur = 0;
if(g_pDirectInput8 != 0)
{
g_pDirectInput8->Release();
g_pDirectInput8 = 0;
}
}
2003-04-04 03:31:43 +00:00
// ******************************************************************
// * Update Window
// ******************************************************************
{
SetWindowText(hWndButton, szOrgText);
SetWindowText(GetDlgItem(hWndDlg, IDC_CONFIG_STATUS), szNewText);
MSG Msg;
while(PeekMessage(&Msg, hWndDlg, WM_MOUSEFIRST, WM_MOUSELAST, PM_REMOVE));
while(PeekMessage(&Msg, hWndDlg, WM_KEYFIRST, WM_KEYLAST, PM_REMOVE));
}
2003-03-30 06:30:19 +00:00
g_bConfigDone = true;
}