--- np2/win9x/menu.cpp 2003/10/30 18:09:06 1.4 +++ np2/win9x/menu.cpp 2004/04/08 13:08:22 1.18 @@ -3,72 +3,126 @@ #include "np2.h" #include "sysmng.h" #include "menu.h" +#include "np2class.h" #include "pccore.h" + #define MFCHECK(a) ((a)?MF_CHECKED:MF_UNCHECKED) typedef struct { -const char *str; - int id; -} SMENUITEM; - -static const char smenu_toolwin[] = "&Tool Window"; -static const char smenu_center[] = "&Centering"; -static const char smenu_snap[] = "&Window Snap"; -static const char smenu_bg[] = "&Background"; -static const char smenu_bgsnd[] = "Background &Sound"; -static const char smenu_keydisp[] = "&Key display"; -static const char smenu_320x200[] = " 320x200"; -static const char smenu_480x300[] = " 480x300"; -static const char smenu_640x400[] = " 640x400"; -static const char smenu_800x500[] = " 800x500"; -static const char smenu_960x600[] = " 960x600"; -static const char smenu_1280x800[] = "1280x600"; - -static const char smenu_memdump[] = "&Memory Dump"; -static const char smenu_dbguty[] = "&Debug Utility"; - -static const SMENUITEM smenuitem[] = { - {smenu_toolwin, IDM_TOOLWIN}, - {smenu_center, IDM_SCREENCENTER}, - {smenu_snap, IDM_SNAPENABLE}, - {smenu_bg, IDM_BACKGROUND}, - {smenu_bgsnd, IDM_BGSOUND}, - {smenu_keydisp, IDM_KEYDISP}, - {NULL, 0}, - {smenu_320x200, IDM_SCRNMUL4}, - {smenu_480x300, IDM_SCRNMUL6}, - {smenu_640x400, IDM_SCRNMUL8}, - {smenu_800x500, IDM_SCRNMUL10}, - {smenu_960x600, IDM_SCRNMUL12}, - {smenu_1280x800, IDM_SCRNMUL16}, - {NULL, 0}}; + UINT16 id; + UINT16 str; +} MENUITEMS; + + +// これってAPIあるのか? +void menu_addmenubar(HMENU popup, HMENU menubar) { + + UINT cnt; + UINT pos; + UINT i; + MENUITEMINFO mii; + char str[128]; + HMENU hSubMenu; + + cnt = GetMenuItemCount(menubar); + pos = 0; + for (i=0; iid) { + insertresmenu(menu, pos, MF_BYPOSITION | MF_STRING, + item->id, item->str); } else { - InsertMenu(hMenu, i, MF_BYPOSITION | MF_SEPARATOR, 0, NULL); + InsertMenu(menu, pos, MF_BYPOSITION | MF_SEPARATOR, 0, NULL); } + item++; + pos++; } +} + + +// ---- + +static const MENUITEMS smenuitem[] = { + {IDM_TOOLWIN, IDS_TOOLWIN}, +#if defined(SUPPORT_KEYDISP) + {IDM_KEYDISP, IDS_KEYDISP}, +#endif +#if defined(SUPPORT_SOFTKBD) + {IDM_SOFTKBD, IDS_SOFTKBD}, +#endif + {0, 0}, + {IDM_SCREENCENTER, IDS_SCREENCENTER}, + {IDM_SNAPENABLE, IDS_SNAPENABLE}, + {IDM_BACKGROUND, IDS_BACKGROUND}, + {IDM_BGSOUND, IDS_BGSOUND}, + {0, 0}, + {IDM_SCRNMUL4, IDS_SCRNMUL4}, + {IDM_SCRNMUL6, IDS_SCRNMUL6}, + {IDM_SCRNMUL8, IDS_SCRNMUL8}, + {IDM_SCRNMUL10, IDS_SCRNMUL10}, + {IDM_SCRNMUL12, IDS_SCRNMUL12}, + {IDM_SCRNMUL16, IDS_SCRNMUL16}, + {0, 0}}; + +static const MENUITEMS smenuitem2[] = { +#if defined(CPUCORE_IA32) && defined(SUPPORT_MEMDBG32) + {IDM_MEMDBG32, IDS_MEMDBG32}, +#endif + {IDM_MEMORYDUMP, IDS_MEMORYDUMP}, + {IDM_DEBUGUTY, IDS_DEBUGUTY}, + {0, 0}}; + + +void sysmenu_initialize(void) { + + HMENU hMenu; + + hMenu = GetSystemMenu(hWndMain, FALSE); + insertresmenus(hMenu, 0, smenuitem, sizeof(smenuitem)/sizeof(MENUITEMS)); if (np2oscfg.I286SAVE) { - InsertMenu(hMenu, 6, MF_BYPOSITION | MF_STRING, IDM_MEMORYDUMP, - smenu_memdump); - InsertMenu(hMenu, 7, MF_BYPOSITION | MF_STRING, IDM_DEBUGUTY, - smenu_dbguty); + insertresmenus(hMenu, 0, smenuitem2, + sizeof(smenuitem2)/sizeof(MENUITEMS)); } } -void xmenu_settoolwin(BYTE value) { +void sysmenu_settoolwin(BYTE value) { value &= 1; np2oscfg.toolwin = value; @@ -76,7 +130,15 @@ void xmenu_settoolwin(BYTE value) { IDM_TOOLWIN, MFCHECK(value)); } -void xmenu_setwinsnap(BYTE value) { +void sysmenu_setkeydisp(BYTE value) { + + value &= 1; + np2oscfg.keydisp = value; + CheckMenuItem(GetSystemMenu(hWndMain, FALSE), + IDM_KEYDISP, MFCHECK(value)); +} + +void sysmenu_setwinsnap(BYTE value) { value &= 1; np2oscfg.WINSNAP = value; @@ -84,7 +146,7 @@ void xmenu_setwinsnap(BYTE value) { IDM_SNAPENABLE, MFCHECK(value)); } -void xmenu_setbackground(BYTE value) { +void sysmenu_setbackground(BYTE value) { HMENU hmenu; @@ -101,7 +163,7 @@ void xmenu_setbackground(BYTE value) { } } -void xmenu_setbgsound(BYTE value) { +void sysmenu_setbgsound(BYTE value) { np2oscfg.background &= 1; np2oscfg.background |= (value & 2); @@ -109,7 +171,7 @@ void xmenu_setbgsound(BYTE value) { IDM_BGSOUND, MFCHECK((value & 2) ^ 2)); } -void xmenu_setscrnmul(BYTE value) { +void sysmenu_setscrnmul(BYTE value) { HMENU hmenu; @@ -126,11 +188,121 @@ void xmenu_setscrnmul(BYTE value) { // ---- +typedef struct { + UINT16 title; + MENUITEMS item[3]; +} DISKMENU; + +static const DISKMENU fddmenu[4] = { + {IDS_FDD1, {{IDM_FDD1OPEN, IDS_OPEN}, + {0, 0}, + {IDM_FDD1EJECT, IDS_EJECT}}}, + {IDS_FDD2, {{IDM_FDD2OPEN, IDS_OPEN}, + {0, 0}, + {IDM_FDD2EJECT, IDS_EJECT}}}, + {IDS_FDD3, {{IDM_FDD3OPEN, IDS_OPEN}, + {0, 0}, + {IDM_FDD3EJECT, IDS_EJECT}}}, + {IDS_FDD4, {{IDM_FDD4OPEN, IDS_OPEN}, + {0, 0}, + {IDM_FDD4EJECT, IDS_EJECT}}}}; + +static void insdiskmenu(HMENU hMenu, UINT pos, const DISKMENU *m) { + + HMENU hSubMenu; + + hSubMenu = CreatePopupMenu(); + insertresmenus(hSubMenu, 0, m->item, 3); + insertresmenu(hMenu, pos, MF_BYPOSITION | MF_POPUP, + (UINT)hSubMenu, m->title); +} + +#if defined(SUPPORT_SCSI) +static const DISKMENU scsimenu[4] = { + {IDS_SCSI0, {{IDM_SCSI0OPEN, IDS_OPEN}, + {0, 0}, + {IDM_SCSI0EJECT, IDS_REMOVE}}}, + {IDS_SCSI1, {{IDM_SCSI1OPEN, IDS_OPEN}, + {0, 0}, + {IDM_SCSI1EJECT, IDS_REMOVE}}}, + {IDS_SCSI2, {{IDM_SCSI2OPEN, IDS_OPEN}, + {0, 0}, + {IDM_SCSI2EJECT, IDS_REMOVE}}}, + {IDS_SCSI3, {{IDM_SCSI3OPEN, IDS_OPEN}, + {0, 0}, + {IDM_SCSI3EJECT, IDS_REMOVE}}}}; +#endif + +#if defined(SUPPORT_STATSAVE) +static const char xmenu_stat[] = "S&tat"; +static const char xmenu_statsave[] = "Save %u"; +static const char xmenu_statload[] = "Load %u"; + +static void addstatsavemenu(HMENU hMenu, UINT pos) { + + HMENU hSubMenu; + UINT i; + char buf[16]; + + hSubMenu = CreatePopupMenu(); + for (i=0; i= 5) { + if (value > 6) { value = 0; } np2oscfg.F12COPY = value; - hmenu = GetMenu(hWndMain); + hmenu = np2class_gethmenu(hWndMain); CheckMenuItem(hmenu, IDM_F12MOUSE, MFCHECK(value == 0)); CheckMenuItem(hmenu, IDM_F12COPY, MFCHECK(value == 1)); CheckMenuItem(hmenu, IDM_F12STOP, MFCHECK(value == 2)); CheckMenuItem(hmenu, IDM_F12EQU, MFCHECK(value == 3)); CheckMenuItem(hmenu, IDM_F12COMMA, MFCHECK(value == 4)); + CheckMenuItem(hmenu, IDM_USERKEY1, MFCHECK(value == 5)); + CheckMenuItem(hmenu, IDM_USERKEY2, MFCHECK(value == 6)); } void xmenu_setbeepvol(BYTE value) { @@ -226,7 +400,7 @@ void xmenu_setbeepvol(BYTE value) { value &= 3; np2cfg.BEEP_VOL = value; - hmenu = GetMenu(hWndMain); + hmenu = np2class_gethmenu(hWndMain); CheckMenuItem(hmenu, IDM_BEEPOFF, MFCHECK(value == 0)); CheckMenuItem(hmenu, IDM_BEEPLOW, MFCHECK(value == 1)); CheckMenuItem(hmenu, IDM_BEEPMID, MFCHECK(value == 2)); @@ -239,23 +413,31 @@ void xmenu_setsound(BYTE value) { sysmng_update(SYS_UPDATESBOARD); np2cfg.SOUND_SW = value; - hmenu = GetMenu(hWndMain); - CheckMenuItem(hmenu, IDM_NOSOUND, MFCHECK(value == 0)); - CheckMenuItem(hmenu, IDM_PC9801_14, MFCHECK(value & 1)); - CheckMenuItem(hmenu, IDM_PC9801_26K, MFCHECK(value & 2)); - CheckMenuItem(hmenu, IDM_PC9801_86, MFCHECK(value & 4)); - CheckMenuItem(hmenu, IDM_PC9801_118, MFCHECK(value & 8)); - CheckMenuItem(hmenu, IDM_CHIBIOTO, MFCHECK(value & 0x10)); - CheckMenuItem(hmenu, IDM_SPEAKBOARD, MFCHECK(value & 0x20)); - CheckMenuItem(hmenu, IDM_SPARKBOARD, MFCHECK(value & 0x40)); - CheckMenuItem(hmenu, IDM_AMD98, MFCHECK(value & 0x80)); + hmenu = np2class_gethmenu(hWndMain); + CheckMenuItem(hmenu, IDM_NOSOUND, MFCHECK(value == 0x00)); + CheckMenuItem(hmenu, IDM_PC9801_14, MFCHECK(value == 0x01)); + CheckMenuItem(hmenu, IDM_PC9801_26K, MFCHECK(value == 0x02)); + CheckMenuItem(hmenu, IDM_PC9801_86, MFCHECK(value == 0x04)); + CheckMenuItem(hmenu, IDM_PC9801_26_86, MFCHECK(value == 0x06)); + CheckMenuItem(hmenu, IDM_PC9801_86_CB, MFCHECK(value == 0x14)); + CheckMenuItem(hmenu, IDM_PC9801_118, MFCHECK(value == 0x08)); + CheckMenuItem(hmenu, IDM_SPEAKBOARD, MFCHECK(value == 0x20)); + CheckMenuItem(hmenu, IDM_SPARKBOARD, MFCHECK(value == 0x40)); + CheckMenuItem(hmenu, IDM_AMD98, MFCHECK(value == 0x80)); +} + +void xmenu_setjastsound(BYTE value) { + + value &= 1; + np2oscfg.jastsnd = value; + CheckMenuItem(np2class_gethmenu(hWndMain), IDM_JASTSOUND, MFCHECK(value)); } void xmenu_setmotorflg(BYTE value) { value &= 1; np2cfg.MOTOR = value; - CheckMenuItem(GetMenu(hWndMain), IDM_SEEKSND, MFCHECK(value)); + CheckMenuItem(np2class_gethmenu(hWndMain), IDM_SEEKSND, MFCHECK(value)); } void xmenu_setextmem(BYTE value) { @@ -264,31 +446,44 @@ void xmenu_setextmem(BYTE value) { sysmng_update(SYS_UPDATEMEMORY); np2cfg.EXTMEM = value; - hmenu = GetMenu(hWndMain); + hmenu = np2class_gethmenu(hWndMain); CheckMenuItem(hmenu, IDM_MEM640, MFCHECK(value == 0)); CheckMenuItem(hmenu, IDM_MEM16, MFCHECK(value == 1)); CheckMenuItem(hmenu, IDM_MEM36, MFCHECK(value == 3)); CheckMenuItem(hmenu, IDM_MEM76, MFCHECK(value == 7)); + CheckMenuItem(hmenu, IDM_MEM116, MFCHECK(value == 11)); + CheckMenuItem(hmenu, IDM_MEM136, MFCHECK(value == 13)); } void xmenu_setmouse(BYTE value) { value &= 1; np2oscfg.MOUSE_SW = value; - CheckMenuItem(GetMenu(hWndMain), IDM_MOUSE, MFCHECK(value)); + CheckMenuItem(np2class_gethmenu(hWndMain), IDM_MOUSE, MFCHECK(value)); } +#if defined(SUPPORT_S98) void xmenu_sets98logging(BYTE value) { - CheckMenuItem(GetMenu(hWndMain), IDM_S98LOGGING, MFCHECK(value)); + CheckMenuItem(np2class_gethmenu(hWndMain), + IDM_S98LOGGING, MFCHECK(value)); } +#endif + +#if defined(SUPPORT_WAVEREC) +void xmenu_setwaverec(BYTE value) { + + CheckMenuItem(np2class_gethmenu(hWndMain), + IDM_WAVEREC, MFCHECK(value)); +} +#endif void xmenu_setshortcut(BYTE value) { HMENU hmenu; np2oscfg.shortcut = value; - hmenu = GetMenu(hWndMain); + hmenu = np2class_gethmenu(hWndMain); CheckMenuItem(hmenu, IDM_ALTENTER, MFCHECK(value & 1)); CheckMenuItem(hmenu, IDM_ALTF4, MFCHECK(value & 2)); } @@ -299,7 +494,7 @@ void xmenu_setdispclk(BYTE value) { value &= 3; np2oscfg.DISPCLK = value; - hmenu = GetMenu(hWndMain); + hmenu = np2class_gethmenu(hWndMain); CheckMenuItem(hmenu, IDM_DISPCLOCK, MFCHECK(value & 1)); CheckMenuItem(hmenu, IDM_DISPFRAME, MFCHECK(value & 2)); sysmng_workclockrenewal(); @@ -310,34 +505,27 @@ void xmenu_setbtnmode(BYTE value) { value &= 1; np2cfg.BTN_MODE = value; - CheckMenuItem(GetMenu(hWndMain), IDM_JOYX, MFCHECK(value)); + CheckMenuItem(np2class_gethmenu(hWndMain), IDM_JOYX, MFCHECK(value)); } void xmenu_setbtnrapid(BYTE value) { value &= 1; np2cfg.BTN_RAPID = value; - CheckMenuItem(GetMenu(hWndMain), IDM_RAPID, MFCHECK(value)); + CheckMenuItem(np2class_gethmenu(hWndMain), IDM_RAPID, MFCHECK(value)); } void xmenu_setmsrapid(BYTE value) { value &= 1; np2cfg.MOUSERAPID = value; - CheckMenuItem(GetMenu(hWndMain), IDM_MSRAPID, MFCHECK(value)); + CheckMenuItem(np2class_gethmenu(hWndMain), IDM_MSRAPID, MFCHECK(value)); } void xmenu_setsstp(BYTE value) { value &= 1; np2oscfg.sstp = value; - CheckMenuItem(GetMenu(hWndMain), IDM_SSTP, MFCHECK(value)); -} - -void xmenu_seti286save(BYTE value) { - - if (!value) { - EnableMenuItem(GetMenu(hWndMain), IDM_I286SAVE, MF_GRAYED); - } + CheckMenuItem(np2class_gethmenu(hWndMain), IDM_SSTP, MFCHECK(value)); }