mirror of https://github.com/PCSX2/pcsx2.git
ZeroPad: Revert the changes to the Windows files in ZeroPad, and ifdef off the changes in the common areas, as the Windows version of ZeroPad is clearly only working by voodoo and bailing wire on Windows. (Note: unable to reproduce ZeroPad working properly in any revision [including playground days] on any version of Windows available. Likely because I don't have any poultry handy to sacrifice.)
git-svn-id: http://pcsx2.googlecode.com/svn/trunk@1130 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
parent
66a8c03ded
commit
b02d6a19dd
|
@ -29,15 +29,15 @@
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
HINSTANCE hInst = NULL;
|
HINSTANCE hInst=NULL;
|
||||||
static pthread_spinlock_t s_mutexStatus;
|
static pthread_spinlock_t s_mutexStatus;
|
||||||
static u32 s_keyPress[2], s_keyRelease[2];
|
static u32 s_keyPress[2], s_keyRelease[2];
|
||||||
extern u16 status[2];
|
extern u16 status[2];
|
||||||
|
|
||||||
extern string s_strIniPath;
|
extern string s_strIniPath;
|
||||||
LRESULT WINAPI PADwndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
LRESULT WINAPI PADwndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
||||||
WNDPROC GSwndProc = NULL;
|
WNDPROC GSwndProc=NULL;
|
||||||
HWND GShwnd = NULL;
|
HWND GShwnd=NULL;
|
||||||
|
|
||||||
extern keyEvent event;
|
extern keyEvent event;
|
||||||
|
|
||||||
|
@ -51,21 +51,19 @@ void SaveConfig()
|
||||||
GetModuleFileName(GetModuleHandle((LPCSTR)hInst), szIniFile, 256);
|
GetModuleFileName(GetModuleHandle((LPCSTR)hInst), szIniFile, 256);
|
||||||
szTemp = strrchr(szIniFile, '\\');
|
szTemp = strrchr(szIniFile, '\\');
|
||||||
|
|
||||||
if (!szTemp) return;
|
if(!szTemp) return;
|
||||||
strcpy(szTemp, "\\inis\\zeropad.ini");
|
strcpy(szTemp, "\\inis\\zeropad.ini");
|
||||||
|
|
||||||
for (j = 0; j < 2 * PADSUBKEYS; j++)
|
for (j=0; j<2; j++) {
|
||||||
{
|
for (i=0; i<PADKEYS; i++) {
|
||||||
for (i = 0; i < PADKEYS; i++)
|
|
||||||
{
|
|
||||||
sprintf(szProf, "%d_%d", j, i);
|
sprintf(szProf, "%d_%d", j, i);
|
||||||
sprintf(szValue, "%d", conf.keys[j][i]);
|
sprintf(szValue, "%d", conf.keys[j][i]);
|
||||||
WritePrivateProfileString("Interface", szProf, szValue, szIniFile);
|
WritePrivateProfileString("Interface", szProf,szValue,szIniFile);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
sprintf(szValue, "%u", conf.log);
|
sprintf(szValue,"%u",conf.log);
|
||||||
WritePrivateProfileString("Interface", "Logging", szValue, szIniFile);
|
WritePrivateProfileString("Interface", "Logging",szValue,szIniFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
void LoadConfig()
|
void LoadConfig()
|
||||||
|
@ -97,21 +95,18 @@ void LoadConfig()
|
||||||
GetModuleFileName(GetModuleHandle((LPCSTR)hInst), szIniFile, 256);
|
GetModuleFileName(GetModuleHandle((LPCSTR)hInst), szIniFile, 256);
|
||||||
szTemp = strrchr(szIniFile, '\\');
|
szTemp = strrchr(szIniFile, '\\');
|
||||||
|
|
||||||
if (!szTemp) return ;
|
if(!szTemp) return ;
|
||||||
strcpy(szTemp, "\\inis\\zeropad.ini");
|
strcpy(szTemp, "\\inis\\zeropad.ini");
|
||||||
fp = fopen("inis\\zeropad.ini", "rt");//check if usbnull.ini really exists
|
fp=fopen("inis\\zeropad.ini","rt");//check if usbnull.ini really exists
|
||||||
if (!fp)
|
if (!fp) {
|
||||||
{
|
CreateDirectory("inis",NULL);
|
||||||
CreateDirectory("inis", NULL);
|
|
||||||
SaveConfig();//save and return
|
SaveConfig();//save and return
|
||||||
return ;
|
return ;
|
||||||
}
|
}
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
|
|
||||||
for (j = 0; j < 2 * PADSUBKEYS; j++)
|
for (j=0; j<2; j++) {
|
||||||
{
|
for (i=0; i<PADKEYS; i++) {
|
||||||
for (i = 0; i < PADKEYS; i++)
|
|
||||||
{
|
|
||||||
sprintf(szProf, "%d_%d", j, i);
|
sprintf(szProf, "%d_%d", j, i);
|
||||||
GetPrivateProfileString("Interface", szProf, NULL, szValue, 20, szIniFile);
|
GetPrivateProfileString("Interface", szProf, NULL, szValue, 20, szIniFile);
|
||||||
conf.keys[j][i] = strtoul(szValue, NULL, 10);
|
conf.keys[j][i] = strtoul(szValue, NULL, 10);
|
||||||
|
@ -122,13 +117,12 @@ void LoadConfig()
|
||||||
conf.log = strtoul(szValue, NULL, 10);
|
conf.log = strtoul(szValue, NULL, 10);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SysMessage(char *fmt, ...)
|
void SysMessage(char *fmt, ...) {
|
||||||
{
|
|
||||||
va_list list;
|
va_list list;
|
||||||
char tmp[512];
|
char tmp[512];
|
||||||
|
|
||||||
va_start(list, fmt);
|
va_start(list,fmt);
|
||||||
vsprintf(tmp, fmt, list);
|
vsprintf(tmp,fmt,list);
|
||||||
va_end(list);
|
va_end(list);
|
||||||
MessageBox(0, tmp, "PADwinKeyb Msg", 0);
|
MessageBox(0, tmp, "PADwinKeyb Msg", 0);
|
||||||
}
|
}
|
||||||
|
@ -141,13 +135,12 @@ s32 _PADopen(void *pDsp)
|
||||||
s_keyPress[0] = s_keyPress[1] = 0;
|
s_keyPress[0] = s_keyPress[1] = 0;
|
||||||
s_keyRelease[0] = s_keyRelease[1] = 0;
|
s_keyRelease[0] = s_keyRelease[1] = 0;
|
||||||
|
|
||||||
if (GShwnd != NULL && GSwndProc != NULL)
|
if( GShwnd != NULL && GSwndProc != NULL ) {
|
||||||
{
|
|
||||||
// revert
|
// revert
|
||||||
SetWindowLongPtr(GShwnd, GWLP_WNDPROC, (LPARAM)(WNDPROC)(GSwndProc));
|
SetWindowLongPtr(GShwnd, GWLP_WNDPROC, (LPARAM)(WNDPROC)(GSwndProc));
|
||||||
}
|
}
|
||||||
|
|
||||||
GShwnd = (HWND) * (long*)pDsp;
|
GShwnd = (HWND)*(long*)pDsp;
|
||||||
GSwndProc = (WNDPROC)GetWindowLongPtr(GShwnd, GWLP_WNDPROC);
|
GSwndProc = (WNDPROC)GetWindowLongPtr(GShwnd, GWLP_WNDPROC);
|
||||||
GSwndProc = ((WNDPROC)SetWindowLongPtr(GShwnd, GWLP_WNDPROC, (LPARAM)(WNDPROC)(PADwndProc)));
|
GSwndProc = ((WNDPROC)SetWindowLongPtr(GShwnd, GWLP_WNDPROC, (LPARAM)(WNDPROC)(PADwndProc)));
|
||||||
|
|
||||||
|
@ -156,8 +149,7 @@ s32 _PADopen(void *pDsp)
|
||||||
|
|
||||||
void _PADclose()
|
void _PADclose()
|
||||||
{
|
{
|
||||||
if (GShwnd != NULL && GSwndProc != NULL)
|
if( GShwnd != NULL && GSwndProc != NULL ) {
|
||||||
{
|
|
||||||
SetWindowLongPtr(GShwnd, GWLP_WNDPROC, (LPARAM)(WNDPROC)(GSwndProc));
|
SetWindowLongPtr(GShwnd, GWLP_WNDPROC, (LPARAM)(WNDPROC)(GSwndProc));
|
||||||
GSwndProc = NULL;
|
GSwndProc = NULL;
|
||||||
GShwnd = NULL;
|
GShwnd = NULL;
|
||||||
|
@ -181,30 +173,40 @@ void CALLBACK PADupdate(int pad)
|
||||||
|
|
||||||
LRESULT WINAPI PADwndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
LRESULT WINAPI PADwndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
||||||
{
|
{
|
||||||
int i, pad, keyPress[2] = {0}, keyRelease[2] = {0};
|
int i,pad,keyPress[2]={0},keyRelease[2]={0};
|
||||||
static bool lbutton = false, rbutton = false;
|
static bool lbutton=false,rbutton=false;
|
||||||
|
|
||||||
switch (msg)
|
switch (msg) {
|
||||||
{
|
|
||||||
case WM_KEYDOWN:
|
case WM_KEYDOWN:
|
||||||
if (lParam & 0x40000000)
|
if (lParam & 0x40000000)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
i = FindKey(wParam, pad);
|
for(pad = 0; pad < 2; ++pad ) {
|
||||||
if (i != -1) {
|
for (i=0; i<PADKEYS; i++) {
|
||||||
keyPress[pad] |= (1 << i);
|
if (wParam == conf.keys[pad][i]) {
|
||||||
keyRelease[pad] &= ~(1 << i);
|
keyPress[pad] |=(1<<i);
|
||||||
|
keyRelease[pad] &=~(1<<i);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
event.evt = KEYPRESS;
|
event.evt = KEYPRESS;
|
||||||
event.key = wParam;
|
event.key = wParam;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case WM_KEYUP:
|
case WM_KEYUP:
|
||||||
i = FindKey(wParam, pad);
|
for(pad = 0; pad < 2; ++pad ) {
|
||||||
if (i != -1) {
|
for (i=0; i<PADKEYS; i++) {
|
||||||
keyPress[pad] &= ~(1 << i);
|
if (wParam == conf.keys[pad][i]) {
|
||||||
keyRelease[pad] |= (1 << i);
|
keyPress[pad] &=~(1<<i);
|
||||||
|
keyRelease[pad] |= (1<<i);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
event.evt = KEYRELEASE;
|
event.evt = KEYRELEASE;
|
||||||
event.key = wParam;
|
event.key = wParam;
|
||||||
break;
|
break;
|
||||||
|
@ -234,14 +236,14 @@ LRESULT WINAPI PADwndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case WM_MOUSEMOVE:
|
case WM_MOUSEMOVE:
|
||||||
if (lbutton)
|
if(lbutton)
|
||||||
{
|
{
|
||||||
g_lanalog[0].x = LOWORD(lParam) & 254;
|
g_lanalog[0].x = LOWORD(lParam) & 254;
|
||||||
g_lanalog[0].y = HIWORD(lParam) & 254;
|
g_lanalog[0].y = HIWORD(lParam) & 254;
|
||||||
g_lanalog[1].x = LOWORD(lParam) & 254;
|
g_lanalog[1].x = LOWORD(lParam) & 254;
|
||||||
g_lanalog[1].y = HIWORD(lParam) & 254;
|
g_lanalog[1].y = HIWORD(lParam) & 254;
|
||||||
}
|
}
|
||||||
if (rbutton)
|
if(rbutton)
|
||||||
{
|
{
|
||||||
g_ranalog[0].x = LOWORD(lParam) & 254;
|
g_ranalog[0].x = LOWORD(lParam) & 254;
|
||||||
g_ranalog[0].y = HIWORD(lParam) & 254;
|
g_ranalog[0].y = HIWORD(lParam) & 254;
|
||||||
|
@ -261,8 +263,7 @@ LRESULT WINAPI PADwndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
||||||
}
|
}
|
||||||
|
|
||||||
pthread_spin_lock(&s_mutexStatus);
|
pthread_spin_lock(&s_mutexStatus);
|
||||||
for (pad = 0; pad < 2; ++pad)
|
for(pad = 0; pad < 2; ++pad ) {
|
||||||
{
|
|
||||||
s_keyPress[pad] |= keyPress[pad];
|
s_keyPress[pad] |= keyPress[pad];
|
||||||
s_keyPress[pad] &= ~keyRelease[pad];
|
s_keyPress[pad] &= ~keyRelease[pad];
|
||||||
s_keyRelease[pad] |= keyRelease[pad];
|
s_keyRelease[pad] |= keyRelease[pad];
|
||||||
|
@ -276,61 +277,56 @@ LRESULT WINAPI PADwndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
||||||
string GetKeyLabel(const int pad, const int index)
|
string GetKeyLabel(const int pad, const int index)
|
||||||
{
|
{
|
||||||
const int key = conf.keys[pad][index];
|
const int key = conf.keys[pad][index];
|
||||||
char buff[16] = "NONE)";
|
char buff[16]="NONE)";
|
||||||
|
|
||||||
if (key < 0x100)
|
if (key < 0x100)
|
||||||
{
|
{
|
||||||
if (key == 0)
|
if (key == 0)
|
||||||
strcpy(buff, "NONE");
|
strcpy (buff, "NONE");
|
||||||
else
|
else {
|
||||||
{
|
if(key>=0x60 && key<=0x69) {
|
||||||
if (key >= 0x60 && key <= 0x69)
|
|
||||||
sprintf(buff, "NumPad %c", '0' + key - 0x60);
|
sprintf(buff, "NumPad %c", '0' + key - 0x60);
|
||||||
else
|
}
|
||||||
sprintf(buff, "%c", key);
|
else sprintf(buff, "%c", key);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (key >= 0x1000 && key < 0x2000)
|
else if (key >= 0x1000 && key < 0x2000)
|
||||||
{
|
{
|
||||||
sprintf(buff, "J%d_%d", (key & 0xfff) / 0x100, (key & 0xff) + 1);
|
sprintf (buff, "J%d_%d", (key & 0xfff) / 0x100, (key & 0xff) + 1);
|
||||||
}
|
}
|
||||||
else if (key >= 0x2000 && key < 0x3000)
|
else if (key >= 0x2000 && key < 0x3000)
|
||||||
{
|
{
|
||||||
static const char name[][4] = { "MIN", "MAX" };
|
static const char name[][4] = { "MIN", "MAX" };
|
||||||
const int axis = (key & 0xff);
|
const int axis = (key & 0xff);
|
||||||
|
sprintf (buff, "J%d_AXIS%d_%s", (key & 0xfff) / 0x100, axis / 2, name[axis % 2]);
|
||||||
sprintf(buff, "J%d_AXIS%d_%s", (key & 0xfff) / 0x100, axis / 2, name[axis % 2]);
|
if (index >= 17 && index <= 20)
|
||||||
if (index >= 17 && index <= 20) buff[strlen(buff) -4] = '\0';
|
buff[strlen (buff) -4] = '\0';
|
||||||
}
|
}
|
||||||
else if (key >= 0x3000 && key < 0x4000)
|
else if (key >= 0x3000 && key < 0x4000)
|
||||||
{
|
{
|
||||||
static const char name[][7] = { "FOWARD", "RIGHT", "BACK", "LEFT" };
|
static const char name[][7] = { "FOWARD", "RIGHT", "BACK", "LEFT" };
|
||||||
const int pov = (key & 0xff);
|
const int pov = (key & 0xff);
|
||||||
sprintf(buff, "J%d_POV%d_%s", (key & 0xfff) / 0x100, pov / 4, name[pov % 4]);
|
sprintf (buff, "J%d_POV%d_%s", (key & 0xfff) / 0x100, pov /4, name[pov % 4]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return buff;
|
return buff;
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOL CALLBACK ConfigureDlgProc(HWND hW, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
BOOL CALLBACK ConfigureDlgProc(HWND hW, UINT uMsg, WPARAM wParam, LPARAM lParam) {
|
||||||
{
|
|
||||||
HWND hWC;
|
HWND hWC;
|
||||||
TCITEM tcI;
|
TCITEM tcI;
|
||||||
int i, key, numkeys;
|
int i,key, numkeys;
|
||||||
u8* pkeyboard;
|
u8* pkeyboard;
|
||||||
static int disabled = 0;
|
static int disabled=0;
|
||||||
static int padn = 0;
|
static int padn=0;
|
||||||
|
|
||||||
switch (uMsg)
|
switch(uMsg) {
|
||||||
{
|
|
||||||
case WM_INITDIALOG:
|
case WM_INITDIALOG:
|
||||||
LoadConfig();
|
LoadConfig();
|
||||||
padn = 0;
|
padn = 0;
|
||||||
if (conf.log) CheckDlgButton(hW, IDC_LOG, TRUE);
|
if (conf.log) CheckDlgButton(hW, IDC_LOG, TRUE);
|
||||||
|
|
||||||
for (i = 0; i < PADKEYS; i++)
|
for (i=0; i<PADKEYS; i++) {
|
||||||
{
|
hWC = GetDlgItem(hW, IDC_L2 + i*2);
|
||||||
hWC = GetDlgItem(hW, IDC_L2 + i * 2);
|
|
||||||
Button_SetText(hWC, GetKeyLabel(padn, i).c_str());
|
Button_SetText(hWC, GetKeyLabel(padn, i).c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -348,46 +344,41 @@ BOOL CALLBACK ConfigureDlgProc(HWND hW, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
case WM_TIMER:
|
case WM_TIMER:
|
||||||
if (disabled)
|
if (disabled){
|
||||||
{
|
|
||||||
key = 0;
|
key = 0;
|
||||||
//pkeyboard = SDL_GetKeyState(&numkeys);
|
//pkeyboard = SDL_GetKeyState(&numkeys);
|
||||||
for (int i = 0; i < numkeys; ++i)
|
for (int i = 0; i < numkeys; ++i) {
|
||||||
{
|
if( pkeyboard[i] ) {
|
||||||
if (pkeyboard[i])
|
|
||||||
{
|
|
||||||
key = i;
|
key = i;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (key == 0)
|
if( key == 0 ) {
|
||||||
{
|
|
||||||
// check joystick
|
// check joystick
|
||||||
}
|
}
|
||||||
|
|
||||||
if (key != 0)
|
if (key != 0){
|
||||||
{
|
|
||||||
KillTimer(hW, 0x80);
|
KillTimer(hW, 0x80);
|
||||||
hWC = GetDlgItem(hW, disabled);
|
hWC = GetDlgItem(hW, disabled);
|
||||||
conf.keys[padn][disabled-IDC_L2] = key;
|
conf.keys[padn][disabled-IDC_L2] = key;
|
||||||
Button_SetText(hWC, GetKeyLabel(padn, disabled - IDC_L2).c_str());
|
Button_SetText(hWC, GetKeyLabel(padn, disabled-IDC_L2).c_str());
|
||||||
EnableWindow(hWC, TRUE);
|
EnableWindow(hWC, TRUE);
|
||||||
disabled = 0;
|
disabled=0;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
case WM_COMMAND:
|
case WM_COMMAND:
|
||||||
for (i = IDC_L2; i <= IDC_LEFT; i += 2)
|
for(i = IDC_L2; i <= IDC_LEFT; i+=2)
|
||||||
{
|
{
|
||||||
if (LOWORD(wParam) == i)
|
if(LOWORD(wParam) == i)
|
||||||
{
|
{
|
||||||
if (disabled)//change selection
|
if (disabled)//change selection
|
||||||
EnableWindow(GetDlgItem(hW, disabled), TRUE);
|
EnableWindow(GetDlgItem(hW, disabled), TRUE);
|
||||||
|
|
||||||
EnableWindow(GetDlgItem(hW, disabled = wParam), FALSE);
|
EnableWindow(GetDlgItem(hW, disabled=wParam), FALSE);
|
||||||
|
|
||||||
SetTimer(hW, 0x80, 250, NULL);
|
SetTimer(hW, 0x80, 250, NULL);
|
||||||
|
|
||||||
|
@ -395,21 +386,16 @@ BOOL CALLBACK ConfigureDlgProc(HWND hW, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (LOWORD(wParam))
|
switch(LOWORD(wParam)) {
|
||||||
{
|
|
||||||
case IDCANCEL:
|
case IDCANCEL:
|
||||||
KillTimer(hW, 0x80);
|
KillTimer(hW, 0x80);
|
||||||
EndDialog(hW, TRUE);
|
EndDialog(hW, TRUE);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
case IDOK:
|
case IDOK:
|
||||||
KillTimer(hW, 0x80);
|
KillTimer(hW, 0x80);
|
||||||
|
|
||||||
if (IsDlgButtonChecked(hW, IDC_LOG))
|
if (IsDlgButtonChecked(hW, IDC_LOG))
|
||||||
conf.log = 1;
|
conf.log = 1;
|
||||||
else
|
else conf.log = 0;
|
||||||
conf.log = 0;
|
|
||||||
|
|
||||||
SaveConfig();
|
SaveConfig();
|
||||||
EndDialog(hW, FALSE);
|
EndDialog(hW, FALSE);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
@ -417,18 +403,17 @@ BOOL CALLBACK ConfigureDlgProc(HWND hW, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case WM_NOTIFY:
|
case WM_NOTIFY:
|
||||||
switch (wParam)
|
switch (wParam) {
|
||||||
{
|
|
||||||
case IDC_TABC:
|
case IDC_TABC:
|
||||||
hWC = GetDlgItem(hW, IDC_TABC);
|
hWC = GetDlgItem(hW, IDC_TABC);
|
||||||
padn = TabCtrl_GetCurSel(hWC);
|
padn = TabCtrl_GetCurSel(hWC);
|
||||||
|
|
||||||
for (i = 0; i < PADKEYS; i++)
|
for (i=0; i<PADKEYS; i++) {
|
||||||
{
|
|
||||||
hWC = GetDlgItem(hW, IDC_EL3 + i);
|
hWC = GetDlgItem(hW, IDC_EL3 + i);
|
||||||
Button_SetText(hWC, GetKeyLabel(padn, i).c_str());
|
Button_SetText(hWC, GetKeyLabel(padn, i).c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
@ -436,16 +421,13 @@ BOOL CALLBACK ConfigureDlgProc(HWND hW, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOL CALLBACK AboutDlgProc(HWND hW, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
BOOL CALLBACK AboutDlgProc(HWND hW, UINT uMsg, WPARAM wParam, LPARAM lParam) {
|
||||||
{
|
switch(uMsg) {
|
||||||
switch (uMsg)
|
|
||||||
{
|
|
||||||
case WM_INITDIALOG:
|
case WM_INITDIALOG:
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
case WM_COMMAND:
|
case WM_COMMAND:
|
||||||
switch (LOWORD(wParam))
|
switch(LOWORD(wParam)) {
|
||||||
{
|
|
||||||
case IDOK:
|
case IDOK:
|
||||||
EndDialog(hW, FALSE);
|
EndDialog(hW, FALSE);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
@ -454,28 +436,24 @@ BOOL CALLBACK AboutDlgProc(HWND hW, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CALLBACK PADconfigure()
|
void CALLBACK PADconfigure() {
|
||||||
{
|
|
||||||
DialogBox(hInst,
|
DialogBox(hInst,
|
||||||
MAKEINTRESOURCE(IDD_DIALOG1),
|
MAKEINTRESOURCE(IDD_DIALOG1),
|
||||||
GetActiveWindow(),
|
GetActiveWindow(),
|
||||||
(DLGPROC)ConfigureDlgProc);
|
(DLGPROC)ConfigureDlgProc);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CALLBACK PADabout()
|
void CALLBACK PADabout() {
|
||||||
{
|
|
||||||
SysMessage("Author: zerofrog\nThanks to SSSPSXPad, TwinPAD, and PADwin plugins");
|
SysMessage("Author: zerofrog\nThanks to SSSPSXPad, TwinPAD, and PADwin plugins");
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 CALLBACK PADtest()
|
s32 CALLBACK PADtest() {
|
||||||
{
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOL APIENTRY DllMain(HANDLE hModule, // DLL INIT
|
BOOL APIENTRY DllMain(HANDLE hModule, // DLL INIT
|
||||||
DWORD dwReason,
|
DWORD dwReason,
|
||||||
LPVOID lpReserved)
|
LPVOID lpReserved) {
|
||||||
{
|
|
||||||
hInst = (HINSTANCE)hModule;
|
hInst = (HINSTANCE)hModule;
|
||||||
return TRUE; // very quick :)
|
return TRUE; // very quick :)
|
||||||
}
|
}
|
||||||
|
|
|
@ -136,6 +136,14 @@ void _KeyPress(int pad, u32 key)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
for (i=0; i<PADKEYS; i++) {
|
||||||
|
if (key == conf.keys[pad][i]) {
|
||||||
|
status[pad]&=~(1<<i);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#else
|
||||||
for (int p = 0; p < PADSUBKEYS; p++)
|
for (int p = 0; p < PADSUBKEYS; p++)
|
||||||
{
|
{
|
||||||
for (i = 0; i < PADKEYS; i++)
|
for (i = 0; i < PADKEYS; i++)
|
||||||
|
@ -147,6 +155,7 @@ void _KeyPress(int pad, u32 key)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
event.evt = KEYPRESS;
|
event.evt = KEYPRESS;
|
||||||
event.key = key;
|
event.key = key;
|
||||||
|
@ -156,6 +165,14 @@ void _KeyRelease(int pad, u32 key)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
for (i=0; i<PADKEYS; i++) {
|
||||||
|
if (key == conf.keys[pad][i]) {
|
||||||
|
status[pad]|= (1<<i);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#else
|
||||||
for (int p = 0; p < PADSUBKEYS; p++)
|
for (int p = 0; p < PADSUBKEYS; p++)
|
||||||
{
|
{
|
||||||
for (i = 0; i < PADKEYS; i++)
|
for (i = 0; i < PADKEYS; i++)
|
||||||
|
@ -167,7 +184,7 @@ void _KeyRelease(int pad, u32 key)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
event.evt = KEYRELEASE;
|
event.evt = KEYRELEASE;
|
||||||
event.key = key;
|
event.key = key;
|
||||||
}
|
}
|
||||||
|
|
|
@ -72,7 +72,12 @@ extern char libraryName[256];
|
||||||
#define PADOPTION_REVERTRX 0x8
|
#define PADOPTION_REVERTRX 0x8
|
||||||
#define PADOPTION_REVERTRY 0x10
|
#define PADOPTION_REVERTRY 0x10
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
#define PADSUBKEYS 1
|
||||||
|
#else
|
||||||
#define PADSUBKEYS 2
|
#define PADSUBKEYS 2
|
||||||
|
#endif
|
||||||
|
|
||||||
extern int PadEnum[2][2];
|
extern int PadEnum[2][2];
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
|
|
Loading…
Reference in New Issue