Win32 - memory watch - option to bind to main window, if checked it gives GENS dialog style control, where there is no extra task bar item, and it minimizes when FCEUX is minimized

This commit is contained in:
adelikat 2009-06-25 02:56:18 +00:00
parent c4236dd151
commit 6e9cf95760
6 changed files with 23 additions and 3 deletions

View File

@ -1,4 +1,5 @@
24-jun-2009 - adelikat - win32 - 24-jun-2009 - adelikat - win32 - memory watch - option to bind to main window, if checked it gives GENS dialog style control, where there is no extra task bar item, and it minimizes when FCEUX is minimized
24-jun-2009 - adelikat - win32 - palette commandline options
24-jun-2009 - adelikat - win32 - Sound Dialog - cleanup, when sound is off, all controls are grayed out 24-jun-2009 - adelikat - win32 - Sound Dialog - cleanup, when sound is off, all controls are grayed out
24-jun-2009 - adelikat - win32 - Hex Editor - Drag & Drop for .tbl files 24-jun-2009 - adelikat - win32 - Hex Editor - Drag & Drop for .tbl files
24-jun-2009 - adelikat - win32 - Drag & Drop for .fcm, it converts and then loads the converted movie automatically 24-jun-2009 - adelikat - win32 - Drag & Drop for .fcm, it converts and then loads the converted movie automatically

View File

@ -206,6 +206,7 @@ static CFGSTRUCT fceuconfig[] = {
AC(MemWatchLoadOnStart), AC(MemWatchLoadOnStart),
AC(MemWatchLoadFileOnStart), AC(MemWatchLoadFileOnStart),
AC(MemWCollapsed), AC(MemWCollapsed),
AC(BindToMain),
AC(EnableAutosave), AC(EnableAutosave),
AC(frameAdvanceLagSkip), AC(frameAdvanceLagSkip),

View File

@ -28,6 +28,7 @@
#include "help.h" #include "help.h"
#include <string> #include <string>
#include "main.h" #include "main.h"
#include "window.h" //adelikat: For GetMainHWDN()
using namespace std; using namespace std;
@ -57,6 +58,7 @@ char memwLastFilename[2048]; //Last watch file used by memwatch
bool fileChanged = false; //Determines if Save Changes should appear bool fileChanged = false; //Determines if Save Changes should appear
bool MemWatchLoadOnStart = false; //Load on Start Flag bool MemWatchLoadOnStart = false; //Load on Start Flag
bool MemWatchLoadFileOnStart = false; //Load last file Flag bool MemWatchLoadFileOnStart = false; //Load last file Flag
bool BindToMain = false; //Whether or not FCEUX is in control of this dialog (by default all dialogs in FCEUX aren't)
string memwhelp = "{01ABA5FD-D54A-44EF-961A-42C7AA586D95}"; //Name of memory watch chapter in .chm (sure would be nice to get better names for these!" string memwhelp = "{01ABA5FD-D54A-44EF-961A-42C7AA586D95}"; //Name of memory watch chapter in .chm (sure would be nice to get better names for these!"
@ -785,6 +787,7 @@ static BOOL CALLBACK MemWatchCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARA
case WM_INITMENU: case WM_INITMENU:
CheckMenuItem(memwmenu, MEMW_OPTIONS_LOADSTART, MemWatchLoadOnStart ? MF_CHECKED : MF_UNCHECKED); CheckMenuItem(memwmenu, MEMW_OPTIONS_LOADSTART, MemWatchLoadOnStart ? MF_CHECKED : MF_UNCHECKED);
CheckMenuItem(memwmenu, MEMW_OPTIONS_LOADLASTFILE, MemWatchLoadFileOnStart ? MF_CHECKED : MF_UNCHECKED); CheckMenuItem(memwmenu, MEMW_OPTIONS_LOADLASTFILE, MemWatchLoadFileOnStart ? MF_CHECKED : MF_UNCHECKED);
CheckMenuItem(memwmenu, ID_OPTIONS_BINDTOMAINWINDOW, BindToMain ? MF_CHECKED : MF_UNCHECKED);
break; break;
case WM_CLOSE: case WM_CLOSE:
case WM_QUIT: case WM_QUIT:
@ -861,6 +864,11 @@ static BOOL CALLBACK MemWatchCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARA
CheckMenuItem(memwmenu, MEMW_OPTIONS_LOADLASTFILE, MemWatchLoadFileOnStart ? MF_CHECKED : MF_UNCHECKED); CheckMenuItem(memwmenu, MEMW_OPTIONS_LOADLASTFILE, MemWatchLoadFileOnStart ? MF_CHECKED : MF_UNCHECKED);
break; break;
case ID_OPTIONS_BINDTOMAINWINDOW: //adelikat: This option will attach/detach memwatch from the main window, if attached it doesn't not have its own taskbar item and will minimize when FCEUX is minimized
BindToMain ^= 1;
CheckMenuItem(memwmenu, ID_OPTIONS_BINDTOMAINWINDOW, BindToMain ? MF_CHECKED : MF_UNCHECKED);
break;
case MEMW_HELP_WCOMMANDS: case MEMW_HELP_WCOMMANDS:
OpenHelpWindow(memwhelp); OpenHelpWindow(memwhelp);
break; break;
@ -968,7 +976,13 @@ void CreateMemWatch()
} }
//Create //Create
hwndMemWatch=CreateDialog(fceu_hInstance,"MEMWATCH",NULL,MemWatchCallB); HWND Parent;
if (BindToMain)
Parent = GetMainHWND();
else
Parent = NULL;
hwndMemWatch=CreateDialog(fceu_hInstance,"MEMWATCH",Parent,MemWatchCallB);
memwmenu=GetMenu(hwndMemWatch); memwmenu=GetMenu(hwndMemWatch);
UpdateMemWatch(); UpdateMemWatch();
memwrecentmenu = CreateMenu(); memwrecentmenu = CreateMenu();

View File

@ -10,3 +10,4 @@ extern char *memw_recent_files[];
extern HWND memw_pwindow; extern HWND memw_pwindow;
extern bool RamChangeInitialize; extern bool RamChangeInitialize;
extern bool MemWCollapsed; extern bool MemWCollapsed;
extern bool BindToMain;

View File

@ -298,6 +298,8 @@ BEGIN
MENUITEM "Load Last &File on Startup", MEMW_OPTIONS_LOADLASTFILE MENUITEM "Load Last &File on Startup", MEMW_OPTIONS_LOADLASTFILE
MENUITEM SEPARATOR MENUITEM SEPARATOR
MENUITEM "&Collapse to 1 column", MEMW_OPTIONS_EXPANDCOLLAPSE MENUITEM "&Collapse to 1 column", MEMW_OPTIONS_EXPANDCOLLAPSE
MENUITEM SEPARATOR
MENUITEM "Bind to Main Window", ID_OPTIONS_BINDTOMAINWINDOW
END END
POPUP "&Help" POPUP "&Help"
BEGIN BEGIN

View File

@ -689,6 +689,7 @@
#define FCEUX_CONTEXT_SAVEMOVIEAS 40358 #define FCEUX_CONTEXT_SAVEMOVIEAS 40358
#define ID_FILE_RECENT40359 40359 #define ID_FILE_RECENT40359 40359
#define ID_TASEDIT_FILE_RECENT 40360 #define ID_TASEDIT_FILE_RECENT 40360
#define ID_OPTIONS_BINDTOMAINWINDOW 40361
#define IDC_DEBUGGER_ICONTRAY 55535 #define IDC_DEBUGGER_ICONTRAY 55535
#define MW_ValueLabel2 65423 #define MW_ValueLabel2 65423
#define MW_ValueLabel1 65426 #define MW_ValueLabel1 65426
@ -698,7 +699,7 @@
#ifdef APSTUDIO_INVOKED #ifdef APSTUDIO_INVOKED
#ifndef APSTUDIO_READONLY_SYMBOLS #ifndef APSTUDIO_READONLY_SYMBOLS
#define _APS_NEXT_RESOURCE_VALUE 125 #define _APS_NEXT_RESOURCE_VALUE 125
#define _APS_NEXT_COMMAND_VALUE 40361 #define _APS_NEXT_COMMAND_VALUE 40362
#define _APS_NEXT_CONTROL_VALUE 1205 #define _APS_NEXT_CONTROL_VALUE 1205
#define _APS_NEXT_SYMED_VALUE 101 #define _APS_NEXT_SYMED_VALUE 101
#endif #endif