mirror of https://github.com/PCSX2/pcsx2.git
LilyPad: Safely exit fullscreen on escape hack now sends the escape back to PCSX2 as well after un-maximizing the GS window.
Minor changes to the general config screen's hack section. git-svn-id: http://pcsx2.googlecode.com/svn/trunk@709 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
parent
4f63ac1101
commit
d0703dd50f
|
@ -20,6 +20,9 @@
|
||||||
|
|
||||||
GeneralConfig config;
|
GeneralConfig config;
|
||||||
|
|
||||||
|
// 1 if running inside a PS2 emulator. Set to 1 on any
|
||||||
|
// of the PS2-specific functions (PS2EgetLibVersion2, PS2EgetLibType).
|
||||||
|
// Only affects if I allow read input in GS thread to be set.
|
||||||
u8 ps2e = 0;
|
u8 ps2e = 0;
|
||||||
|
|
||||||
HWND hWndProp = 0;
|
HWND hWndProp = 0;
|
||||||
|
|
|
@ -428,7 +428,6 @@ void InputDeviceManager::DisableAllDevices() {
|
||||||
|
|
||||||
void InputDeviceManager::DisableDevice(int index) {
|
void InputDeviceManager::DisableDevice(int index) {
|
||||||
devices[index]->enabled = 0;
|
devices[index]->enabled = 0;
|
||||||
// Should never happen, but just in case...
|
|
||||||
if (devices[index]->active) devices[index]->Deactivate();
|
if (devices[index]->active) devices[index]->Deactivate();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -106,8 +106,6 @@ class Pad {
|
||||||
public:
|
public:
|
||||||
ButtonSum sum, lockedSum;
|
ButtonSum sum, lockedSum;
|
||||||
|
|
||||||
Stick rStick, lStick;
|
|
||||||
|
|
||||||
int lockedState;
|
int lockedState;
|
||||||
u8 vibrate[8];
|
u8 vibrate[8];
|
||||||
|
|
||||||
|
@ -497,6 +495,7 @@ u32 CALLBACK PS2EgetLibVersion2(u32 type) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Used in about and config screens.
|
||||||
void GetNameAndVersionString(wchar_t *out) {
|
void GetNameAndVersionString(wchar_t *out) {
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
wsprintfW(out, L"LilyPad Debug %i.%i.%i (r%i)", (VERSION>>8)&0xFF, VERSION&0xFF, (VERSION>>24)&0xFF, SVN_REV);
|
wsprintfW(out, L"LilyPad Debug %i.%i.%i (r%i)", (VERSION>>8)&0xFF, VERSION&0xFF, (VERSION>>24)&0xFF, SVN_REV);
|
||||||
|
@ -1089,6 +1088,19 @@ DWORD WINAPI RenameWindowThreadProc(void *lpParameter) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*DWORD WINAPI MaximizeWindowThreadProc(void *lpParameter) {
|
||||||
|
while ((HWND)lpParameter == hWnd || hWnd) {
|
||||||
|
Sleep(10);
|
||||||
|
}
|
||||||
|
Sleep(100);
|
||||||
|
keybd_event(VK_LMENU, MapVirtualKey(VK_LMENU, MAPVK_VK_TO_VSC), 0, 0);
|
||||||
|
keybd_event(VK_RETURN, MapVirtualKey(VK_RETURN, MAPVK_VK_TO_VSC), 0, 0);
|
||||||
|
Sleep(10);
|
||||||
|
keybd_event(VK_RETURN, MapVirtualKey(VK_RETURN, MAPVK_VK_TO_VSC), KEYEVENTF_KEYUP, 0);
|
||||||
|
keybd_event(VK_LMENU, MapVirtualKey(VK_LMENU, MAPVK_VK_TO_VSC), KEYEVENTF_KEYUP, 0);
|
||||||
|
return 0;
|
||||||
|
}//*/
|
||||||
|
|
||||||
keyEvent* CALLBACK PADkeyEvent() {
|
keyEvent* CALLBACK PADkeyEvent() {
|
||||||
if (!config.GSThreadUpdates) {
|
if (!config.GSThreadUpdates) {
|
||||||
Update(2);
|
Update(2);
|
||||||
|
@ -1096,13 +1108,32 @@ keyEvent* CALLBACK PADkeyEvent() {
|
||||||
static int shiftDown = 0;
|
static int shiftDown = 0;
|
||||||
static keyEvent ev;
|
static keyEvent ev;
|
||||||
if (!GetQueuedKeyEvent(&ev)) return 0;
|
if (!GetQueuedKeyEvent(&ev)) return 0;
|
||||||
if (ev.key == VK_ESCAPE && ev.evt == KEYPRESS && config.escapeFullscreenHack) {
|
if ((ev.key == VK_ESCAPE || ev.key == -2) && ev.evt == KEYPRESS && config.escapeFullscreenHack) {
|
||||||
if (IsWindowMaximized(hWnd)) {
|
if (IsWindowMaximized(hWnd)) {
|
||||||
|
QueueKeyEvent(-2, KEYPRESS);
|
||||||
|
if (ev.key != -2)
|
||||||
EatWndProc(hWnd, KillFullScreenProc);
|
EatWndProc(hWnd, KillFullScreenProc);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
ev.key = VK_ESCAPE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
if ((ev.key == VK_F9 || ev.key == -1) && ev.evt == KEYPRESS) {
|
||||||
|
if (IsWindowMaximized(hWnd)) {
|
||||||
|
QueueKeyEvent(-1, KEYPRESS);
|
||||||
|
if (ev.key == VK_F9)
|
||||||
|
EatWndProc(hWnd, KillFullScreenProc);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
if (ev.key == -1) {
|
||||||
|
HANDLE hThread = CreateThread(0, 0, MaximizeWindowThreadProc, hWnd, 0, 0);
|
||||||
|
if (hThread) CloseHandle(hThread);
|
||||||
|
}
|
||||||
|
ev.key = VK_F9;
|
||||||
|
}//*/
|
||||||
|
|
||||||
if (ev.key == VK_F2 && ev.evt == KEYPRESS) {
|
if (ev.key == VK_F2 && ev.evt == KEYPRESS) {
|
||||||
saveStateIndex += 1 - 2*shiftDown;
|
saveStateIndex += 1 - 2*shiftDown;
|
||||||
saveStateIndex = (saveStateIndex+10)%10;
|
saveStateIndex = (saveStateIndex+10)%10;
|
||||||
|
@ -1157,7 +1188,7 @@ u32 CALLBACK PSEgetLibVersion() {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Little funkiness to handle rounding floating points to ints without the C runtime.
|
// Little funkiness to handle rounding floating points to ints without the C runtime.
|
||||||
// Unfortunately, means I can't use /GL optimization option.
|
// Unfortunately, means I can't use /GL optimization option when NO_CRT is defined.
|
||||||
#ifdef NO_CRT
|
#ifdef NO_CRT
|
||||||
extern "C" long _cdecl _ftol();
|
extern "C" long _cdecl _ftol();
|
||||||
extern "C" long _cdecl _ftol2_sse() {
|
extern "C" long _cdecl _ftol2_sse() {
|
||||||
|
|
|
@ -264,17 +264,18 @@ BEGIN
|
||||||
GROUPBOX "Hacks",IDC_STATIC,216,211,201,73
|
GROUPBOX "Hacks",IDC_STATIC,216,211,201,73
|
||||||
CONTROL "Send escape on window close",IDC_CLOSE_HACK1,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,224,223,113,10
|
CONTROL "Send escape on window close",IDC_CLOSE_HACK1,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,224,223,113,10
|
||||||
CONTROL "Exit emulator on window close",IDC_CLOSE_HACK2,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,224,235,112,10
|
CONTROL "Exit emulator on window close",IDC_CLOSE_HACK2,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,224,235,112,10
|
||||||
CONTROL "Safe fullscreen exit on escape",IDC_ESCAPE_FULLSCREEN_HACK,
|
CONTROL "Safe fullscreen exit on escape\n(Doesn't like GSDX with DX9)",IDC_ESCAPE_FULLSCREEN_HACK,
|
||||||
"Button",BS_AUTOCHECKBOX | WS_TABSTOP,224,247,112,10
|
"Button",BS_AUTOCHECKBOX | BS_MULTILINE | WS_TABSTOP,224,247,110,18
|
||||||
CONTROL "Always hide cursor",IDC_FORCE_HIDE,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,224,259,71,10
|
CONTROL "Use GS thread\n(Recommended)",IDC_GS_THREAD_INPUT,
|
||||||
CONTROL "Disable screensaver",IDC_DISABLE_SCREENSAVER,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,224,271,80,10
|
"Button",BS_AUTOCHECKBOX | BS_MULTILINE | WS_TABSTOP,224,265,107,16
|
||||||
CONTROL "Guitar Hero 2 Hack",IDC_GH2_HACK,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,336,223,76,10
|
CONTROL "Disable screensaver",IDC_DISABLE_SCREENSAVER,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,336,223,80,10
|
||||||
CONTROL "Use GS thread",IDC_GS_THREAD_INPUT,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,336,235,62,10
|
CONTROL "Always hide cursor",IDC_FORCE_HIDE,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,336,235,71,10
|
||||||
CONTROL "Save state # in title",IDC_SAVE_STATE_TITLE,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,336,247,79,10
|
CONTROL "Save state # in title",IDC_SAVE_STATE_TITLE,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,336,247,79,10
|
||||||
|
CONTROL "Guitar Hero 2 Hack",IDC_GH2_HACK,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,336,259,76,10
|
||||||
GROUPBOX "Debugging",IDC_STATIC,216,285,79,25
|
GROUPBOX "Debugging",IDC_STATIC,216,285,79,25
|
||||||
CONTROL "Enable logging",IDC_DEBUG_FILE,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,223,296,63,10
|
CONTROL "Enable logging",IDC_DEBUG_FILE,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,223,296,63,10
|
||||||
PUSHBUTTON "Save",ID_SAVE,369,295,48,15
|
|
||||||
PUSHBUTTON "Load",ID_LOAD,313,295,48,15
|
PUSHBUTTON "Load",ID_LOAD,313,295,48,15
|
||||||
|
PUSHBUTTON "Save",ID_SAVE,369,295,48,15
|
||||||
END
|
END
|
||||||
|
|
||||||
IDD_ABOUT DIALOGEX 0, 0, 108, 66
|
IDD_ABOUT DIALOGEX 0, 0, 108, 66
|
||||||
|
|
Loading…
Reference in New Issue