--- np2/win9x/menu.cpp 2003/11/01 22:23:04 1.5 +++ np2/win9x/menu.cpp 2004/02/11 17:39:59 1.11 @@ -3,6 +3,7 @@ #include "np2.h" #include "sysmng.h" #include "menu.h" +#include "np2class.h" #include "pccore.h" @@ -28,6 +29,7 @@ static const char smenu_1280x800[] = "12 static const char smenu_memdump[] = "&Memory Dump"; static const char smenu_dbguty[] = "&Debug Utility"; +static const char menu_i286save[] = "&i286 save"; static const SMENUITEM smenuitem[] = { {smenu_toolwin, IDM_TOOLWIN}, @@ -46,7 +48,7 @@ static const SMENUITEM smenuitem[] = { {smenu_1280x800, IDM_SCRNMUL16}, {NULL, 0}}; -void sysmenu_init(void) { +void sysmenu_initialize(void) { HMENU hMenu; UINT i; @@ -135,11 +137,101 @@ void sysmenu_setscrnmul(BYTE value) { // ---- +// これって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; 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) { @@ -235,7 +329,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)); @@ -248,23 +342,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) { @@ -273,7 +375,7 @@ 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)); @@ -284,12 +386,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)); } void xmenu_sets98logging(BYTE value) { - CheckMenuItem(GetMenu(hWndMain), IDM_S98LOGGING, MFCHECK(value)); + CheckMenuItem(np2class_gethmenu(hWndMain), + IDM_S98LOGGING, MFCHECK(value)); } void xmenu_setshortcut(BYTE value) { @@ -297,7 +400,7 @@ 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)); } @@ -308,7 +411,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(); @@ -319,34 +422,35 @@ 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)); + CheckMenuItem(np2class_gethmenu(hWndMain), IDM_SSTP, MFCHECK(value)); } void xmenu_seti286save(BYTE value) { - if (!value) { - EnableMenuItem(GetMenu(hWndMain), IDM_I286SAVE, MF_GRAYED); + if (value) { + InsertMenu(GetSubMenu(np2class_gethmenu(hWndMain), 6), 10, + MF_BYPOSITION | MF_STRING, IDM_I286SAVE, menu_i286save); } }