2012-11-01 15:19:01 +00:00
|
|
|
// NOTE: Apologies for the quality of this code, this is really from pre-opensource Dolphin - that is, 2003.
|
|
|
|
|
|
|
|
#include <windows.h>
|
2012-11-17 22:44:29 +00:00
|
|
|
#include <tchar.h>
|
2013-03-29 17:50:08 +00:00
|
|
|
|
2013-07-06 19:49:28 +00:00
|
|
|
#include <map>
|
|
|
|
|
2013-03-29 17:50:08 +00:00
|
|
|
#include "base/NativeApp.h"
|
2013-03-11 21:55:29 +00:00
|
|
|
#include "Globals.h"
|
2012-11-01 15:19:01 +00:00
|
|
|
|
|
|
|
#include "shellapi.h"
|
|
|
|
#include "commctrl.h"
|
|
|
|
|
2013-03-29 17:50:08 +00:00
|
|
|
#include "input/input_state.h"
|
2013-07-08 10:35:08 +00:00
|
|
|
#include "input/keycodes.h"
|
2013-03-11 21:55:29 +00:00
|
|
|
#include "Core/Debugger/SymbolMap.h"
|
|
|
|
#include "Windows/OpenGLBase.h"
|
|
|
|
#include "Windows/Debugger/Debugger_Disasm.h"
|
|
|
|
#include "Windows/Debugger/Debugger_MemoryDlg.h"
|
2012-11-01 15:19:01 +00:00
|
|
|
#include "main.h"
|
|
|
|
|
2013-03-11 21:55:29 +00:00
|
|
|
#include "Core/Core.h"
|
|
|
|
#include "Core/MemMap.h"
|
|
|
|
#include "Core/SaveState.h"
|
|
|
|
#include "Core/System.h"
|
|
|
|
#include "Core/Config.h"
|
|
|
|
#include "Windows/EmuThread.h"
|
2012-11-01 15:19:01 +00:00
|
|
|
|
|
|
|
#include "resource.h"
|
|
|
|
|
2013-03-11 21:55:29 +00:00
|
|
|
#include "Windows/WndMainWindow.h"
|
2013-07-06 17:08:59 +00:00
|
|
|
#include "Windows/WindowsHost.h"
|
2013-03-11 21:55:29 +00:00
|
|
|
#include "Common/LogManager.h"
|
|
|
|
#include "Common/ConsoleListener.h"
|
|
|
|
#include "Windows/W32Util/DialogManager.h"
|
|
|
|
#include "Windows/W32Util/ShellUtil.h"
|
|
|
|
#include "Windows/W32Util/Misc.h"
|
|
|
|
#include "GPU/GPUInterface.h"
|
|
|
|
#include "GPU/GPUState.h"
|
2013-04-19 09:21:16 +00:00
|
|
|
#include "native/image/png_load.h"
|
2013-05-01 21:55:34 +00:00
|
|
|
#include "GPU/GLES/TextureScaler.h"
|
2013-05-17 10:31:06 +00:00
|
|
|
#include "ControlMapping.h"
|
2013-05-22 16:00:06 +00:00
|
|
|
#include "UI/OnScreenDisplay.h"
|
|
|
|
#include "i18n/i18n.h"
|
2012-11-01 15:19:01 +00:00
|
|
|
|
|
|
|
#ifdef THEMES
|
|
|
|
#include "XPTheme.h"
|
|
|
|
#endif
|
|
|
|
|
2013-04-16 19:12:55 +00:00
|
|
|
#define ENABLE_TOUCH 0
|
|
|
|
|
2013-07-06 19:49:28 +00:00
|
|
|
extern std::map<int, int> windowsTransTable;
|
2013-05-04 21:21:06 +00:00
|
|
|
BOOL g_bFullScreen = FALSE;
|
2013-03-29 20:21:27 +00:00
|
|
|
static RECT g_normalRC = {0};
|
2013-06-22 20:27:59 +00:00
|
|
|
extern bool g_TakeScreenshot;
|
2013-03-29 17:50:08 +00:00
|
|
|
extern InputState input_state;
|
2013-07-07 08:42:39 +00:00
|
|
|
|
2013-05-04 21:21:06 +00:00
|
|
|
#define TIMER_CURSORUPDATE 1
|
2013-06-11 18:14:53 +00:00
|
|
|
#define TIMER_CURSORMOVEUPDATE 2
|
2013-05-04 21:54:22 +00:00
|
|
|
#define CURSORUPDATE_INTERVAL_MS 50
|
2013-06-11 18:14:53 +00:00
|
|
|
#define CURSORUPDATE_MOVE_TIMESPAN_MS 500
|
2013-04-18 09:13:00 +00:00
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
namespace MainWindow
|
|
|
|
{
|
|
|
|
HWND hwndMain;
|
|
|
|
HWND hwndDisplay;
|
|
|
|
HWND hwndGameList;
|
2013-03-29 20:21:27 +00:00
|
|
|
static HMENU menu;
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2013-03-29 20:21:27 +00:00
|
|
|
static HINSTANCE hInst;
|
2013-05-26 21:55:23 +00:00
|
|
|
static int cursorCounter = 0;
|
2013-06-11 18:14:53 +00:00
|
|
|
static int prevCursorX = -1;
|
|
|
|
static int prevCursorY = -1;
|
|
|
|
static bool mouseButtonDown = false;
|
|
|
|
static bool hideCursor = false;
|
2013-07-07 08:42:39 +00:00
|
|
|
static void *rawInputBuffer;
|
|
|
|
static size_t rawInputBufferSize;
|
2013-07-09 20:25:29 +00:00
|
|
|
static int currentSavestateSlot = 0;
|
2012-11-01 15:19:01 +00:00
|
|
|
|
|
|
|
//W32Util::LayeredWindow *layer;
|
|
|
|
#define MAX_LOADSTRING 100
|
2013-03-29 20:21:27 +00:00
|
|
|
const TCHAR *szTitle = TEXT("PPSSPP");
|
|
|
|
const TCHAR *szWindowClass = TEXT("PPSSPPWnd");
|
|
|
|
const TCHAR *szDisplayClass = TEXT("PPSSPPDisplay");
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2013-03-17 13:46:39 +00:00
|
|
|
// Forward declarations of functions included in this code module:
|
2012-11-01 15:19:01 +00:00
|
|
|
LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM);
|
|
|
|
LRESULT CALLBACK DisplayProc(HWND, UINT, WPARAM, LPARAM);
|
|
|
|
LRESULT CALLBACK About(HWND, UINT, WPARAM, LPARAM);
|
|
|
|
|
2013-07-21 09:21:50 +00:00
|
|
|
const UINT WM_USER_SAVESTATE_FINISH = WM_USER + 100;
|
|
|
|
|
2013-07-07 02:12:06 +00:00
|
|
|
HWND GetHWND() {
|
2012-11-01 15:19:01 +00:00
|
|
|
return hwndMain;
|
|
|
|
}
|
|
|
|
|
2013-07-07 02:12:06 +00:00
|
|
|
HWND GetDisplayHWND() {
|
2012-11-01 15:19:01 +00:00
|
|
|
return hwndDisplay;
|
|
|
|
}
|
|
|
|
|
2013-07-07 02:12:06 +00:00
|
|
|
void Init(HINSTANCE hInstance) {
|
2013-02-19 00:28:13 +00:00
|
|
|
#ifdef THEMES
|
|
|
|
WTL::CTheme::IsThemingSupported();
|
2012-11-01 15:19:01 +00:00
|
|
|
#endif
|
|
|
|
//Register classes
|
|
|
|
WNDCLASSEX wcex;
|
|
|
|
wcex.cbSize = sizeof(WNDCLASSEX);
|
|
|
|
wcex.style = CS_HREDRAW | CS_VREDRAW;
|
|
|
|
wcex.lpfnWndProc = (WNDPROC)WndProc;
|
|
|
|
wcex.cbClsExtra = 0;
|
|
|
|
wcex.cbWndExtra = 0;
|
|
|
|
wcex.hInstance = hInstance;
|
|
|
|
wcex.hIcon = LoadIcon(hInstance, (LPCTSTR)IDI_PPSSPP);
|
|
|
|
wcex.hCursor = LoadCursor(NULL, IDC_ARROW);
|
2012-12-05 06:31:41 +00:00
|
|
|
wcex.hbrBackground = (HBRUSH)GetStockObject(BLACK_BRUSH);
|
2012-11-01 15:19:01 +00:00
|
|
|
wcex.lpszMenuName = (LPCSTR)IDR_MENU1;
|
|
|
|
wcex.lpszClassName = szWindowClass;
|
|
|
|
wcex.hIconSm = (HICON)LoadImage(hInstance, (LPCTSTR)IDI_PPSSPP, IMAGE_ICON, 16,16,LR_SHARED);
|
|
|
|
RegisterClassEx(&wcex);
|
|
|
|
|
|
|
|
wcex.style = CS_HREDRAW | CS_VREDRAW;;
|
|
|
|
wcex.lpfnWndProc = (WNDPROC)DisplayProc;
|
|
|
|
wcex.hIcon = 0;
|
|
|
|
wcex.hbrBackground = (HBRUSH)GetStockObject(BLACK_BRUSH);
|
|
|
|
wcex.lpszMenuName = 0;
|
|
|
|
wcex.lpszClassName = szDisplayClass;
|
|
|
|
wcex.hIconSm = 0;
|
|
|
|
RegisterClassEx(&wcex);
|
|
|
|
}
|
|
|
|
|
2012-11-17 16:46:05 +00:00
|
|
|
void GetWindowRectAtZoom(int zoom, RECT &rcInner, RECT &rcOuter) {
|
2013-01-26 22:46:02 +00:00
|
|
|
// GetWindowRect(hwndMain, &rcInner);
|
2013-03-30 23:25:10 +00:00
|
|
|
rcInner.left = 0;
|
|
|
|
rcInner.top = 0;
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2013-03-30 23:25:10 +00:00
|
|
|
rcInner.right=480*zoom;//+client edge
|
|
|
|
rcInner.bottom=272*zoom; //+client edge
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2012-11-17 16:46:05 +00:00
|
|
|
rcOuter=rcInner;
|
|
|
|
AdjustWindowRect(&rcOuter, WS_OVERLAPPEDWINDOW, TRUE);
|
2013-03-30 23:25:10 +00:00
|
|
|
rcOuter.right += g_Config.iWindowX - rcOuter.left;
|
|
|
|
rcOuter.bottom += g_Config.iWindowY - rcOuter.top;
|
|
|
|
rcOuter.left = g_Config.iWindowX;
|
|
|
|
rcOuter.top = g_Config.iWindowY;
|
2012-11-17 16:46:05 +00:00
|
|
|
}
|
|
|
|
|
2013-03-30 16:49:02 +00:00
|
|
|
void SavePosition() {
|
|
|
|
WINDOWPLACEMENT placement;
|
|
|
|
GetWindowPlacement(hwndMain, &placement);
|
|
|
|
if (placement.showCmd == SW_SHOWNORMAL) {
|
|
|
|
RECT rc;
|
|
|
|
GetWindowRect(hwndMain, &rc);
|
|
|
|
g_Config.iWindowX = rc.left;
|
|
|
|
g_Config.iWindowY = rc.top;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-02-11 18:02:38 +00:00
|
|
|
void ResizeDisplay(bool noWindowMovement = false) {
|
2013-01-26 22:46:02 +00:00
|
|
|
RECT rc;
|
|
|
|
GetClientRect(hwndMain, &rc);
|
2013-02-11 18:02:38 +00:00
|
|
|
if (!noWindowMovement) {
|
|
|
|
|
|
|
|
if ((rc.right - rc.left) == PSP_CoreParameter().pixelWidth &&
|
|
|
|
(rc.bottom - rc.top) == PSP_CoreParameter().pixelHeight)
|
|
|
|
return;
|
|
|
|
PSP_CoreParameter().pixelWidth = rc.right - rc.left;
|
|
|
|
PSP_CoreParameter().pixelHeight = rc.bottom - rc.top;
|
|
|
|
MoveWindow(hwndDisplay, 0, 0, PSP_CoreParameter().pixelWidth, PSP_CoreParameter().pixelHeight, TRUE);
|
|
|
|
}
|
2013-01-26 23:15:39 +00:00
|
|
|
|
|
|
|
// round up to a zoom factor for the render size.
|
|
|
|
int zoom = (rc.right - rc.left + 479) / 480;
|
|
|
|
if (g_Config.SSAntiAliasing) zoom *= 2;
|
|
|
|
PSP_CoreParameter().renderWidth = 480 * zoom;
|
|
|
|
PSP_CoreParameter().renderHeight = 272 * zoom;
|
|
|
|
PSP_CoreParameter().outputWidth = 480 * zoom;
|
|
|
|
PSP_CoreParameter().outputHeight = 272 * zoom;
|
|
|
|
|
|
|
|
if (gpu)
|
|
|
|
gpu->Resized();
|
2013-01-26 22:46:02 +00:00
|
|
|
}
|
|
|
|
|
2012-12-21 15:49:02 +00:00
|
|
|
void SetZoom(float zoom) {
|
|
|
|
if (zoom < 5)
|
2012-12-21 23:41:09 +00:00
|
|
|
g_Config.iWindowZoom = (int) zoom;
|
2012-11-17 16:46:05 +00:00
|
|
|
RECT rc, rcOuter;
|
2012-12-21 23:41:09 +00:00
|
|
|
GetWindowRectAtZoom((int) zoom, rc, rcOuter);
|
2012-11-17 16:46:05 +00:00
|
|
|
MoveWindow(hwndMain, rcOuter.left, rcOuter.top, rcOuter.right - rcOuter.left, rcOuter.bottom - rcOuter.top, TRUE);
|
2013-01-26 22:46:02 +00:00
|
|
|
ResizeDisplay();
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
2013-05-26 21:55:23 +00:00
|
|
|
void CorrectCursor() {
|
2013-06-11 18:14:53 +00:00
|
|
|
bool autoHide = g_bFullScreen && !mouseButtonDown && globalUIState == UISTATE_INGAME;
|
|
|
|
if (autoHide && hideCursor) {
|
2013-05-26 21:55:23 +00:00
|
|
|
while (cursorCounter >= 0) {
|
|
|
|
cursorCounter = ShowCursor(FALSE);
|
|
|
|
}
|
|
|
|
} else {
|
2013-06-11 18:14:53 +00:00
|
|
|
hideCursor = !autoHide;
|
2013-05-26 21:55:23 +00:00
|
|
|
if (cursorCounter < 0) {
|
|
|
|
cursorCounter = ShowCursor(TRUE);
|
|
|
|
SetCursor(LoadCursor(NULL, IDC_ARROW));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-05-01 21:55:34 +00:00
|
|
|
void setTexScalingLevel(int num) {
|
|
|
|
g_Config.iTexScalingLevel = num;
|
|
|
|
if(gpu) gpu->ClearCacheNextFrame();
|
|
|
|
}
|
2013-06-30 06:48:50 +00:00
|
|
|
|
|
|
|
void setTexFiltering(int num) {
|
|
|
|
g_Config.iTexFiltering = num;
|
|
|
|
}
|
|
|
|
|
2013-05-01 21:55:34 +00:00
|
|
|
void setTexScalingType(int num) {
|
|
|
|
g_Config.iTexScalingType = num;
|
2013-04-30 15:20:28 +00:00
|
|
|
if(gpu) gpu->ClearCacheNextFrame();
|
2013-04-30 01:47:33 +00:00
|
|
|
}
|
2013-06-30 06:48:50 +00:00
|
|
|
|
2013-07-21 15:17:42 +00:00
|
|
|
void setRenderingMode(int num) {
|
|
|
|
g_Config.iRenderingMode = num;
|
2013-07-21 23:33:18 +00:00
|
|
|
if (gpu) gpu->Resized();
|
2013-07-21 15:17:42 +00:00
|
|
|
}
|
|
|
|
|
2013-05-10 00:36:23 +00:00
|
|
|
void setFpsLimit(int fps) {
|
|
|
|
g_Config.iFpsLimit = fps;
|
|
|
|
}
|
2013-06-30 06:48:50 +00:00
|
|
|
|
2013-06-01 05:15:38 +00:00
|
|
|
void enableCheats(bool cheats){
|
2013-05-23 11:10:39 +00:00
|
|
|
g_Config.bEnableCheats = cheats;
|
2013-05-18 22:04:01 +00:00
|
|
|
}
|
2013-04-30 01:47:33 +00:00
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
BOOL Show(HINSTANCE hInstance, int nCmdShow)
|
|
|
|
{
|
|
|
|
hInst = hInstance; // Store instance handle in our global variable
|
|
|
|
|
2012-11-17 16:46:05 +00:00
|
|
|
int zoom = g_Config.iWindowZoom;
|
|
|
|
if (zoom < 1) zoom = 1;
|
|
|
|
if (zoom > 4) zoom = 4;
|
|
|
|
|
2013-06-08 00:32:07 +00:00
|
|
|
RECT rc, rcOrig;
|
2012-11-17 16:46:05 +00:00
|
|
|
GetWindowRectAtZoom(zoom, rcOrig, rc);
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2013-03-29 20:21:27 +00:00
|
|
|
u32 style = WS_OVERLAPPEDWINDOW;
|
2012-11-01 15:19:01 +00:00
|
|
|
|
|
|
|
hwndMain = CreateWindowEx(0,szWindowClass, "", style,
|
2013-06-08 00:32:07 +00:00
|
|
|
rc.left, rc.top, rc.right - rc.left, rc.bottom - rc.top, NULL, NULL, hInstance, NULL);
|
2012-11-01 15:19:01 +00:00
|
|
|
if (!hwndMain)
|
|
|
|
return FALSE;
|
|
|
|
|
2013-06-08 00:32:07 +00:00
|
|
|
hwndDisplay = CreateWindowEx(0, szDisplayClass, TEXT(""), WS_CHILD | WS_VISIBLE,
|
|
|
|
rcOrig.left, rcOrig.top, rcOrig.right - rcOrig.left, rcOrig.bottom - rcOrig.top, hwndMain, 0, hInstance, 0);
|
|
|
|
if (!hwndDisplay)
|
|
|
|
return FALSE;
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
menu = GetMenu(hwndMain);
|
|
|
|
#ifdef FINAL
|
|
|
|
RemoveMenu(menu,2,MF_BYPOSITION);
|
|
|
|
RemoveMenu(menu,2,MF_BYPOSITION);
|
|
|
|
#endif
|
|
|
|
MENUINFO info;
|
|
|
|
ZeroMemory(&info,sizeof(MENUINFO));
|
|
|
|
info.cbSize = sizeof(MENUINFO);
|
|
|
|
info.cyMax = 0;
|
|
|
|
info.dwStyle = MNS_CHECKORBMP;
|
|
|
|
info.fMask = MIM_STYLE;
|
2012-11-23 11:42:35 +00:00
|
|
|
for (int i = 0; i < GetMenuItemCount(menu); i++)
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
|
|
|
SetMenuInfo(GetSubMenu(menu,i),&info);
|
|
|
|
}
|
2013-06-08 00:32:07 +00:00
|
|
|
UpdateMenus();
|
2012-11-01 15:19:01 +00:00
|
|
|
|
|
|
|
//accept dragged files
|
|
|
|
DragAcceptFiles(hwndMain, TRUE);
|
|
|
|
|
2013-06-11 18:14:53 +00:00
|
|
|
hideCursor = true;
|
2013-06-08 00:32:07 +00:00
|
|
|
SetTimer(hwndMain, TIMER_CURSORUPDATE, CURSORUPDATE_INTERVAL_MS, 0);
|
|
|
|
|
|
|
|
Update();
|
|
|
|
SetPlaying(0);
|
2013-07-10 18:22:22 +00:00
|
|
|
|
|
|
|
if(g_Config.bFullScreenOnLaunch)
|
|
|
|
_ViewFullScreen(hwndMain);
|
2013-06-08 00:32:07 +00:00
|
|
|
|
|
|
|
ShowWindow(hwndMain, nCmdShow);
|
|
|
|
|
2013-07-06 17:47:37 +00:00
|
|
|
W32Util::MakeTopMost(hwndMain, g_Config.bTopMost);
|
|
|
|
|
2013-04-16 19:12:55 +00:00
|
|
|
#if ENABLE_TOUCH
|
|
|
|
RegisterTouchWindow(hwndDisplay, TWF_WANTPALM);
|
|
|
|
#endif
|
|
|
|
|
2013-07-07 08:42:39 +00:00
|
|
|
RAWINPUTDEVICE keyboard;
|
|
|
|
memset(&keyboard, 0, sizeof(keyboard));
|
|
|
|
keyboard.usUsagePage = 1;
|
|
|
|
keyboard.usUsage = 6;
|
|
|
|
keyboard.dwFlags = 0; // RIDEV_NOLEGACY | ;
|
|
|
|
RegisterRawInputDevices(&keyboard, 1, sizeof(RAWINPUTDEVICE));
|
|
|
|
|
2013-05-04 21:21:06 +00:00
|
|
|
SetFocus(hwndDisplay);
|
2012-11-01 15:19:01 +00:00
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2013-03-28 19:26:24 +00:00
|
|
|
void BrowseAndBoot(std::string defaultPath)
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-03-28 21:31:51 +00:00
|
|
|
std::string fn;
|
2013-05-25 05:45:28 +00:00
|
|
|
std::string filter = "PSP ROMs (*.iso *.cso *.pbp *.elf)|*.pbp;*.elf;*.iso;*.cso;*.prx|All files (*.*)|*.*||";
|
2013-05-24 16:46:20 +00:00
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
for (int i=0; i<(int)filter.length(); i++)
|
|
|
|
{
|
|
|
|
if (filter[i] == '|')
|
|
|
|
filter[i] = '\0';
|
|
|
|
}
|
|
|
|
|
2013-07-17 05:33:26 +00:00
|
|
|
// pause if a game is being played
|
|
|
|
bool isPaused = false;
|
|
|
|
if (globalUIState == UISTATE_INGAME)
|
|
|
|
{
|
|
|
|
isPaused = Core_IsStepping();
|
|
|
|
if (!isPaused)
|
|
|
|
Core_EnableStepping(true);
|
|
|
|
}
|
|
|
|
|
2013-03-29 18:32:20 +00:00
|
|
|
if (W32Util::BrowseForFileName(true, GetHWND(), "Load File", defaultPath.size() ? defaultPath.c_str() : 0, filter.c_str(),"*.pbp;*.elf;*.iso;*.cso;",fn))
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-07-17 05:33:26 +00:00
|
|
|
if (globalUIState == UISTATE_INGAME || globalUIState == UISTATE_PAUSEMENU)
|
|
|
|
{
|
|
|
|
Core_EnableStepping(false);
|
|
|
|
}
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
// decode the filename with fullpath
|
|
|
|
std::string fullpath = fn;
|
|
|
|
char drive[MAX_PATH];
|
|
|
|
char dir[MAX_PATH];
|
|
|
|
char fname[MAX_PATH];
|
|
|
|
char ext[MAX_PATH];
|
|
|
|
_splitpath(fullpath.c_str(), drive, dir, fname, ext);
|
|
|
|
|
|
|
|
std::string executable = std::string(drive) + std::string(dir) + std::string(fname) + std::string(ext);
|
2013-03-29 18:32:20 +00:00
|
|
|
NativeMessageReceived("boot", executable.c_str());
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
2013-07-17 05:33:26 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
if (!isPaused)
|
|
|
|
Core_EnableStepping(false);
|
|
|
|
}
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
LRESULT CALLBACK DisplayProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
|
|
|
|
{
|
|
|
|
switch (message)
|
|
|
|
{
|
|
|
|
case WM_ACTIVATE:
|
|
|
|
break;
|
|
|
|
case WM_SETFOCUS:
|
|
|
|
break;
|
|
|
|
case WM_SIZE:
|
|
|
|
break;
|
2013-03-29 18:32:20 +00:00
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
case WM_ERASEBKGND:
|
|
|
|
return DefWindowProc(hWnd, message, wParam, lParam);
|
2013-03-29 18:32:20 +00:00
|
|
|
|
2013-06-01 21:34:50 +00:00
|
|
|
// Poor man's touch - mouse input. We send the data both as an input_state pointer,
|
|
|
|
// and as asynchronous touch events for minimal latency.
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
case WM_LBUTTONDOWN:
|
2013-03-29 17:50:08 +00:00
|
|
|
{
|
2013-07-09 20:51:02 +00:00
|
|
|
// Hack: Take the opportunity to show the cursor.
|
|
|
|
mouseButtonDown = true;
|
|
|
|
{
|
|
|
|
lock_guard guard(input_state.lock);
|
|
|
|
input_state.mouse_valid = true;
|
|
|
|
input_state.pointer_down[0] = true;
|
2013-04-01 02:15:59 +00:00
|
|
|
|
2013-07-09 20:51:02 +00:00
|
|
|
int factor = g_Config.iWindowZoom == 1 ? 2 : 1;
|
|
|
|
input_state.pointer_x[0] = GET_X_LPARAM(lParam) * factor;
|
|
|
|
input_state.pointer_y[0] = GET_Y_LPARAM(lParam) * factor;
|
|
|
|
}
|
2013-06-01 21:34:50 +00:00
|
|
|
|
|
|
|
TouchInput touch;
|
|
|
|
touch.id = 0;
|
|
|
|
touch.flags = TOUCH_DOWN;
|
2013-07-09 12:46:15 +00:00
|
|
|
touch.x = input_state.pointer_x[0];
|
|
|
|
touch.y = input_state.pointer_y[0];
|
2013-06-01 21:34:50 +00:00
|
|
|
NativeTouch(touch);
|
2013-07-09 20:51:02 +00:00
|
|
|
SetCapture(hWnd);
|
|
|
|
break;
|
2013-03-29 17:50:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
case WM_MOUSEMOVE:
|
|
|
|
{
|
2013-06-11 18:14:53 +00:00
|
|
|
// Hack: Take the opportunity to show the cursor.
|
|
|
|
mouseButtonDown = (wParam & MK_LBUTTON) != 0;
|
|
|
|
int cursorX = GET_X_LPARAM(lParam);
|
|
|
|
int cursorY = GET_Y_LPARAM(lParam);
|
|
|
|
if (abs(cursorX - prevCursorX) > 1 || abs(cursorY - prevCursorY) > 1) {
|
|
|
|
hideCursor = false;
|
|
|
|
SetTimer(hwndMain, TIMER_CURSORMOVEUPDATE, CURSORUPDATE_MOVE_TIMESPAN_MS, 0);
|
|
|
|
}
|
|
|
|
prevCursorX = cursorX;
|
|
|
|
prevCursorY = cursorY;
|
|
|
|
|
2013-07-09 20:51:02 +00:00
|
|
|
{
|
|
|
|
lock_guard guard(input_state.lock);
|
|
|
|
int factor = g_Config.iWindowZoom == 1 ? 2 : 1;
|
|
|
|
input_state.pointer_x[0] = GET_X_LPARAM(lParam) * factor;
|
|
|
|
input_state.pointer_y[0] = GET_Y_LPARAM(lParam) * factor;
|
|
|
|
}
|
2013-06-01 21:34:50 +00:00
|
|
|
|
|
|
|
if (wParam & MK_LBUTTON) {
|
|
|
|
TouchInput touch;
|
|
|
|
touch.id = 0;
|
|
|
|
touch.flags = TOUCH_MOVE;
|
2013-07-09 12:46:15 +00:00
|
|
|
touch.x = input_state.pointer_x[0];
|
|
|
|
touch.y = input_state.pointer_y[0];
|
2013-06-01 21:34:50 +00:00
|
|
|
NativeTouch(touch);
|
2013-04-01 02:15:59 +00:00
|
|
|
}
|
2013-03-29 17:50:08 +00:00
|
|
|
}
|
2012-11-01 15:19:01 +00:00
|
|
|
break;
|
|
|
|
|
2013-03-29 17:50:08 +00:00
|
|
|
case WM_LBUTTONUP:
|
|
|
|
{
|
2013-07-09 20:51:02 +00:00
|
|
|
// Hack: Take the opportunity to hide the cursor.
|
|
|
|
mouseButtonDown = false;
|
|
|
|
{
|
|
|
|
lock_guard guard(input_state.lock);
|
|
|
|
input_state.pointer_down[0] = false;
|
|
|
|
int factor = g_Config.iWindowZoom == 1 ? 2 : 1;
|
|
|
|
input_state.pointer_x[0] = GET_X_LPARAM(lParam) * factor;
|
|
|
|
input_state.pointer_y[0] = GET_Y_LPARAM(lParam) * factor;
|
|
|
|
}
|
2013-06-01 21:34:50 +00:00
|
|
|
TouchInput touch;
|
|
|
|
touch.id = 0;
|
|
|
|
touch.flags = TOUCH_UP;
|
2013-07-09 12:46:15 +00:00
|
|
|
touch.x = input_state.pointer_x[0];
|
|
|
|
touch.y = input_state.pointer_y[0];
|
2013-06-01 21:34:50 +00:00
|
|
|
NativeTouch(touch);
|
2013-07-09 20:51:02 +00:00
|
|
|
ReleaseCapture();
|
|
|
|
break;
|
2013-03-29 17:50:08 +00:00
|
|
|
}
|
|
|
|
|
2013-06-01 21:34:50 +00:00
|
|
|
// Actual touch! Unfinished
|
|
|
|
|
2013-04-16 19:12:55 +00:00
|
|
|
case WM_TOUCH:
|
|
|
|
{
|
|
|
|
// TODO: Enabling this section will probably break things on Windows XP.
|
|
|
|
// We probably need to manually fetch pointers to GetTouchInputInfo and CloseTouchInputHandle.
|
|
|
|
#if ENABLE_TOUCH
|
|
|
|
UINT inputCount = LOWORD(wParam);
|
|
|
|
TOUCHINPUT *inputs = new TOUCHINPUT[inputCount];
|
|
|
|
if (GetTouchInputInfo((HTOUCHINPUT)lParam,
|
|
|
|
inputCount,
|
|
|
|
inputs,
|
|
|
|
sizeof(TOUCHINPUT)))
|
|
|
|
{
|
|
|
|
for (int i = 0; i < inputCount; i++) {
|
|
|
|
// TODO: process inputs here!
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!CloseTouchInputHandle((HTOUCHINPUT)lParam))
|
|
|
|
{
|
|
|
|
// error handling
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// GetLastError() and error handling
|
|
|
|
}
|
|
|
|
delete [] inputs;
|
|
|
|
return DefWindowProc(hWnd, message, wParam, lParam);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
case WM_PAINT:
|
|
|
|
return DefWindowProc(hWnd, message, wParam, lParam);
|
|
|
|
default:
|
|
|
|
return DefWindowProc(hWnd, message, wParam, lParam);
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2013-07-07 08:42:39 +00:00
|
|
|
static int GetTrueVKey(const RAWKEYBOARD &kb) {
|
|
|
|
switch (kb.VKey) {
|
|
|
|
case VK_SHIFT:
|
2013-07-07 16:27:53 +00:00
|
|
|
return MapVirtualKey(kb.MakeCode, MAPVK_VSC_TO_VK_EX);
|
2013-07-07 08:42:39 +00:00
|
|
|
case VK_CONTROL:
|
2013-07-07 16:27:53 +00:00
|
|
|
if (kb.Flags & RI_KEY_E0)
|
2013-07-07 08:42:39 +00:00
|
|
|
return VK_RCONTROL;
|
|
|
|
else
|
|
|
|
return VK_LCONTROL;
|
|
|
|
|
|
|
|
case VK_MENU:
|
2013-07-07 16:27:53 +00:00
|
|
|
if (kb.Flags & RI_KEY_E0)
|
2013-07-07 08:42:39 +00:00
|
|
|
return VK_RMENU; // Right Alt / AltGr
|
|
|
|
else
|
|
|
|
return VK_LMENU; // Left Alt
|
|
|
|
default:
|
|
|
|
return kb.VKey;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
|
|
|
|
{
|
|
|
|
int wmId, wmEvent;
|
|
|
|
std::string fn;
|
|
|
|
|
|
|
|
switch (message)
|
|
|
|
{
|
|
|
|
case WM_CREATE:
|
|
|
|
break;
|
|
|
|
|
|
|
|
case WM_MOVE:
|
2013-03-30 16:49:02 +00:00
|
|
|
SavePosition();
|
2013-01-26 23:15:39 +00:00
|
|
|
ResizeDisplay();
|
|
|
|
break;
|
|
|
|
|
|
|
|
case WM_SIZE:
|
2013-03-30 16:49:02 +00:00
|
|
|
SavePosition();
|
2013-01-26 23:15:39 +00:00
|
|
|
ResizeDisplay();
|
2012-11-01 15:19:01 +00:00
|
|
|
break;
|
|
|
|
|
2013-05-04 21:21:06 +00:00
|
|
|
case WM_TIMER:
|
|
|
|
// Hack: Take the opportunity to also show/hide the mouse cursor in fullscreen mode.
|
2013-06-11 18:14:53 +00:00
|
|
|
switch (wParam)
|
|
|
|
{
|
|
|
|
case TIMER_CURSORUPDATE:
|
|
|
|
CorrectCursor();
|
|
|
|
return 0;
|
|
|
|
case TIMER_CURSORMOVEUPDATE:
|
|
|
|
hideCursor = true;
|
|
|
|
KillTimer(hWnd, TIMER_CURSORMOVEUPDATE);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
break;
|
2013-05-04 21:21:06 +00:00
|
|
|
|
2013-07-08 10:35:08 +00:00
|
|
|
// For some reason, need to catch this here rather than in DisplayProc.
|
|
|
|
case WM_MOUSEWHEEL:
|
|
|
|
{
|
|
|
|
int wheelDelta = (short)(wParam >> 16);
|
|
|
|
KeyInput key;
|
|
|
|
key.deviceId = DEVICE_ID_MOUSE;
|
|
|
|
|
|
|
|
if (wheelDelta < 0) {
|
|
|
|
key.keyCode = KEYCODE_EXT_MOUSEWHEEL_DOWN;
|
|
|
|
wheelDelta = -wheelDelta;
|
|
|
|
} else {
|
|
|
|
key.keyCode = KEYCODE_EXT_MOUSEWHEEL_UP;
|
|
|
|
}
|
|
|
|
// There's no separate keyup event for mousewheel events, let's pass them both together.
|
|
|
|
// This also means it really won't work great for key mapping :( Need to build a 1 frame delay or something.
|
|
|
|
key.flags = KEY_DOWN | KEY_UP | KEY_HASWHEELDELTA | (wheelDelta << 16);
|
|
|
|
NativeKey(key);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
case WM_COMMAND:
|
2013-06-03 12:30:12 +00:00
|
|
|
{
|
2013-06-08 00:32:07 +00:00
|
|
|
if (!EmuThread_Ready())
|
|
|
|
return DefWindowProc(hWnd, message, wParam, lParam);
|
2013-06-03 12:30:12 +00:00
|
|
|
I18NCategory *g = GetI18NCategory("Graphics");
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
wmId = LOWORD(wParam);
|
|
|
|
wmEvent = HIWORD(wParam);
|
|
|
|
// Parse the menu selections:
|
|
|
|
switch (wmId)
|
|
|
|
{
|
|
|
|
case ID_FILE_LOAD:
|
2013-03-28 19:26:24 +00:00
|
|
|
BrowseAndBoot("");
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ID_FILE_LOAD_MEMSTICK:
|
|
|
|
{
|
|
|
|
std::string memStickDir, flash0dir;
|
|
|
|
GetSysDirectories(memStickDir, flash0dir);
|
2013-03-28 21:31:51 +00:00
|
|
|
memStickDir += "PSP\\GAME\\";
|
2013-03-28 19:26:24 +00:00
|
|
|
BrowseAndBoot(memStickDir);
|
|
|
|
}
|
2012-11-01 15:19:01 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case ID_FILE_REFRESHGAMELIST:
|
|
|
|
break;
|
|
|
|
|
2013-03-28 19:17:45 +00:00
|
|
|
case ID_FILE_MEMSTICK:
|
|
|
|
{
|
|
|
|
std::string memStickDir, flash0dir;
|
|
|
|
GetSysDirectories(memStickDir, flash0dir);
|
|
|
|
ShellExecuteA(NULL, "open", memStickDir.c_str(), 0, 0, SW_SHOW);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
2013-07-09 20:25:29 +00:00
|
|
|
case ID_TOGGLE_PAUSE:
|
2013-07-10 14:49:48 +00:00
|
|
|
if (globalUIState == UISTATE_PAUSEMENU)
|
|
|
|
{
|
2013-03-29 19:03:11 +00:00
|
|
|
NativeMessageReceived("run", "");
|
2013-07-15 15:41:24 +00:00
|
|
|
if (disasmWindow[0])
|
2013-07-10 14:49:48 +00:00
|
|
|
SendMessage(disasmWindow[0]->GetDlgHandle(), WM_COMMAND, IDC_GO, 0);
|
|
|
|
}
|
|
|
|
else if (Core_IsStepping()) //It is paused, then continue to run
|
2013-07-09 20:25:29 +00:00
|
|
|
{
|
|
|
|
if (disasmWindow[0])
|
|
|
|
SendMessage(disasmWindow[0]->GetDlgHandle(), WM_COMMAND, IDC_GO, 0);
|
|
|
|
else
|
|
|
|
Core_EnableStepping(false);
|
2013-03-29 19:03:11 +00:00
|
|
|
} else {
|
2013-07-09 20:25:29 +00:00
|
|
|
if (disasmWindow[0])
|
|
|
|
SendMessage(disasmWindow[0]->GetDlgHandle(), WM_COMMAND, IDC_STOP, 0);
|
|
|
|
else
|
|
|
|
Core_EnableStepping(true);
|
2013-03-29 19:03:11 +00:00
|
|
|
}
|
2012-11-01 15:19:01 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case ID_EMULATION_STOP:
|
2013-04-21 02:54:25 +00:00
|
|
|
if (memoryWindow[0]) {
|
2013-03-29 20:21:27 +00:00
|
|
|
SendMessage(memoryWindow[0]->GetDlgHandle(), WM_CLOSE, 0, 0);
|
2013-04-21 02:54:25 +00:00
|
|
|
}
|
|
|
|
if (disasmWindow[0]) {
|
|
|
|
SendMessage(disasmWindow[0]->GetDlgHandle(), WM_CLOSE, 0, 0);
|
|
|
|
}
|
|
|
|
if (Core_IsStepping()) {
|
|
|
|
Core_EnableStepping(false);
|
|
|
|
}
|
2013-03-29 17:50:08 +00:00
|
|
|
NativeMessageReceived("stop", "");
|
2012-11-01 15:19:01 +00:00
|
|
|
SetPlaying(0);
|
|
|
|
Update();
|
|
|
|
break;
|
|
|
|
|
2013-02-03 00:17:35 +00:00
|
|
|
case ID_EMULATION_RESET:
|
2013-03-29 19:51:14 +00:00
|
|
|
NativeMessageReceived("reset", "");
|
2013-02-03 00:17:35 +00:00
|
|
|
break;
|
2012-11-01 15:19:01 +00:00
|
|
|
|
|
|
|
case ID_EMULATION_SPEEDLIMIT:
|
|
|
|
g_Config.bSpeedLimit = !g_Config.bSpeedLimit;
|
|
|
|
break;
|
|
|
|
|
2013-01-02 20:00:10 +00:00
|
|
|
case ID_FILE_LOADSTATEFILE:
|
2012-12-28 22:43:09 +00:00
|
|
|
if (W32Util::BrowseForFileName(true, hWnd, "Load state",0,"Save States (*.ppst)\0*.ppst\0All files\0*.*\0\0","ppst",fn))
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-07-09 20:25:29 +00:00
|
|
|
SetCursor(LoadCursor(0, IDC_WAIT));
|
2012-12-28 21:50:59 +00:00
|
|
|
SaveState::Load(fn, SaveStateActionFinished);
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
2013-01-02 20:00:10 +00:00
|
|
|
case ID_FILE_SAVESTATEFILE:
|
2012-12-28 22:43:09 +00:00
|
|
|
if (W32Util::BrowseForFileName(false, hWnd, "Save state",0,"Save States (*.ppst)\0*.ppst\0All files\0*.*\0\0","ppst",fn))
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
2013-07-09 20:25:29 +00:00
|
|
|
SetCursor(LoadCursor(0, IDC_WAIT));
|
2012-12-28 21:50:59 +00:00
|
|
|
SaveState::Save(fn, SaveStateActionFinished);
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
2013-07-09 20:25:29 +00:00
|
|
|
// TODO: Improve UI for multiple slots
|
|
|
|
case ID_FILE_SAVESTATE_NEXT_SLOT:
|
|
|
|
{
|
2013-07-17 05:33:26 +00:00
|
|
|
currentSavestateSlot = (currentSavestateSlot + 1)%SaveState::SAVESTATESLOTS;
|
2013-07-09 20:25:29 +00:00
|
|
|
char msg[30];
|
|
|
|
sprintf(msg, "Using save state slot %d.", currentSavestateSlot + 1);
|
|
|
|
osm.Show(msg);
|
|
|
|
break;
|
|
|
|
}
|
2013-01-02 20:00:10 +00:00
|
|
|
|
|
|
|
case ID_FILE_QUICKLOADSTATE:
|
2013-07-09 20:25:29 +00:00
|
|
|
SetCursor(LoadCursor(0, IDC_WAIT));
|
|
|
|
SaveState::LoadSlot(currentSavestateSlot, SaveStateActionFinished);
|
2013-01-02 20:00:10 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case ID_FILE_QUICKSAVESTATE:
|
2013-07-09 20:25:29 +00:00
|
|
|
SetCursor(LoadCursor(0, IDC_WAIT));
|
|
|
|
SaveState::SaveSlot(currentSavestateSlot, SaveStateActionFinished);
|
2013-01-02 20:00:10 +00:00
|
|
|
break;
|
|
|
|
|
2012-11-17 16:46:05 +00:00
|
|
|
case ID_OPTIONS_SCREEN1X:
|
|
|
|
SetZoom(1);
|
|
|
|
break;
|
|
|
|
case ID_OPTIONS_SCREEN2X:
|
|
|
|
SetZoom(2);
|
|
|
|
break;
|
|
|
|
case ID_OPTIONS_SCREEN3X:
|
|
|
|
SetZoom(3);
|
|
|
|
break;
|
|
|
|
case ID_OPTIONS_SCREEN4X:
|
|
|
|
SetZoom(4);
|
|
|
|
break;
|
|
|
|
|
2013-04-17 19:07:41 +00:00
|
|
|
case ID_OPTIONS_MIPMAP:
|
|
|
|
g_Config.bMipMap = !g_Config.bMipMap;
|
|
|
|
break;
|
|
|
|
|
2013-06-16 21:45:06 +00:00
|
|
|
case ID_OPTIONS_VSYNC:
|
2013-07-20 14:03:52 +00:00
|
|
|
g_Config.bVSync = !g_Config.bVSync;
|
2013-06-16 21:45:06 +00:00
|
|
|
break;
|
|
|
|
|
2013-04-30 10:14:34 +00:00
|
|
|
case ID_TEXTURESCALING_OFF:
|
2013-05-01 21:55:34 +00:00
|
|
|
setTexScalingLevel(1);
|
2013-04-30 10:14:34 +00:00
|
|
|
break;
|
2013-05-01 21:55:34 +00:00
|
|
|
case ID_TEXTURESCALING_2X:
|
|
|
|
setTexScalingLevel(2);
|
2013-04-30 01:47:33 +00:00
|
|
|
break;
|
2013-05-01 21:55:34 +00:00
|
|
|
case ID_TEXTURESCALING_3X:
|
|
|
|
setTexScalingLevel(3);
|
2013-04-30 10:14:34 +00:00
|
|
|
break;
|
2013-05-01 21:55:34 +00:00
|
|
|
case ID_TEXTURESCALING_4X:
|
|
|
|
setTexScalingLevel(4);
|
2013-04-30 01:47:33 +00:00
|
|
|
break;
|
2013-05-01 21:55:34 +00:00
|
|
|
case ID_TEXTURESCALING_5X:
|
|
|
|
setTexScalingLevel(5);
|
2013-04-30 01:47:33 +00:00
|
|
|
break;
|
2013-05-01 21:55:34 +00:00
|
|
|
|
|
|
|
case ID_TEXTURESCALING_XBRZ:
|
|
|
|
setTexScalingType(TextureScaler::XBRZ);
|
2013-04-30 01:47:33 +00:00
|
|
|
break;
|
2013-05-01 21:55:34 +00:00
|
|
|
case ID_TEXTURESCALING_HYBRID:
|
|
|
|
setTexScalingType(TextureScaler::HYBRID);
|
2013-04-30 01:47:33 +00:00
|
|
|
break;
|
2013-05-04 23:27:15 +00:00
|
|
|
case ID_TEXTURESCALING_BICUBIC:
|
|
|
|
setTexScalingType(TextureScaler::BICUBIC);
|
|
|
|
break;
|
|
|
|
case ID_TEXTURESCALING_HYBRID_BICUBIC:
|
|
|
|
setTexScalingType(TextureScaler::HYBRID_BICUBIC);
|
|
|
|
break;
|
2013-04-30 01:47:33 +00:00
|
|
|
|
2013-05-03 14:21:46 +00:00
|
|
|
case ID_TEXTURESCALING_DEPOSTERIZE:
|
|
|
|
g_Config.bTexDeposterize = !g_Config.bTexDeposterize;
|
|
|
|
if(gpu) gpu->ClearCacheNextFrame();
|
|
|
|
break;
|
|
|
|
|
2013-07-21 15:17:42 +00:00
|
|
|
case ID_OPTIONS_NONBUFFEREDRENDERING:
|
|
|
|
setRenderingMode(0);
|
|
|
|
break;
|
|
|
|
|
2012-11-20 10:35:48 +00:00
|
|
|
case ID_OPTIONS_BUFFEREDRENDERING:
|
2013-07-21 15:17:42 +00:00
|
|
|
setRenderingMode(1);
|
2012-11-20 10:35:48 +00:00
|
|
|
break;
|
|
|
|
|
2013-07-21 23:33:18 +00:00
|
|
|
case ID_OPTIONS_READFBOTOMEMORYCPU:
|
2013-07-21 15:17:42 +00:00
|
|
|
setRenderingMode(2);
|
2013-07-09 20:25:29 +00:00
|
|
|
break;
|
|
|
|
|
2013-07-21 23:33:18 +00:00
|
|
|
case ID_OPTIONS_READFBOTOMEMORYGPU:
|
2013-07-21 15:17:42 +00:00
|
|
|
setRenderingMode(3);
|
2013-07-19 23:23:17 +00:00
|
|
|
break;
|
|
|
|
|
2012-11-26 16:35:08 +00:00
|
|
|
case ID_OPTIONS_SHOWDEBUGSTATISTICS:
|
|
|
|
g_Config.bShowDebugStats = !g_Config.bShowDebugStats;
|
|
|
|
break;
|
|
|
|
|
2012-12-21 10:08:54 +00:00
|
|
|
case ID_OPTIONS_HARDWARETRANSFORM:
|
|
|
|
g_Config.bHardwareTransform = !g_Config.bHardwareTransform;
|
2013-05-22 16:00:06 +00:00
|
|
|
osm.ShowOnOff(g->T("Hardware Transform"), g_Config.bHardwareTransform);
|
2012-12-21 10:08:54 +00:00
|
|
|
break;
|
|
|
|
|
2013-02-13 17:21:21 +00:00
|
|
|
case ID_OPTIONS_STRETCHDISPLAY:
|
|
|
|
g_Config.bStretchToDisplay = !g_Config.bStretchToDisplay;
|
2013-03-03 12:00:21 +00:00
|
|
|
if (gpu)
|
|
|
|
gpu->Resized(); // easy way to force a clear...
|
2013-02-13 17:21:21 +00:00
|
|
|
break;
|
|
|
|
|
2013-02-18 23:44:22 +00:00
|
|
|
case ID_OPTIONS_FRAMESKIP:
|
2013-05-02 14:48:28 +00:00
|
|
|
g_Config.iFrameSkip = g_Config.iFrameSkip == 0 ? 1 : 0;
|
2013-05-22 16:00:06 +00:00
|
|
|
osm.ShowOnOff(g->T("Frame Skipping"), g_Config.iFrameSkip != 0);
|
2013-02-18 23:44:22 +00:00
|
|
|
break;
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
case ID_FILE_EXIT:
|
|
|
|
DestroyWindow(hWnd);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ID_CPU_DYNAREC:
|
2013-02-16 08:49:33 +00:00
|
|
|
g_Config.bJit = true;
|
2013-05-22 16:00:06 +00:00
|
|
|
osm.ShowOnOff(g->T("Dynarec", "Dynarec (JIT)"), g_Config.bJit);
|
2013-03-29 20:21:27 +00:00
|
|
|
break;
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
case ID_CPU_INTERPRETER:
|
2013-02-16 08:49:33 +00:00
|
|
|
g_Config.bJit = false;
|
2012-11-01 15:19:01 +00:00
|
|
|
break;
|
|
|
|
|
2013-01-04 09:26:14 +00:00
|
|
|
case ID_EMULATION_RUNONLOAD:
|
|
|
|
g_Config.bAutoRun = !g_Config.bAutoRun;
|
|
|
|
break;
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2013-01-05 18:57:06 +00:00
|
|
|
case ID_DEBUG_DUMPNEXTFRAME:
|
2013-03-03 12:00:21 +00:00
|
|
|
if (gpu)
|
|
|
|
gpu->DumpNextFrame();
|
2012-11-01 15:19:01 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case ID_DEBUG_LOADMAPFILE:
|
2013-03-03 12:00:21 +00:00
|
|
|
if (W32Util::BrowseForFileName(true, hWnd, "Load .MAP",0,"Maps\0*.map\0All files\0*.*\0\0","map",fn)) {
|
2012-11-01 15:19:01 +00:00
|
|
|
symbolMap.LoadSymbolMap(fn.c_str());
|
|
|
|
// HLE_PatchFunctions();
|
2013-03-29 18:52:32 +00:00
|
|
|
if (disasmWindow[0])
|
|
|
|
disasmWindow[0]->NotifyMapLoaded();
|
|
|
|
if (memoryWindow[0])
|
|
|
|
memoryWindow[0]->NotifyMapLoaded();
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case ID_DEBUG_SAVEMAPFILE:
|
|
|
|
if (W32Util::BrowseForFileName(false, hWnd, "Save .MAP",0,"Maps\0*.map\0All files\0*.*\0\0","map",fn))
|
|
|
|
symbolMap.SaveSymbolMap(fn.c_str());
|
|
|
|
break;
|
2013-01-05 18:57:06 +00:00
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
case ID_DEBUG_RESETSYMBOLTABLE:
|
|
|
|
symbolMap.ResetSymbolMap();
|
|
|
|
for (int i=0; i<numCPUs; i++)
|
|
|
|
if (disasmWindow[i])
|
|
|
|
disasmWindow[i]->NotifyMapLoaded();
|
|
|
|
for (int i=0; i<numCPUs; i++)
|
|
|
|
if (memoryWindow[i])
|
|
|
|
memoryWindow[i]->NotifyMapLoaded();
|
|
|
|
break;
|
|
|
|
case ID_DEBUG_DISASSEMBLY:
|
|
|
|
if (disasmWindow[0])
|
|
|
|
disasmWindow[0]->Show(true);
|
|
|
|
break;
|
|
|
|
case ID_DEBUG_MEMORYVIEW:
|
|
|
|
if (memoryWindow[0])
|
|
|
|
memoryWindow[0]->Show(true);
|
|
|
|
break;
|
|
|
|
case ID_DEBUG_LOG:
|
2012-12-22 17:21:23 +00:00
|
|
|
LogManager::GetInstance()->GetConsoleListener()->Show(LogManager::GetInstance()->GetConsoleListener()->Hidden());
|
2012-11-01 15:19:01 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case ID_OPTIONS_IGNOREILLEGALREADS:
|
|
|
|
g_Config.bIgnoreBadMemAccess = !g_Config.bIgnoreBadMemAccess;
|
|
|
|
break;
|
2013-01-05 18:57:06 +00:00
|
|
|
|
2012-12-05 06:31:41 +00:00
|
|
|
case ID_OPTIONS_FULLSCREEN:
|
2013-01-29 17:12:05 +00:00
|
|
|
g_Config.bFullScreen = !g_Config.bFullScreen ;
|
2012-12-18 11:56:35 +00:00
|
|
|
if(g_bFullScreen) {
|
2012-12-05 06:31:41 +00:00
|
|
|
_ViewNormal(hWnd);
|
2013-01-27 13:05:09 +00:00
|
|
|
} else {
|
2012-12-05 06:31:41 +00:00
|
|
|
_ViewFullScreen(hWnd);
|
2012-12-18 11:56:35 +00:00
|
|
|
}
|
2012-12-05 06:31:41 +00:00
|
|
|
break;
|
2013-01-05 18:57:06 +00:00
|
|
|
|
2013-01-19 16:05:08 +00:00
|
|
|
case ID_OPTIONS_VERTEXCACHE:
|
|
|
|
g_Config.bVertexCache = !g_Config.bVertexCache;
|
|
|
|
break;
|
2013-02-11 18:02:38 +00:00
|
|
|
case ID_OPTIONS_SHOWFPS:
|
2013-06-19 05:08:29 +00:00
|
|
|
g_Config.iShowFPSCounter = !g_Config.iShowFPSCounter;
|
2013-02-11 18:02:38 +00:00
|
|
|
break;
|
2012-11-01 15:19:01 +00:00
|
|
|
case ID_OPTIONS_DISPLAYRAWFRAMEBUFFER:
|
|
|
|
g_Config.bDisplayFramebuffer = !g_Config.bDisplayFramebuffer;
|
|
|
|
break;
|
2012-12-21 16:49:53 +00:00
|
|
|
case ID_OPTIONS_FASTMEMORY:
|
|
|
|
g_Config.bFastMemory = !g_Config.bFastMemory;
|
|
|
|
break;
|
2013-01-10 11:51:18 +00:00
|
|
|
case ID_OPTIONS_USEVBO:
|
|
|
|
g_Config.bUseVBO = !g_Config.bUseVBO;
|
|
|
|
break;
|
2013-07-01 19:42:45 +00:00
|
|
|
case ID_OPTIONS_TEXTUREFILTERING_AUTO:
|
2013-07-20 12:50:50 +00:00
|
|
|
setTexFiltering(1);
|
2013-07-01 18:00:34 +00:00
|
|
|
break;
|
2013-06-21 04:52:10 +00:00
|
|
|
case ID_OPTIONS_NEARESTFILTERING:
|
2013-06-30 06:48:50 +00:00
|
|
|
setTexFiltering(2) ;
|
2013-06-21 04:52:10 +00:00
|
|
|
break;
|
2013-01-02 21:57:57 +00:00
|
|
|
case ID_OPTIONS_LINEARFILTERING:
|
2013-06-30 06:48:50 +00:00
|
|
|
setTexFiltering(3) ;
|
2012-12-29 01:02:47 +00:00
|
|
|
break;
|
2013-06-29 19:35:28 +00:00
|
|
|
case ID_OPTIONS_LINEARFILTERING_CG:
|
2013-06-30 06:48:50 +00:00
|
|
|
setTexFiltering(4) ;
|
2013-06-29 19:35:28 +00:00
|
|
|
break;
|
2013-06-10 21:45:12 +00:00
|
|
|
case ID_OPTIONS_TOPMOST:
|
|
|
|
g_Config.bTopMost = !g_Config.bTopMost;
|
|
|
|
W32Util::MakeTopMost(hWnd, g_Config.bTopMost);
|
|
|
|
break;
|
|
|
|
|
2013-01-10 02:28:49 +00:00
|
|
|
case ID_OPTIONS_SIMPLE2XSSAA:
|
2013-01-26 23:15:39 +00:00
|
|
|
g_Config.SSAntiAliasing = !g_Config.SSAntiAliasing;
|
2013-02-11 18:02:38 +00:00
|
|
|
ResizeDisplay(true);
|
2013-01-10 02:28:49 +00:00
|
|
|
break;
|
2013-01-02 21:57:57 +00:00
|
|
|
case ID_OPTIONS_CONTROLS:
|
2013-07-06 17:08:59 +00:00
|
|
|
MessageBox(hWnd, "Control mapping has been moved to the in-window Settings menu.\n", "Sorry", 0);
|
2013-01-02 21:57:57 +00:00
|
|
|
break;
|
2013-07-06 17:08:59 +00:00
|
|
|
|
2013-04-16 19:38:17 +00:00
|
|
|
case ID_EMULATION_SOUND:
|
|
|
|
g_Config.bEnableSound = !g_Config.bEnableSound;
|
|
|
|
break;
|
2013-06-15 09:40:31 +00:00
|
|
|
|
|
|
|
case ID_HELP_OPENWEBSITE:
|
2012-11-01 15:19:01 +00:00
|
|
|
ShellExecute(NULL, "open", "http://www.ppsspp.org/", NULL, NULL, SW_SHOWNORMAL);
|
2013-06-15 09:40:31 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case ID_HELP_OPENFORUM:
|
|
|
|
ShellExecute(NULL, "open", "http://forums.ppsspp.org/", NULL, NULL, SW_SHOWNORMAL);
|
|
|
|
break;
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2013-07-07 02:12:06 +00:00
|
|
|
case ID_HELP_ABOUT:
|
2012-11-01 15:19:01 +00:00
|
|
|
DialogManager::EnableAll(FALSE);
|
|
|
|
DialogBox(hInst, (LPCTSTR)IDD_ABOUTBOX, hWnd, (DLGPROC)About);
|
|
|
|
DialogManager::EnableAll(TRUE);
|
|
|
|
break;
|
2013-06-22 20:27:59 +00:00
|
|
|
case ID_DEBUG_TAKESCREENSHOT:
|
|
|
|
g_TakeScreenshot = true;
|
|
|
|
break;
|
2012-11-01 15:19:01 +00:00
|
|
|
|
|
|
|
default:
|
2013-06-03 12:30:12 +00:00
|
|
|
MessageBox(hwndMain,"Unimplemented","Sorry",0);
|
2012-11-01 15:19:01 +00:00
|
|
|
break;
|
|
|
|
}
|
2013-06-03 12:30:12 +00:00
|
|
|
}
|
2012-11-01 15:19:01 +00:00
|
|
|
break;
|
2013-07-06 17:08:59 +00:00
|
|
|
|
2013-07-07 08:42:39 +00:00
|
|
|
case WM_INPUT:
|
2013-07-06 17:08:59 +00:00
|
|
|
{
|
2013-07-07 08:42:39 +00:00
|
|
|
UINT dwSize;
|
|
|
|
GetRawInputData((HRAWINPUT)lParam, RID_INPUT, NULL, &dwSize, sizeof(RAWINPUTHEADER));
|
|
|
|
if (!rawInputBuffer) {
|
|
|
|
rawInputBuffer = malloc(dwSize);
|
|
|
|
rawInputBufferSize = dwSize;
|
2013-07-07 02:12:06 +00:00
|
|
|
}
|
2013-07-07 08:42:39 +00:00
|
|
|
if (dwSize > rawInputBufferSize) {
|
|
|
|
rawInputBuffer = realloc(rawInputBuffer, dwSize);
|
|
|
|
}
|
|
|
|
GetRawInputData((HRAWINPUT)lParam, RID_INPUT, rawInputBuffer, &dwSize, sizeof(RAWINPUTHEADER));
|
|
|
|
RAWINPUT* raw = (RAWINPUT*)rawInputBuffer;
|
|
|
|
|
2013-07-07 16:27:53 +00:00
|
|
|
if (raw->header.dwType == RIM_TYPEKEYBOARD) {
|
2013-07-07 08:42:39 +00:00
|
|
|
KeyInput key;
|
|
|
|
key.deviceId = DEVICE_ID_KEYBOARD;
|
2013-07-07 16:27:53 +00:00
|
|
|
if (raw->data.keyboard.Message == WM_KEYDOWN || raw->data.keyboard.Message == WM_SYSKEYDOWN) {
|
2013-07-07 08:42:39 +00:00
|
|
|
key.flags = KEY_DOWN;
|
|
|
|
key.keyCode = windowsTransTable[GetTrueVKey(raw->data.keyboard)];
|
2013-07-15 15:41:24 +00:00
|
|
|
if (key.keyCode) {
|
2013-07-07 08:42:39 +00:00
|
|
|
NativeKey(key);
|
2013-07-15 15:41:24 +00:00
|
|
|
}
|
2013-07-07 08:42:39 +00:00
|
|
|
} else if (raw->data.keyboard.Message == WM_KEYUP) {
|
|
|
|
key.flags = KEY_UP;
|
|
|
|
key.keyCode = windowsTransTable[GetTrueVKey(raw->data.keyboard)];
|
2013-07-15 15:41:24 +00:00
|
|
|
if (key.keyCode) {
|
2013-07-07 08:42:39 +00:00
|
|
|
NativeKey(key);
|
2013-07-15 15:41:24 +00:00
|
|
|
}
|
2013-07-07 08:42:39 +00:00
|
|
|
}
|
2013-07-07 02:12:06 +00:00
|
|
|
}
|
2013-07-06 17:08:59 +00:00
|
|
|
}
|
2013-03-29 22:12:37 +00:00
|
|
|
return 0;
|
2013-05-13 09:13:49 +00:00
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
case WM_DROPFILES:
|
|
|
|
{
|
2013-06-08 00:32:07 +00:00
|
|
|
if (!EmuThread_Ready())
|
|
|
|
return DefWindowProc(hWnd, message, wParam, lParam);
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
HDROP hdrop = (HDROP)wParam;
|
|
|
|
int count = DragQueryFile(hdrop,0xFFFFFFFF,0,0);
|
|
|
|
if (count != 1)
|
|
|
|
{
|
|
|
|
MessageBox(hwndMain,"You can only load one file at a time","Error",MB_ICONINFORMATION);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
TCHAR filename[512];
|
|
|
|
DragQueryFile(hdrop,0,filename,512);
|
|
|
|
TCHAR *type = filename+_tcslen(filename)-3;
|
|
|
|
|
2013-03-29 17:50:08 +00:00
|
|
|
SendMessage(hWnd, WM_COMMAND, ID_EMULATION_STOP, 0);
|
2013-04-07 03:09:29 +00:00
|
|
|
// Ugly, need to wait for the stop message to process in the EmuThread.
|
|
|
|
Sleep(20);
|
2012-11-01 15:19:01 +00:00
|
|
|
|
|
|
|
MainWindow::SetPlaying(filename);
|
|
|
|
MainWindow::Update();
|
|
|
|
|
2013-04-07 03:09:29 +00:00
|
|
|
NativeMessageReceived("boot", filename);
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case WM_CLOSE:
|
2013-06-08 00:32:07 +00:00
|
|
|
/*
|
|
|
|
if (g_Config.bConfirmOnQuit && __KernelIsRunning())
|
|
|
|
if (IDYES != MessageBox(hwndMain, "A game is in progress. Are you sure you want to exit?",
|
|
|
|
"Are you sure?", MB_YESNO | MB_ICONQUESTION))
|
|
|
|
return 0;
|
|
|
|
//*/
|
2012-11-01 15:19:01 +00:00
|
|
|
EmuThread_Stop();
|
|
|
|
|
2013-01-02 21:57:57 +00:00
|
|
|
return DefWindowProc(hWnd,message,wParam,lParam);
|
2013-01-05 18:57:06 +00:00
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
case WM_DESTROY:
|
2013-06-11 18:14:53 +00:00
|
|
|
KillTimer(hWnd, TIMER_CURSORUPDATE);
|
|
|
|
KillTimer(hWnd, TIMER_CURSORMOVEUPDATE);
|
2012-11-01 15:19:01 +00:00
|
|
|
PostQuitMessage(0);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case WM_USER+1:
|
2013-04-01 01:35:29 +00:00
|
|
|
if (disasmWindow[0])
|
|
|
|
SendMessage(disasmWindow[0]->GetDlgHandle(), WM_CLOSE, 0, 0);
|
|
|
|
if (memoryWindow[0])
|
2013-04-21 02:54:25 +00:00
|
|
|
SendMessage(memoryWindow[0]->GetDlgHandle(), WM_CLOSE, 0, 0);
|
2013-04-01 01:35:29 +00:00
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
disasmWindow[0] = new CDisasm(MainWindow::GetHInstance(), MainWindow::GetHWND(), currentDebugMIPS);
|
|
|
|
DialogManager::AddDlg(disasmWindow[0]);
|
2012-12-04 16:05:36 +00:00
|
|
|
disasmWindow[0]->Show(g_Config.bShowDebuggerOnLoad);
|
2013-05-04 21:54:22 +00:00
|
|
|
if (g_Config.bFullScreen)
|
|
|
|
_ViewFullScreen(hWnd);
|
2012-11-01 15:19:01 +00:00
|
|
|
memoryWindow[0] = new CMemoryDlg(MainWindow::GetHInstance(), MainWindow::GetHWND(), currentDebugMIPS);
|
|
|
|
DialogManager::AddDlg(memoryWindow[0]);
|
|
|
|
if (disasmWindow[0])
|
|
|
|
disasmWindow[0]->NotifyMapLoaded();
|
|
|
|
if (memoryWindow[0])
|
|
|
|
memoryWindow[0]->NotifyMapLoaded();
|
2012-12-22 17:21:23 +00:00
|
|
|
|
2013-04-01 01:28:13 +00:00
|
|
|
SetForegroundWindow(hwndMain);
|
2012-11-01 15:19:01 +00:00
|
|
|
break;
|
2013-03-29 18:52:32 +00:00
|
|
|
|
2013-07-21 09:21:50 +00:00
|
|
|
case WM_USER_SAVESTATE_FINISH:
|
|
|
|
SetCursor(LoadCursor(0, IDC_ARROW));
|
|
|
|
break;
|
2013-03-29 18:52:32 +00:00
|
|
|
|
2013-03-29 18:32:20 +00:00
|
|
|
case WM_MENUSELECT:
|
2013-05-13 08:08:10 +00:00
|
|
|
// Unfortunately, accelerate keys (hotkeys) shares the same enabled/disabled states
|
|
|
|
// with corresponding menu items.
|
2013-03-29 18:32:20 +00:00
|
|
|
UpdateMenus();
|
|
|
|
break;
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2013-05-02 18:58:10 +00:00
|
|
|
// Turn off the screensaver.
|
|
|
|
// Note that if there's a screensaver password, this simple method
|
|
|
|
// doesn't work on Vista or higher.
|
|
|
|
case WM_SYSCOMMAND:
|
|
|
|
{
|
|
|
|
switch (wParam)
|
|
|
|
{
|
|
|
|
case SC_SCREENSAVE:
|
|
|
|
return 0;
|
|
|
|
case SC_MONITORPOWER:
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
return DefWindowProc(hWnd, message, wParam, lParam);
|
|
|
|
}
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
default:
|
|
|
|
return DefWindowProc(hWnd, message, wParam, lParam);
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void UpdateMenus()
|
|
|
|
{
|
|
|
|
HMENU menu = GetMenu(GetHWND());
|
|
|
|
#define CHECKITEM(item,value) CheckMenuItem(menu,item,MF_BYCOMMAND | ((value) ? MF_CHECKED : MF_UNCHECKED));
|
|
|
|
|
|
|
|
CHECKITEM(ID_EMULATION_SPEEDLIMIT,g_Config.bSpeedLimit);
|
|
|
|
// CHECK(ID_OPTIONS_ENABLEFRAMEBUFFER,g_Config.bEnableFrameBuffer);
|
|
|
|
// CHECK(ID_OPTIONS_EMULATESYSCALL,g_bEmulateSyscall);
|
|
|
|
CHECKITEM(ID_OPTIONS_DISPLAYRAWFRAMEBUFFER, g_Config.bDisplayFramebuffer);
|
|
|
|
CHECKITEM(ID_OPTIONS_IGNOREILLEGALREADS,g_Config.bIgnoreBadMemAccess);
|
2013-02-16 13:24:02 +00:00
|
|
|
CHECKITEM(ID_CPU_INTERPRETER,g_Config.bJit == false);
|
|
|
|
CHECKITEM(ID_CPU_DYNAREC,g_Config.bJit == true);
|
2012-11-26 16:35:08 +00:00
|
|
|
CHECKITEM(ID_OPTIONS_SHOWDEBUGSTATISTICS, g_Config.bShowDebugStats);
|
2012-12-21 10:08:54 +00:00
|
|
|
CHECKITEM(ID_OPTIONS_HARDWARETRANSFORM, g_Config.bHardwareTransform);
|
2012-12-21 15:49:02 +00:00
|
|
|
CHECKITEM(ID_OPTIONS_FASTMEMORY, g_Config.bFastMemory);
|
2013-01-26 23:15:39 +00:00
|
|
|
CHECKITEM(ID_OPTIONS_SIMPLE2XSSAA, g_Config.SSAntiAliasing);
|
2013-02-13 17:21:21 +00:00
|
|
|
CHECKITEM(ID_OPTIONS_STRETCHDISPLAY, g_Config.bStretchToDisplay);
|
2013-01-04 09:26:14 +00:00
|
|
|
CHECKITEM(ID_EMULATION_RUNONLOAD, g_Config.bAutoRun);
|
2013-01-10 11:51:18 +00:00
|
|
|
CHECKITEM(ID_OPTIONS_USEVBO, g_Config.bUseVBO);
|
2013-01-19 16:05:08 +00:00
|
|
|
CHECKITEM(ID_OPTIONS_VERTEXCACHE, g_Config.bVertexCache);
|
2013-06-19 05:08:29 +00:00
|
|
|
CHECKITEM(ID_OPTIONS_SHOWFPS, g_Config.iShowFPSCounter);
|
2013-05-02 14:48:28 +00:00
|
|
|
CHECKITEM(ID_OPTIONS_FRAMESKIP, g_Config.iFrameSkip != 0);
|
2013-04-17 19:07:41 +00:00
|
|
|
CHECKITEM(ID_OPTIONS_MIPMAP, g_Config.bMipMap);
|
2013-07-20 14:03:52 +00:00
|
|
|
CHECKITEM(ID_OPTIONS_VSYNC, g_Config.bVSync);
|
2013-06-10 21:45:12 +00:00
|
|
|
CHECKITEM(ID_OPTIONS_TOPMOST, g_Config.bTopMost);
|
2013-05-13 08:08:10 +00:00
|
|
|
CHECKITEM(ID_EMULATION_SOUND, g_Config.bEnableSound);
|
|
|
|
CHECKITEM(ID_TEXTURESCALING_DEPOSTERIZE, g_Config.bTexDeposterize);
|
2013-04-16 19:38:17 +00:00
|
|
|
|
2013-03-29 19:03:11 +00:00
|
|
|
static const int zoomitems[4] = {
|
2012-11-17 16:46:05 +00:00
|
|
|
ID_OPTIONS_SCREEN1X,
|
|
|
|
ID_OPTIONS_SCREEN2X,
|
|
|
|
ID_OPTIONS_SCREEN3X,
|
|
|
|
ID_OPTIONS_SCREEN4X,
|
|
|
|
};
|
|
|
|
for (int i = 0; i < 4; i++) {
|
|
|
|
CheckMenuItem(menu, zoomitems[i], MF_BYCOMMAND | ((i == g_Config.iWindowZoom - 1) ? MF_CHECKED : MF_UNCHECKED));
|
|
|
|
}
|
2013-04-30 01:47:33 +00:00
|
|
|
|
2013-04-30 10:14:34 +00:00
|
|
|
static const int texscalingitems[] = {
|
|
|
|
ID_TEXTURESCALING_OFF,
|
2013-05-01 21:55:34 +00:00
|
|
|
ID_TEXTURESCALING_2X,
|
|
|
|
ID_TEXTURESCALING_3X,
|
|
|
|
ID_TEXTURESCALING_4X,
|
|
|
|
ID_TEXTURESCALING_5X,
|
2013-04-30 01:47:33 +00:00
|
|
|
};
|
2013-04-30 10:14:34 +00:00
|
|
|
for (int i = 0; i < 5; i++) {
|
2013-05-01 21:55:34 +00:00
|
|
|
CheckMenuItem(menu, texscalingitems[i], MF_BYCOMMAND | ((i == g_Config.iTexScalingLevel-1) ? MF_CHECKED : MF_UNCHECKED));
|
|
|
|
}
|
|
|
|
|
|
|
|
static const int texscalingtypeitems[] = {
|
|
|
|
ID_TEXTURESCALING_XBRZ,
|
|
|
|
ID_TEXTURESCALING_HYBRID,
|
2013-05-04 23:27:15 +00:00
|
|
|
ID_TEXTURESCALING_BICUBIC,
|
|
|
|
ID_TEXTURESCALING_HYBRID_BICUBIC,
|
2013-05-01 21:55:34 +00:00
|
|
|
};
|
2013-05-04 23:27:15 +00:00
|
|
|
for (int i = 0; i < 4; i++) {
|
2013-05-01 21:55:34 +00:00
|
|
|
CheckMenuItem(menu, texscalingtypeitems[i], MF_BYCOMMAND | ((i == g_Config.iTexScalingType) ? MF_CHECKED : MF_UNCHECKED));
|
2013-04-30 01:47:33 +00:00
|
|
|
}
|
2013-05-13 08:08:10 +00:00
|
|
|
|
2013-06-30 06:48:50 +00:00
|
|
|
static const int texfilteringitems[] = {
|
2013-07-01 19:42:45 +00:00
|
|
|
ID_OPTIONS_TEXTUREFILTERING_AUTO,
|
2013-06-30 06:48:50 +00:00
|
|
|
ID_OPTIONS_NEARESTFILTERING,
|
|
|
|
ID_OPTIONS_LINEARFILTERING,
|
|
|
|
ID_OPTIONS_LINEARFILTERING_CG,
|
|
|
|
};
|
2013-07-01 19:42:45 +00:00
|
|
|
for (int i = 0; i < 4; i++) {
|
2013-07-20 12:50:50 +00:00
|
|
|
CheckMenuItem(menu, texfilteringitems[i], MF_BYCOMMAND | ( (i + 1) == g_Config.iTexFiltering )? MF_CHECKED : MF_UNCHECKED);
|
2013-06-30 06:48:50 +00:00
|
|
|
}
|
|
|
|
|
2013-07-21 15:17:42 +00:00
|
|
|
static const int renderingmode[] = {
|
|
|
|
ID_OPTIONS_NONBUFFEREDRENDERING,
|
|
|
|
ID_OPTIONS_BUFFEREDRENDERING,
|
|
|
|
ID_OPTIONS_READFBOTOMEMORYCPU,
|
2013-07-21 23:33:18 +00:00
|
|
|
ID_OPTIONS_READFBOTOMEMORYGPU,
|
2013-07-21 15:17:42 +00:00
|
|
|
};
|
|
|
|
for (int i = 0; i < 4; i++) {
|
|
|
|
CheckMenuItem(menu, renderingmode[i], MF_BYCOMMAND | ( i == g_Config.iRenderingMode )? MF_CHECKED : MF_UNCHECKED);
|
|
|
|
}
|
|
|
|
|
2013-05-13 08:08:10 +00:00
|
|
|
UpdateCommands();
|
|
|
|
}
|
|
|
|
|
|
|
|
void UpdateCommands()
|
|
|
|
{
|
|
|
|
static GlobalUIState lastGlobalUIState = UISTATE_PAUSEMENU;
|
|
|
|
static CoreState lastCoreState = CORE_ERROR;
|
|
|
|
|
|
|
|
if (lastGlobalUIState == globalUIState && lastCoreState == coreState)
|
|
|
|
return;
|
|
|
|
|
|
|
|
lastCoreState = coreState;
|
|
|
|
lastGlobalUIState = globalUIState;
|
|
|
|
|
|
|
|
HMENU menu = GetMenu(GetHWND());
|
|
|
|
|
2013-07-10 14:49:48 +00:00
|
|
|
const char* pauseMenuText = (Core_IsStepping() || globalUIState != UISTATE_INGAME) ? "Run\tF8" : "Pause\tF8";
|
|
|
|
ModifyMenu(menu, ID_TOGGLE_PAUSE, MF_BYCOMMAND | MF_STRING, ID_TOGGLE_PAUSE, pauseMenuText);
|
2013-05-13 08:08:10 +00:00
|
|
|
|
|
|
|
UINT ingameEnable = globalUIState == UISTATE_INGAME ? MF_ENABLED : MF_GRAYED;
|
2013-07-09 20:25:29 +00:00
|
|
|
EnableMenuItem(menu,ID_TOGGLE_PAUSE, ingameEnable);
|
2013-05-13 08:08:10 +00:00
|
|
|
EnableMenuItem(menu,ID_EMULATION_STOP, ingameEnable);
|
|
|
|
EnableMenuItem(menu,ID_EMULATION_RESET, ingameEnable);
|
|
|
|
|
|
|
|
UINT menuEnable = globalUIState == UISTATE_MENU ? MF_ENABLED : MF_GRAYED;
|
|
|
|
EnableMenuItem(menu,ID_FILE_SAVESTATEFILE, !menuEnable);
|
|
|
|
EnableMenuItem(menu,ID_FILE_LOADSTATEFILE, !menuEnable);
|
|
|
|
EnableMenuItem(menu,ID_FILE_QUICKSAVESTATE, !menuEnable);
|
|
|
|
EnableMenuItem(menu,ID_FILE_QUICKLOADSTATE, !menuEnable);
|
|
|
|
EnableMenuItem(menu,ID_CPU_DYNAREC, menuEnable);
|
|
|
|
EnableMenuItem(menu,ID_CPU_INTERPRETER, menuEnable);
|
2013-07-10 14:49:48 +00:00
|
|
|
EnableMenuItem(menu,ID_TOGGLE_PAUSE, !menuEnable);
|
2013-05-13 08:08:10 +00:00
|
|
|
EnableMenuItem(menu,ID_EMULATION_STOP, !menuEnable);
|
2013-07-10 14:49:48 +00:00
|
|
|
EnableMenuItem(menu,ID_EMULATION_RESET, !menuEnable);
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Message handler for about box.
|
|
|
|
LRESULT CALLBACK About(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
|
|
|
|
{
|
|
|
|
switch (message)
|
|
|
|
{
|
|
|
|
case WM_INITDIALOG:
|
|
|
|
W32Util::CenterWindow(hDlg);
|
2013-03-11 21:55:29 +00:00
|
|
|
{
|
|
|
|
HWND versionBox = GetDlgItem(hDlg, IDC_VERSION);
|
|
|
|
char temp[256];
|
|
|
|
sprintf(temp, "PPSSPP %s", PPSSPP_GIT_VERSION);
|
|
|
|
SetWindowText(versionBox, temp);
|
|
|
|
}
|
2012-11-01 15:19:01 +00:00
|
|
|
return TRUE;
|
|
|
|
|
|
|
|
case WM_COMMAND:
|
|
|
|
if (LOWORD(wParam) == IDOK || LOWORD(wParam) == IDCANCEL)
|
|
|
|
{
|
|
|
|
EndDialog(hDlg, LOWORD(wParam));
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Update()
|
|
|
|
{
|
|
|
|
InvalidateRect(hwndDisplay,0,0);
|
|
|
|
UpdateWindow(hwndDisplay);
|
|
|
|
SendMessage(hwndMain,WM_SIZE,0,0);
|
|
|
|
}
|
|
|
|
|
|
|
|
void Redraw()
|
|
|
|
{
|
|
|
|
InvalidateRect(hwndDisplay,0,0);
|
|
|
|
}
|
2013-03-29 20:21:27 +00:00
|
|
|
|
2012-12-05 06:31:41 +00:00
|
|
|
void _ViewNormal(HWND hWnd)
|
|
|
|
{
|
2012-12-22 00:57:44 +00:00
|
|
|
// put caption and border styles back
|
|
|
|
DWORD dwOldStyle = ::GetWindowLong(hWnd, GWL_STYLE);
|
|
|
|
DWORD dwNewStyle = dwOldStyle | WS_CAPTION | WS_THICKFRAME;
|
|
|
|
::SetWindowLong(hWnd, GWL_STYLE, dwNewStyle);
|
|
|
|
|
|
|
|
// put back the menu bar
|
|
|
|
::SetMenu(hWnd, menu);
|
|
|
|
|
|
|
|
// resize to normal view
|
|
|
|
// NOTE: use SWP_FRAMECHANGED to force redraw non-client
|
|
|
|
const int x = g_normalRC.left;
|
|
|
|
const int y = g_normalRC.top;
|
|
|
|
const int cx = g_normalRC.right - g_normalRC.left;
|
|
|
|
const int cy = g_normalRC.bottom - g_normalRC.top;
|
|
|
|
::SetWindowPos(hWnd, HWND_NOTOPMOST, x, y, cx, cy, SWP_FRAMECHANGED);
|
|
|
|
|
|
|
|
// reset full screen indicator
|
|
|
|
g_bFullScreen = FALSE;
|
2013-05-26 21:55:23 +00:00
|
|
|
CorrectCursor();
|
2013-01-26 22:46:02 +00:00
|
|
|
ResizeDisplay();
|
2013-05-26 21:56:05 +00:00
|
|
|
ShowOwnedPopups(hwndMain, TRUE);
|
2012-12-05 06:31:41 +00:00
|
|
|
}
|
|
|
|
|
2012-12-22 00:57:44 +00:00
|
|
|
void _ViewFullScreen(HWND hWnd)
|
|
|
|
{
|
|
|
|
// keep in mind normal window rectangle
|
|
|
|
::GetWindowRect(hWnd, &g_normalRC);
|
|
|
|
|
|
|
|
// remove caption and border styles
|
|
|
|
DWORD dwOldStyle = ::GetWindowLong(hWnd, GWL_STYLE);
|
|
|
|
DWORD dwNewStyle = dwOldStyle & ~(WS_CAPTION | WS_THICKFRAME);
|
|
|
|
::SetWindowLong(hWnd, GWL_STYLE, dwNewStyle);
|
|
|
|
|
|
|
|
// remove the menu bar
|
|
|
|
::SetMenu(hWnd, NULL);
|
|
|
|
|
|
|
|
// resize to full screen view
|
|
|
|
// NOTE: use SWP_FRAMECHANGED to force redraw non-client
|
|
|
|
const int x = 0;
|
|
|
|
const int y = 0;
|
|
|
|
const int cx = ::GetSystemMetrics(SM_CXSCREEN);
|
|
|
|
const int cy = ::GetSystemMetrics(SM_CYSCREEN);
|
|
|
|
::SetWindowPos(hWnd, HWND_TOPMOST, x, y, cx, cy, SWP_FRAMECHANGED);
|
|
|
|
|
|
|
|
// set full screen indicator
|
|
|
|
g_bFullScreen = TRUE;
|
2013-05-26 21:55:23 +00:00
|
|
|
CorrectCursor();
|
2013-01-26 22:46:02 +00:00
|
|
|
ResizeDisplay();
|
2013-05-26 21:56:05 +00:00
|
|
|
ShowOwnedPopups(hwndMain, FALSE);
|
2012-12-22 00:57:44 +00:00
|
|
|
}
|
2012-11-01 15:19:01 +00:00
|
|
|
|
|
|
|
void SetPlaying(const char *text)
|
|
|
|
{
|
2013-03-02 20:31:11 +00:00
|
|
|
char temp[256];
|
2012-11-01 15:19:01 +00:00
|
|
|
if (text == 0)
|
2013-03-02 20:31:11 +00:00
|
|
|
snprintf(temp, 256, "PPSSPP %s", PPSSPP_GIT_VERSION);
|
2012-11-01 15:19:01 +00:00
|
|
|
else
|
2013-03-02 20:31:11 +00:00
|
|
|
snprintf(temp, 256, "%s - PPSSPP %s", text, PPSSPP_GIT_VERSION);
|
|
|
|
temp[255] = '\0';
|
|
|
|
SetWindowText(hwndMain, temp);
|
2012-11-01 15:19:01 +00:00
|
|
|
}
|
|
|
|
|
2013-01-02 20:00:10 +00:00
|
|
|
void SaveStateActionFinished(bool result, void *userdata)
|
2012-12-28 21:50:59 +00:00
|
|
|
{
|
2013-07-21 09:21:50 +00:00
|
|
|
PostMessage(hwndMain, WM_USER_SAVESTATE_FINISH, 0, 0);
|
2012-12-28 21:50:59 +00:00
|
|
|
}
|
|
|
|
|
2012-11-01 15:19:01 +00:00
|
|
|
HINSTANCE GetHInstance()
|
|
|
|
{
|
|
|
|
return hInst;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|