mirror of https://github.com/PCSX2/pcsx2.git
LilyPad: General fixes and UI improvements
Some general fixes and UI improvements. Adds Reset Configuration to Input/Force Feedback configuration screens that resets the configuration for the selected control(s). Adds Restore Defaults button to the General tab that deletes all LilyPad Settings and bindings and resets to the default settings. Adds double-click functionality to the PAD list on the General tab, which will now send the user straight to the corresponding PAD tab.
This commit is contained in:
parent
84a8fdadc5
commit
f3a89f59e4
|
@ -279,27 +279,27 @@ wchar_t *GetCommandStringW(u8 command, int port, int slot)
|
||||||
if ((unsigned int)res - 1 <= 18)
|
if ((unsigned int)res - 1 <= 18)
|
||||||
return temp;
|
return temp;
|
||||||
}
|
}
|
||||||
static wchar_t stick[2] = {'L', 'R'};
|
static wchar_t *stick[2] = {L"L-Stick", L"R-Stick"};
|
||||||
static wchar_t *dir[] = {
|
static wchar_t *dir[] = {
|
||||||
L"Up", L"Right",
|
L"Up", L"Right",
|
||||||
L"Down", L"Left"};
|
L"Down", L"Left"};
|
||||||
wsprintfW(temp, L"%c-Stick %s", stick[(command - 0x20) / 4], dir[command & 3]);
|
wsprintfW(temp, L"%s %s", padtype == neGconPad ? L"Rotate" : stick[(command - 0x20) / 4], dir[command & 3]);
|
||||||
return temp;
|
return temp;
|
||||||
}
|
}
|
||||||
/* Get text from the buttons. */
|
/* Get text from the buttons. */
|
||||||
if (command >= 0x0F && command <= 0x2D) {
|
if (command >= 0x0F && command <= 0x2D) {
|
||||||
HWND hWnd = GetDlgItem(hWnds[port][slot][padtype], 0x10F0 + command);
|
HWND hWnd = GetDlgItem(hWnds[port][slot][padtype], 0x10F0 + command);
|
||||||
if (!hWnd) {
|
if (!hWnd || ((padtype == Dualshock2Pad || padtype == neGconPad) && command >= 0x14 && command <= 0x17)) {
|
||||||
wchar_t *strings[] = {
|
wchar_t *strings[] = {
|
||||||
L"Mouse", // 0x0F (15)
|
L"Mouse", // 0x0F (15)
|
||||||
L"Select", // 0x10 (16)
|
L"Select", // 0x10 (16)
|
||||||
L"L3", // 0x11 (17)
|
L"L3", // 0x11 (17)
|
||||||
L"R3", // 0x12 (18)
|
L"R3", // 0x12 (18)
|
||||||
L"Start", // 0x13 (19)
|
L"Start", // 0x13 (19)
|
||||||
L"Up", // 0x14 (20)
|
L"D-Pad Up", // 0x14 (20)
|
||||||
L"Right", // 0x15 (21)
|
L"D-Pad Right", // 0x15 (21)
|
||||||
L"Down", // 0x16 (22)
|
L"D-Pad Down", // 0x16 (22)
|
||||||
L"Left", // 0x17 (23)
|
L"D-Pad Left", // 0x17 (23)
|
||||||
L"L2", // 0x18 (24)
|
L"L2", // 0x18 (24)
|
||||||
L"R2", // 0x19 (25)
|
L"R2", // 0x19 (25)
|
||||||
L"L1", // 0x1A (26)
|
L"L1", // 0x1A (26)
|
||||||
|
@ -548,6 +548,7 @@ void SelChanged(int port, int slot)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ShowWindow(GetDlgItem(hWnd, ID_CONTROLS), ffb || b);
|
ShowWindow(GetDlgItem(hWnd, ID_CONTROLS), ffb || b);
|
||||||
|
ShowWindow(GetDlgItem(hWnd, ID_RESET_CONFIG), ffb || b);
|
||||||
|
|
||||||
if (!ffb) {
|
if (!ffb) {
|
||||||
SetLogSliderVal(hWnd, IDC_SLIDER_SENSITIVITY, GetDlgItem(hWnd, IDC_AXIS_SENSITIVITY), sensitivity);
|
SetLogSliderVal(hWnd, IDC_SLIDER_SENSITIVITY, GetDlgItem(hWnd, IDC_AXIS_SENSITIVITY), sensitivity);
|
||||||
|
@ -1393,8 +1394,13 @@ int BindCommand(Device *dev, unsigned int uid, unsigned int port, unsigned int s
|
||||||
if (port > 1 || slot > 3 || padtype >= numPadTypes)
|
if (port > 1 || slot > 3 || padtype >= numPadTypes)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (!sensitivity)
|
if (!sensitivity) {
|
||||||
sensitivity = BASE_SENSITIVITY;
|
if (((uid >> 16) & 0xFF) == ABSAXIS) {
|
||||||
|
sensitivity = BASE_ANALOG_SENSITIVITY;
|
||||||
|
} else {
|
||||||
|
sensitivity = BASE_SENSITIVITY;
|
||||||
|
}
|
||||||
|
}
|
||||||
if ((uid >> 16) & (PSHBTN | TGLBTN)) {
|
if ((uid >> 16) & (PSHBTN | TGLBTN)) {
|
||||||
deadZone = 0;
|
deadZone = 0;
|
||||||
skipDeadZone = 0;
|
skipDeadZone = 0;
|
||||||
|
@ -1562,6 +1568,7 @@ INT_PTR CALLBACK DialogProc(HWND hWnd, unsigned int msg, WPARAM wParam, LPARAM l
|
||||||
AddTooltip(ID_LOCK_DIRECTION, hWnd);
|
AddTooltip(ID_LOCK_DIRECTION, hWnd);
|
||||||
AddTooltip(ID_LOCK_BUTTONS, hWnd);
|
AddTooltip(ID_LOCK_BUTTONS, hWnd);
|
||||||
AddTooltip(ID_TURBO_KEY, hWnd);
|
AddTooltip(ID_TURBO_KEY, hWnd);
|
||||||
|
AddTooltip(ID_EXCLUDE, hWnd);
|
||||||
AddTooltip(IDC_RAPID_FIRE, hWnd);
|
AddTooltip(IDC_RAPID_FIRE, hWnd);
|
||||||
AddTooltip(IDC_FLIP, hWnd);
|
AddTooltip(IDC_FLIP, hWnd);
|
||||||
AddTooltip(IDC_SLIDER_DEADZONE, hWnd);
|
AddTooltip(IDC_SLIDER_DEADZONE, hWnd);
|
||||||
|
@ -1895,11 +1902,11 @@ INT_PTR CALLBACK DialogProc(HWND hWnd, unsigned int msg, WPARAM wParam, LPARAM l
|
||||||
// Just in case...
|
// Just in case...
|
||||||
if (selected)
|
if (selected)
|
||||||
break;
|
break;
|
||||||
Device *dev;
|
|
||||||
Binding *b;
|
|
||||||
ForceFeedbackBinding *ffb = 0;
|
|
||||||
int selIndex = ListView_GetNextItem(hWndList, -1, LVNI_SELECTED);
|
int selIndex = ListView_GetNextItem(hWndList, -1, LVNI_SELECTED);
|
||||||
if (selIndex >= 0) {
|
if (selIndex >= 0) {
|
||||||
|
Device *dev;
|
||||||
|
Binding *b;
|
||||||
|
ForceFeedbackBinding *ffb = 0;
|
||||||
if (GetBinding(port, slot, selIndex, dev, b, ffb)) {
|
if (GetBinding(port, slot, selIndex, dev, b, ffb)) {
|
||||||
selected = 0xFF;
|
selected = 0xFF;
|
||||||
hWndButtonProc.SetWndHandle(GetDlgItem(hWnd, cmd));
|
hWndButtonProc.SetWndHandle(GetDlgItem(hWnd, cmd));
|
||||||
|
@ -1989,6 +1996,56 @@ INT_PTR CALLBACK DialogProc(HWND hWnd, unsigned int msg, WPARAM wParam, LPARAM l
|
||||||
} else if (cmd == IDC_FLIP) {
|
} else if (cmd == IDC_FLIP) {
|
||||||
int val = GetLogSliderVal(hWnd, IDC_SLIDER_SENSITIVITY);
|
int val = GetLogSliderVal(hWnd, IDC_SLIDER_SENSITIVITY);
|
||||||
ChangeValue(port, slot, &val, 0, 0, 0);
|
ChangeValue(port, slot, &val, 0, 0, 0);
|
||||||
|
} else if (cmd == ID_RESET_CONFIG) {
|
||||||
|
// Just in case...
|
||||||
|
if (selected)
|
||||||
|
break;
|
||||||
|
int selIndex = ListView_GetNextItem(hWndList, -1, LVNI_SELECTED);
|
||||||
|
if (selIndex >= 0) {
|
||||||
|
Device *dev;
|
||||||
|
Binding *b;
|
||||||
|
ForceFeedbackBinding *ffb = 0;
|
||||||
|
if (GetBinding(port, slot, selIndex, dev, b, ffb)) {
|
||||||
|
selected = 0xFF;
|
||||||
|
if (b) {
|
||||||
|
VirtualControl *control = &dev->virtualControls[b->controlIndex];
|
||||||
|
for (int i = IDC_SLIDER_SENSITIVITY; i <= IDC_SLIDER_SKIP_DEADZONE; i++) {
|
||||||
|
if (i == IDC_SLIDER_SENSITIVITY) {
|
||||||
|
int val = BASE_SENSITIVITY;
|
||||||
|
if (((control->uid >> 16) & 0xFF) == ABSAXIS) {
|
||||||
|
val = BASE_ANALOG_SENSITIVITY;
|
||||||
|
}
|
||||||
|
ChangeValue(port, slot, &val, 0, 0, 0);
|
||||||
|
} else if (i == IDC_SLIDER_DEADZONE) {
|
||||||
|
int val = DEFAULT_DEADZONE;
|
||||||
|
if ((control->uid >> 16) & (PSHBTN | TGLBTN)) {
|
||||||
|
val = 0;
|
||||||
|
} else if ((control->uid >> 16) & PRESSURE_BTN) {
|
||||||
|
val = 1;
|
||||||
|
}
|
||||||
|
ChangeValue(port, slot, 0, 0, &val, 0);
|
||||||
|
} else if (i == IDC_SLIDER_SKIP_DEADZONE) {
|
||||||
|
int val = 1;
|
||||||
|
if ((control->uid >> 16) & (PSHBTN | TGLBTN)) {
|
||||||
|
val = 0;
|
||||||
|
}
|
||||||
|
ChangeValue(port, slot, 0, 0, 0, &val);
|
||||||
|
} else if (i == IDC_RAPID_FIRE) {
|
||||||
|
int val = 0;
|
||||||
|
ChangeValue(port, slot, 0, &val, 0, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (ffb) {
|
||||||
|
for (int i = IDC_FF_AXIS1; i <= IDC_FF_AXIS8; i += 0x10) {
|
||||||
|
int val = BASE_SENSITIVITY;
|
||||||
|
if (ffb->motor != ((i - IDC_FF_AXIS1) / 0x10) || IsDlgButtonChecked(hWnd, i - 1) != BST_CHECKED) {
|
||||||
|
val = 0;
|
||||||
|
}
|
||||||
|
ChangeEffect(port, slot, i, &val, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
} else if (cmd >= IDC_FF_AXIS1_ENABLED && cmd < IDC_FF_AXIS8_ENABLED + 16) {
|
} else if (cmd >= IDC_FF_AXIS1_ENABLED && cmd < IDC_FF_AXIS8_ENABLED + 16) {
|
||||||
int index = (cmd - IDC_FF_AXIS1_ENABLED) / 16;
|
int index = (cmd - IDC_FF_AXIS1_ENABLED) / 16;
|
||||||
int val = GetLogSliderVal(hWnd, 16 * index + IDC_FF_AXIS1);
|
int val = GetLogSliderVal(hWnd, 16 * index + IDC_FF_AXIS1);
|
||||||
|
@ -2225,7 +2282,6 @@ void UpdatePadList(HWND hWnd)
|
||||||
|
|
||||||
INT_PTR CALLBACK GeneralDialogProc(HWND hWnd, unsigned int msg, WPARAM wParam, LPARAM lParam)
|
INT_PTR CALLBACK GeneralDialogProc(HWND hWnd, unsigned int msg, WPARAM wParam, LPARAM lParam)
|
||||||
{
|
{
|
||||||
int i;
|
|
||||||
HWND hWndList = GetDlgItem(hWnd, IDC_PAD_LIST);
|
HWND hWndList = GetDlgItem(hWnd, IDC_PAD_LIST);
|
||||||
switch (msg) {
|
switch (msg) {
|
||||||
case WM_INITDIALOG: {
|
case WM_INITDIALOG: {
|
||||||
|
@ -2284,6 +2340,7 @@ INT_PTR CALLBACK GeneralDialogProc(HWND hWnd, unsigned int msg, WPARAM wParam, L
|
||||||
AddTooltip(IDC_DIAG_LIST, hWnd);
|
AddTooltip(IDC_DIAG_LIST, hWnd);
|
||||||
AddTooltip(IDC_G_XI, hWnd);
|
AddTooltip(IDC_G_XI, hWnd);
|
||||||
AddTooltip(IDC_ANALOG_START1, hWnd);
|
AddTooltip(IDC_ANALOG_START1, hWnd);
|
||||||
|
AddTooltip(ID_RESTORE_DEFAULTS, hWnd);
|
||||||
|
|
||||||
if (config.keyboardApi < 0 || config.keyboardApi > 3)
|
if (config.keyboardApi < 0 || config.keyboardApi > 3)
|
||||||
config.keyboardApi = NO_API;
|
config.keyboardApi = NO_API;
|
||||||
|
@ -2356,6 +2413,21 @@ INT_PTR CALLBACK GeneralDialogProc(HWND hWnd, unsigned int msg, WPARAM wParam, L
|
||||||
break;
|
break;
|
||||||
config.padConfigs[port][slot].autoAnalog = (IsDlgButtonChecked(hWnd, IDC_ANALOG_START1) == BST_CHECKED);
|
config.padConfigs[port][slot].autoAnalog = (IsDlgButtonChecked(hWnd, IDC_ANALOG_START1) == BST_CHECKED);
|
||||||
PropSheet_Changed(hWndProp, hWnd);
|
PropSheet_Changed(hWndProp, hWnd);
|
||||||
|
} else if (HIWORD(wParam) == BN_CLICKED && LOWORD(wParam) == ID_RESTORE_DEFAULTS) {
|
||||||
|
int msgboxID = MessageBoxA(hWndProp, "This will delete all current settings and revert back to the default settings of LilyPad. Continue?",
|
||||||
|
"Restore Defaults Confirmation", MB_YESNO | MB_DEFBUTTON2 | MB_ICONEXCLAMATION);
|
||||||
|
switch (msgboxID) {
|
||||||
|
case IDNO:
|
||||||
|
break;
|
||||||
|
case IDYES:
|
||||||
|
char iniLocation[MAX_PATH * 2] = "inis/LilyPad.ini";
|
||||||
|
remove(iniLocation);
|
||||||
|
createIniDir = true;
|
||||||
|
LoadSettings(1);
|
||||||
|
GeneralDialogProc(hWnd, WM_INITDIALOG, 0, 0);
|
||||||
|
PropSheet_Changed(hWndProp, hWnd);
|
||||||
|
break;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
int mtap = config.multitap[0] + 2 * config.multitap[1];
|
int mtap = config.multitap[0] + 2 * config.multitap[1];
|
||||||
|
@ -2365,7 +2437,7 @@ INT_PTR CALLBACK GeneralDialogProc(HWND hWnd, unsigned int msg, WPARAM wParam, L
|
||||||
}
|
}
|
||||||
config.closeHack = IsDlgButtonChecked(hWnd, IDC_CLOSE_HACK) == BST_CHECKED;
|
config.closeHack = IsDlgButtonChecked(hWnd, IDC_CLOSE_HACK) == BST_CHECKED;
|
||||||
|
|
||||||
for (i = 0; i < 4; i++) {
|
for (int i = 0; i < 4; i++) {
|
||||||
if (i && IsDlgButtonChecked(hWnd, IDC_KB_DISABLE + i) == BST_CHECKED) {
|
if (i && IsDlgButtonChecked(hWnd, IDC_KB_DISABLE + i) == BST_CHECKED) {
|
||||||
config.keyboardApi = (DeviceAPI)i;
|
config.keyboardApi = (DeviceAPI)i;
|
||||||
}
|
}
|
||||||
|
@ -2444,7 +2516,11 @@ INT_PTR CALLBACK GeneralDialogProc(HWND hWnd, unsigned int msg, WPARAM wParam, L
|
||||||
if (n->hdr.code == LVN_ITEMCHANGED) {
|
if (n->hdr.code == LVN_ITEMCHANGED) {
|
||||||
UpdatePadList(hWnd);
|
UpdatePadList(hWnd);
|
||||||
}
|
}
|
||||||
if (n->hdr.code == NM_RCLICK) {
|
if (n->hdr.code == NM_DBLCLK) {
|
||||||
|
UpdatePadList(hWnd);
|
||||||
|
int index = ListView_GetNextItem(hWndList, -1, LVNI_SELECTED);
|
||||||
|
PropSheet_SetCurSel(hWndProp, 0, index + 1);
|
||||||
|
} else if (n->hdr.code == NM_RCLICK) {
|
||||||
UpdatePadList(hWnd);
|
UpdatePadList(hWnd);
|
||||||
int index = ListView_GetNextItem(hWndList, -1, LVNI_SELECTED);
|
int index = ListView_GetNextItem(hWndList, -1, LVNI_SELECTED);
|
||||||
int port1, slot1, port2, slot2, padtype1, padtype2;
|
int port1, slot1, port2, slot2, padtype1, padtype2;
|
||||||
|
|
|
@ -80,7 +80,7 @@ Binding 27=0x00200004, 0, 19, 65536, 0, 0, 1, 2
|
||||||
Binding 28=0x00200005, 0, 16, 65536, 0, 0, 1, 2
|
Binding 28=0x00200005, 0, 16, 65536, 0, 0, 1, 2
|
||||||
Binding 29=0x00200008, 0, 25, 65536, 0, 0, 1, 2
|
Binding 29=0x00200008, 0, 25, 65536, 0, 0, 1, 2
|
||||||
Binding 30=0x00200009, 0, 28, 65536, 0, 0, 1, 2
|
Binding 30=0x00200009, 0, 28, 65536, 0, 0, 1, 2
|
||||||
Binding 31=0x0020000F, 0, 31, 65536, 0, 0, 1, 2
|
Binding 31=0x0020000F, 0, 30, 65536, 0, 0, 1, 2
|
||||||
Binding 32=0x00200010, 0, 29, 65536, 0, 0, 1, 2
|
Binding 32=0x00200010, 0, 29, 65536, 0, 0, 1, 2
|
||||||
Binding 33=0x00200011, 0, 31, 65536, 0, 0, 1, 2
|
Binding 33=0x00200011, 0, 31, 65536, 0, 0, 1, 2
|
||||||
Binding 34=0x01020014, 0, 32, 65536, 0, 0, 13172, 2
|
Binding 34=0x01020014, 0, 32, 65536, 0, 0, 13172, 2
|
||||||
|
@ -153,7 +153,7 @@ Binding 27=0x00200004, 1, 19, 65536, 0, 0, 1, 2
|
||||||
Binding 28=0x00200005, 1, 16, 65536, 0, 0, 1, 2
|
Binding 28=0x00200005, 1, 16, 65536, 0, 0, 1, 2
|
||||||
Binding 29=0x00200008, 1, 25, 65536, 0, 0, 1, 2
|
Binding 29=0x00200008, 1, 25, 65536, 0, 0, 1, 2
|
||||||
Binding 30=0x00200009, 1, 28, 65536, 0, 0, 1, 2
|
Binding 30=0x00200009, 1, 28, 65536, 0, 0, 1, 2
|
||||||
Binding 31=0x0020000F, 1, 31, 65536, 0, 0, 1, 2
|
Binding 31=0x0020000F, 1, 30, 65536, 0, 0, 1, 2
|
||||||
Binding 32=0x00200010, 1, 29, 65536, 0, 0, 1, 2
|
Binding 32=0x00200010, 1, 29, 65536, 0, 0, 1, 2
|
||||||
Binding 33=0x00200011, 1, 31, 65536, 0, 0, 1, 2
|
Binding 33=0x00200011, 1, 31, 65536, 0, 0, 1, 2
|
||||||
Binding 34=0x01020014, 1, 32, 65536, 0, 0, 13172, 2
|
Binding 34=0x01020014, 1, 32, 65536, 0, 0, 13172, 2
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
// a value of 128 or more corresponds to that button being pressed, for binary
|
// a value of 128 or more corresponds to that button being pressed, for binary
|
||||||
// values.
|
// values.
|
||||||
#define BASE_SENSITIVITY (1 << 16)
|
#define BASE_SENSITIVITY (1 << 16)
|
||||||
|
#define BASE_ANALOG_SENSITIVITY (87183)
|
||||||
#define FULLY_DOWN (1 << 16)
|
#define FULLY_DOWN (1 << 16)
|
||||||
|
|
||||||
#define DEFAULT_DEADZONE (BASE_SENSITIVITY * 201 / 1000)
|
#define DEFAULT_DEADZONE (BASE_SENSITIVITY * 201 / 1000)
|
||||||
|
|
|
@ -361,25 +361,25 @@ void AddForce(ButtonSum *sum, u8 cmd, int delta = 255)
|
||||||
}
|
}
|
||||||
// Left stick.
|
// Left stick.
|
||||||
else if (cmd < 0x24) {
|
else if (cmd < 0x24) {
|
||||||
if (cmd == 32) {
|
if (cmd == 0x20) { // Up
|
||||||
sum->sticks[1].vert -= delta;
|
sum->sticks[1].vert -= delta;
|
||||||
} else if (cmd == 33) {
|
} else if (cmd == 0x21) { // Right
|
||||||
sum->sticks[1].horiz += delta;
|
sum->sticks[1].horiz += delta;
|
||||||
} else if (cmd == 34) {
|
} else if (cmd == 0x22) { // Down
|
||||||
sum->sticks[1].vert += delta;
|
sum->sticks[1].vert += delta;
|
||||||
} else if (cmd == 35) {
|
} else if (cmd == 0x23) { // Left
|
||||||
sum->sticks[1].horiz -= delta;
|
sum->sticks[1].horiz -= delta;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Right stick.
|
// Right stick.
|
||||||
else if (cmd < 0x28) {
|
else if (cmd < 0x28) {
|
||||||
if (cmd == 36) {
|
if (cmd == 0x24) { // Up
|
||||||
sum->sticks[0].vert -= delta;
|
sum->sticks[0].vert -= delta;
|
||||||
} else if (cmd == 37) {
|
} else if (cmd == 0x25) { // Right
|
||||||
sum->sticks[0].horiz += delta;
|
sum->sticks[0].horiz += delta;
|
||||||
} else if (cmd == 38) {
|
} else if (cmd == 0x26) { // Down
|
||||||
sum->sticks[0].vert += delta;
|
sum->sticks[0].vert += delta;
|
||||||
} else if (cmd == 39) {
|
} else if (cmd == 0x27) { // Left
|
||||||
sum->sticks[0].horiz -= delta;
|
sum->sticks[0].horiz -= delta;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1336,10 +1336,10 @@ u8 CALLBACK PADpoll(u8 value)
|
||||||
//query.response[4] &= pad->mask[1];
|
//query.response[4] &= pad->mask[1];
|
||||||
|
|
||||||
// No need to cap these, already done int CapSum().
|
// No need to cap these, already done int CapSum().
|
||||||
query.response[9] = (unsigned char)sum->buttons[13]; //D-pad right
|
query.response[9] = (unsigned char)sum->buttons[13]; // D-pad right
|
||||||
query.response[10] = (unsigned char)sum->buttons[15]; //D-pad left
|
query.response[10] = (unsigned char)sum->buttons[15]; // D-pad left
|
||||||
query.response[11] = (unsigned char)sum->buttons[12]; //D-pad up
|
query.response[11] = (unsigned char)sum->buttons[12]; // D-pad up
|
||||||
query.response[12] = (unsigned char)sum->buttons[14]; //D-pad down
|
query.response[12] = (unsigned char)sum->buttons[14]; // D-pad down
|
||||||
|
|
||||||
query.response[13] = (unsigned char)sum->buttons[8]; // Triangle
|
query.response[13] = (unsigned char)sum->buttons[8]; // Triangle
|
||||||
query.response[14] = (unsigned char)sum->buttons[9]; // Circle
|
query.response[14] = (unsigned char)sum->buttons[9]; // Circle
|
||||||
|
|
|
@ -106,6 +106,7 @@ BEGIN
|
||||||
PUSHBUTTON "Exclude Input",ID_EXCLUDE,7,246,58,15
|
PUSHBUTTON "Exclude Input",ID_EXCLUDE,7,246,58,15
|
||||||
// Force Feedback & Input configurations:
|
// Force Feedback & Input configurations:
|
||||||
PUSHBUTTON "Back to Controls",ID_CONTROLS,196,260,59,15
|
PUSHBUTTON "Back to Controls",ID_CONTROLS,196,260,59,15
|
||||||
|
PUSHBUTTON "Reset Configuration",ID_RESET_CONFIG,259,260,72,15
|
||||||
// Force Feedback configuration:
|
// Force Feedback configuration:
|
||||||
GROUPBOX "",ID_FF,195,9,222,248
|
GROUPBOX "",ID_FF,195,9,222,248
|
||||||
COMBOBOX IDC_FF_EFFECT,203,23,206,106,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
|
COMBOBOX IDC_FF_EFFECT,203,23,206,106,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
|
||||||
|
@ -133,10 +134,10 @@ BEGIN
|
||||||
CONTROL "Axis 6",IDC_FF_AXIS6_ENABLED,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,205,243,91,10
|
CONTROL "Axis 6",IDC_FF_AXIS6_ENABLED,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,205,243,91,10
|
||||||
CONTROL "Flip",IDC_FF_AXIS6_FLIP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,302,243,35,10
|
CONTROL "Flip",IDC_FF_AXIS6_FLIP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,302,243,35,10
|
||||||
EDITTEXT IDC_FF_AXIS6_SCALE,375,243,33,12,ES_RIGHT | ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP,WS_EX_RTLREADING
|
EDITTEXT IDC_FF_AXIS6_SCALE,375,243,33,12,ES_RIGHT | ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP,WS_EX_RTLREADING
|
||||||
PUSHBUTTON "Test",ID_TEST,257,260,59,15
|
PUSHBUTTON "Test",ID_TEST,335,260,59,15
|
||||||
// Input configuration:
|
// Input configuration:
|
||||||
GROUPBOX "Configure Binding",ID_SENSITIVITY,195,9,222,110
|
GROUPBOX "Configure Binding",ID_SENSITIVITY,195,9,222,110
|
||||||
EDITTEXT IDC_AXIS_DEVICE,202,22,74,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
EDITTEXT IDC_AXIS_DEVICE,202,22,72,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
||||||
COMBOBOX IDC_AXIS_DIRECTION,276,20,70,47,CBS_DROPDOWNLIST | WS_TABSTOP
|
COMBOBOX IDC_AXIS_DIRECTION,276,20,70,47,CBS_DROPDOWNLIST | WS_TABSTOP
|
||||||
EDITTEXT IDC_AXIS_CONTROL,349,22,65,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
EDITTEXT IDC_AXIS_CONTROL,349,22,65,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
||||||
CONTROL "Flip",IDC_FLIP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,202,37,27,10
|
CONTROL "Flip",IDC_FLIP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,202,37,27,10
|
||||||
|
@ -189,6 +190,7 @@ BEGIN
|
||||||
PUSHBUTTON "Exclude Input",ID_EXCLUDE,7,246,58,15
|
PUSHBUTTON "Exclude Input",ID_EXCLUDE,7,246,58,15
|
||||||
// Force Feedback & Input configurations:
|
// Force Feedback & Input configurations:
|
||||||
PUSHBUTTON "Back to Controls",ID_CONTROLS,196,260,59,15
|
PUSHBUTTON "Back to Controls",ID_CONTROLS,196,260,59,15
|
||||||
|
PUSHBUTTON "Reset Configuration",ID_RESET_CONFIG,259,260,72,15
|
||||||
// Force Feedback configuration:
|
// Force Feedback configuration:
|
||||||
GROUPBOX "",ID_FF,195,9,222,248
|
GROUPBOX "",ID_FF,195,9,222,248
|
||||||
COMBOBOX IDC_FF_EFFECT,203,23,206,106,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
|
COMBOBOX IDC_FF_EFFECT,203,23,206,106,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
|
||||||
|
@ -216,10 +218,10 @@ BEGIN
|
||||||
CONTROL "Axis 6",IDC_FF_AXIS6_ENABLED,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,205,243,91,10
|
CONTROL "Axis 6",IDC_FF_AXIS6_ENABLED,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,205,243,91,10
|
||||||
CONTROL "Flip",IDC_FF_AXIS6_FLIP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,302,243,35,10
|
CONTROL "Flip",IDC_FF_AXIS6_FLIP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,302,243,35,10
|
||||||
EDITTEXT IDC_FF_AXIS6_SCALE,375,243,33,12,ES_RIGHT | ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP,WS_EX_RTLREADING
|
EDITTEXT IDC_FF_AXIS6_SCALE,375,243,33,12,ES_RIGHT | ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP,WS_EX_RTLREADING
|
||||||
PUSHBUTTON "Test",ID_TEST,257,260,59,15
|
PUSHBUTTON "Test",ID_TEST,335,260,59,15
|
||||||
// Input configuration:
|
// Input configuration:
|
||||||
GROUPBOX "Configure Binding",ID_SENSITIVITY,195,9,222,110
|
GROUPBOX "Configure Binding",ID_SENSITIVITY,195,9,222,110
|
||||||
EDITTEXT IDC_AXIS_DEVICE,202,22,74,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
EDITTEXT IDC_AXIS_DEVICE,202,22,72,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
||||||
COMBOBOX IDC_AXIS_DIRECTION,276,20,70,47,CBS_DROPDOWNLIST | WS_TABSTOP
|
COMBOBOX IDC_AXIS_DIRECTION,276,20,70,47,CBS_DROPDOWNLIST | WS_TABSTOP
|
||||||
EDITTEXT IDC_AXIS_CONTROL,349,22,65,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
EDITTEXT IDC_AXIS_CONTROL,349,22,65,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
||||||
CONTROL "Flip",IDC_FLIP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,202,37,27,10
|
CONTROL "Flip",IDC_FLIP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,202,37,27,10
|
||||||
|
@ -272,6 +274,7 @@ BEGIN
|
||||||
PUSHBUTTON "Exclude Input",ID_EXCLUDE,7,246,58,15
|
PUSHBUTTON "Exclude Input",ID_EXCLUDE,7,246,58,15
|
||||||
// Force Feedback & Input configurations:
|
// Force Feedback & Input configurations:
|
||||||
PUSHBUTTON "Back to Controls",ID_CONTROLS,196,260,59,15
|
PUSHBUTTON "Back to Controls",ID_CONTROLS,196,260,59,15
|
||||||
|
PUSHBUTTON "Reset Configuration",ID_RESET_CONFIG,259,260,72,15
|
||||||
// Force Feedback configuration:
|
// Force Feedback configuration:
|
||||||
GROUPBOX "",ID_FF,195,9,222,248
|
GROUPBOX "",ID_FF,195,9,222,248
|
||||||
COMBOBOX IDC_FF_EFFECT,203,23,206,106,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
|
COMBOBOX IDC_FF_EFFECT,203,23,206,106,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
|
||||||
|
@ -299,10 +302,10 @@ BEGIN
|
||||||
CONTROL "Axis 6",IDC_FF_AXIS6_ENABLED,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,205,243,91,10
|
CONTROL "Axis 6",IDC_FF_AXIS6_ENABLED,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,205,243,91,10
|
||||||
CONTROL "Flip",IDC_FF_AXIS6_FLIP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,302,243,35,10
|
CONTROL "Flip",IDC_FF_AXIS6_FLIP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,302,243,35,10
|
||||||
EDITTEXT IDC_FF_AXIS6_SCALE,375,243,33,12,ES_RIGHT | ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP,WS_EX_RTLREADING
|
EDITTEXT IDC_FF_AXIS6_SCALE,375,243,33,12,ES_RIGHT | ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP,WS_EX_RTLREADING
|
||||||
PUSHBUTTON "Test",ID_TEST,257,260,59,15
|
PUSHBUTTON "Test",ID_TEST,335,260,59,15
|
||||||
// Input configuration:
|
// Input configuration:
|
||||||
GROUPBOX "Configure Binding",ID_SENSITIVITY,195,9,222,110
|
GROUPBOX "Configure Binding",ID_SENSITIVITY,195,9,222,110
|
||||||
EDITTEXT IDC_AXIS_DEVICE,202,22,74,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
EDITTEXT IDC_AXIS_DEVICE,202,22,72,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
||||||
COMBOBOX IDC_AXIS_DIRECTION,276,20,70,47,CBS_DROPDOWNLIST | WS_TABSTOP
|
COMBOBOX IDC_AXIS_DIRECTION,276,20,70,47,CBS_DROPDOWNLIST | WS_TABSTOP
|
||||||
EDITTEXT IDC_AXIS_CONTROL,349,22,65,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
EDITTEXT IDC_AXIS_CONTROL,349,22,65,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
||||||
CONTROL "Flip",IDC_FLIP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,202,37,27,10
|
CONTROL "Flip",IDC_FLIP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,202,37,27,10
|
||||||
|
@ -353,9 +356,10 @@ BEGIN
|
||||||
PUSHBUTTON "Exclude Input",ID_EXCLUDE,7,246,58,15
|
PUSHBUTTON "Exclude Input",ID_EXCLUDE,7,246,58,15
|
||||||
// Force Feedback & Input configurations:
|
// Force Feedback & Input configurations:
|
||||||
PUSHBUTTON "Back to Controls",ID_CONTROLS,196,260,59,15
|
PUSHBUTTON "Back to Controls",ID_CONTROLS,196,260,59,15
|
||||||
|
PUSHBUTTON "Reset Configuration",ID_RESET_CONFIG,259,260,72,15
|
||||||
// Input configuration:
|
// Input configuration:
|
||||||
GROUPBOX "Configure Binding",ID_SENSITIVITY,195,9,222,110
|
GROUPBOX "Configure Binding",ID_SENSITIVITY,195,9,222,110
|
||||||
EDITTEXT IDC_AXIS_DEVICE,202,22,74,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
EDITTEXT IDC_AXIS_DEVICE,202,22,72,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
||||||
COMBOBOX IDC_AXIS_DIRECTION,276,20,70,47,CBS_DROPDOWNLIST | WS_TABSTOP
|
COMBOBOX IDC_AXIS_DIRECTION,276,20,70,47,CBS_DROPDOWNLIST | WS_TABSTOP
|
||||||
EDITTEXT IDC_AXIS_CONTROL,349,22,65,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
EDITTEXT IDC_AXIS_CONTROL,349,22,65,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
||||||
CONTROL "Flip",IDC_FLIP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,202,37,27,10
|
CONTROL "Flip",IDC_FLIP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,202,37,27,10
|
||||||
|
@ -416,9 +420,10 @@ BEGIN
|
||||||
PUSHBUTTON "Exclude Input",ID_EXCLUDE,7,246,58,15
|
PUSHBUTTON "Exclude Input",ID_EXCLUDE,7,246,58,15
|
||||||
// Force Feedback & Input configurations:
|
// Force Feedback & Input configurations:
|
||||||
PUSHBUTTON "Back to Controls",ID_CONTROLS,196,260,59,15
|
PUSHBUTTON "Back to Controls",ID_CONTROLS,196,260,59,15
|
||||||
|
PUSHBUTTON "Reset Configuration",ID_RESET_CONFIG,259,260,72,15
|
||||||
// Input configuration:
|
// Input configuration:
|
||||||
GROUPBOX "Configure Binding",ID_SENSITIVITY,195,9,222,110
|
GROUPBOX "Configure Binding",ID_SENSITIVITY,195,9,222,110
|
||||||
EDITTEXT IDC_AXIS_DEVICE,202,22,74,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
EDITTEXT IDC_AXIS_DEVICE,202,22,72,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
||||||
COMBOBOX IDC_AXIS_DIRECTION,276,20,70,47,CBS_DROPDOWNLIST | WS_TABSTOP
|
COMBOBOX IDC_AXIS_DIRECTION,276,20,70,47,CBS_DROPDOWNLIST | WS_TABSTOP
|
||||||
EDITTEXT IDC_AXIS_CONTROL,349,22,65,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
EDITTEXT IDC_AXIS_CONTROL,349,22,65,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
||||||
CONTROL "Flip",IDC_FLIP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,202,37,27,10
|
CONTROL "Flip",IDC_FLIP,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,202,37,27,10
|
||||||
|
|
|
@ -65,6 +65,8 @@ LPWSTR dialog_message(int ID, bool *updateText)
|
||||||
L"Right-click and select \"Refresh\" to update the list of devices in case a recently connected device has not shown up yet.";
|
L"Right-click and select \"Refresh\" to update the list of devices in case a recently connected device has not shown up yet.";
|
||||||
case IDC_G_XI:
|
case IDC_G_XI:
|
||||||
return L"Xbox 360 controllers(and devices imitating it) only";
|
return L"Xbox 360 controllers(and devices imitating it) only";
|
||||||
|
case ID_RESTORE_DEFAULTS:
|
||||||
|
return L"Restores the default contents of LilyPad.ini, undoing all settings changes and bindings that have been set up.";
|
||||||
// Pad tabs
|
// Pad tabs
|
||||||
case IDC_BINDINGS_LIST:
|
case IDC_BINDINGS_LIST:
|
||||||
return L"Shows a list of currently bound inputs of the selected Pad.\n\n"
|
return L"Shows a list of currently bound inputs of the selected Pad.\n\n"
|
||||||
|
@ -92,6 +94,9 @@ LPWSTR dialog_message(int ID, bool *updateText)
|
||||||
L"Note: Analog mode enables the analog sticks to function on a DualShock controller, while in digital mode it behaves as an original PlayStation controller.\n\n";
|
L"Note: Analog mode enables the analog sticks to function on a DualShock controller, while in digital mode it behaves as an original PlayStation controller.\n\n";
|
||||||
case ID_TURBO_KEY:
|
case ID_TURBO_KEY:
|
||||||
return L"Sets a key to send a TAB press to the emulator, which toggles Turbo mode(200% speed) in PCSX2.";
|
return L"Sets a key to send a TAB press to the emulator, which toggles Turbo mode(200% speed) in PCSX2.";
|
||||||
|
case ID_EXCLUDE:
|
||||||
|
return L"Disables an input so it will be ignored when trying to bind another input.\n\n"
|
||||||
|
L"This is helpful when binding controls for a device with an input that's difficult to center like an accelerator, or just always active like a faulty button or analog stick.";
|
||||||
case ID_LOCK_ALL_INPUT:
|
case ID_LOCK_ALL_INPUT:
|
||||||
return L"Locks the current state of the pad. Any further input is handled normally, but the initial pad state is the locked state instead of a state with no buttons pressed. "
|
return L"Locks the current state of the pad. Any further input is handled normally, but the initial pad state is the locked state instead of a state with no buttons pressed. "
|
||||||
L"Pressing it again releases the old pad state, if the old pad state had any keys pressed. Otherwise, it's released automatically.";
|
L"Pressing it again releases the old pad state, if the old pad state had any keys pressed. Otherwise, it's released automatically.";
|
||||||
|
|
|
@ -123,10 +123,9 @@
|
||||||
#define ID_CLEAR 0x1232
|
#define ID_CLEAR 0x1232
|
||||||
#define ID_SPECIAL_INPUTS 0x1233
|
#define ID_SPECIAL_INPUTS 0x1233
|
||||||
// Pad Force Feedback configuration:
|
// Pad Force Feedback configuration:
|
||||||
#define ID_CONTROLS 0x1300
|
#define ID_TEST 0x1300
|
||||||
#define ID_TEST 0x1301
|
#define ID_FF 0x1301
|
||||||
#define ID_FF 0x1302
|
#define IDC_FF_EFFECT 0x1302
|
||||||
#define IDC_FF_EFFECT 0x1303
|
|
||||||
#define IDC_FF_AXIS1_ENABLED 0x1310
|
#define IDC_FF_AXIS1_ENABLED 0x1310
|
||||||
#define IDC_FF_AXIS1 0x1311
|
#define IDC_FF_AXIS1 0x1311
|
||||||
#define IDC_FF_AXIS1_FLIP 0x1312
|
#define IDC_FF_AXIS1_FLIP 0x1312
|
||||||
|
@ -161,6 +160,7 @@
|
||||||
#define IDC_FF_AXIS8_SCALE 0x1383
|
#define IDC_FF_AXIS8_SCALE 0x1383
|
||||||
// Force Feedback & Input configurations:
|
// Force Feedback & Input configurations:
|
||||||
#define ID_CONTROLS 0x1390
|
#define ID_CONTROLS 0x1390
|
||||||
|
#define ID_RESET_CONFIG 0x1391
|
||||||
|
|
||||||
// Next default values for new objects
|
// Next default values for new objects
|
||||||
//
|
//
|
||||||
|
@ -168,7 +168,7 @@
|
||||||
#ifndef APSTUDIO_READONLY_SYMBOLS
|
#ifndef APSTUDIO_READONLY_SYMBOLS
|
||||||
#define _APS_NEXT_RESOURCE_VALUE 116
|
#define _APS_NEXT_RESOURCE_VALUE 116
|
||||||
#define _APS_NEXT_COMMAND_VALUE 40001
|
#define _APS_NEXT_COMMAND_VALUE 40001
|
||||||
#define _APS_NEXT_CONTROL_VALUE 5009
|
#define _APS_NEXT_CONTROL_VALUE 5010
|
||||||
#define _APS_NEXT_SYMED_VALUE 101
|
#define _APS_NEXT_SYMED_VALUE 101
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue