--- np2/win9x/scrnmng.cpp 2003/10/21 14:57:41 1.4 +++ np2/win9x/scrnmng.cpp 2003/10/26 12:12:12 1.6 @@ -31,6 +31,9 @@ typedef struct { BYTE r16b; BYTE l16r; BYTE l16g; + BYTE menudisp; + int menusize; + HMENU menuhdl; RECT scrn; RECT rect; PALETTEENTRY pal[256]; @@ -205,9 +208,17 @@ static void clearoutofrect(const RECT *t static void clearoutscreen(void) { RECT base; + POINT clipt; RECT target; GetClientRect(hWndMain, &base); + clipt.x = 0; + clipt.y = 0; + ClientToScreen(hWndMain, &clipt); + base.left += clipt.x; + base.top += clipt.y; + base.right += clipt.x; + base.bottom += clipt.y; target.left = base.left + ddraw.scrn.left; target.top = base.top + ddraw.scrn.top; target.right = base.left + ddraw.scrn.right; @@ -217,7 +228,13 @@ static void clearoutscreen(void) { static void clearoutfullscreen(void) { - clearoutofrect(&ddraw.scrn, &ddraw.rect); + RECT r; + + r.left = 0; + r.top = (ddraw.menuhdl)?0:ddraw.menusize; + r.right = ddraw.width; // (+ ddraw.extend) + r.bottom = ddraw.height; + clearoutofrect(&ddraw.scrn, &r); dclock_redraw(); } @@ -321,6 +338,10 @@ BOOL scrnmng_create(BYTE scrnmode) { winstyleex |= WS_EX_TOPMOST; CheckMenuItem(hmenu, IDM_WINDOW, MF_UNCHECKED); CheckMenuItem(hmenu, IDM_FULLSCREEN, MF_CHECKED); + ddraw.menudisp = 0; + ddraw.menusize = GetSystemMetrics(SM_CYMENU); + ddraw.menuhdl = GetMenu(hWndMain); + SetMenu(hWndMain, NULL); } else { scrnmng.flag = SCRNFLAG_HAVEEXTEND; @@ -488,6 +509,7 @@ void scrnmng_destroy(void) { if (ddraw.ddraw1) { ddraw.ddraw1->Release(); } + scrnmng_enablemenubar(); ZeroMemory(&ddraw, sizeof(ddraw)); } @@ -507,6 +529,42 @@ RGB16 scrnmng_makepal16(RGB32 pal32) { (pal.p.r << ddraw.l16r) + (pal.p.b >> ddraw.r16b))); } +void scrnmng_enablemenubar(void) { + + if (ddraw.menuhdl) { + SetMenu(hWndMain, ddraw.menuhdl); + ddraw.menuhdl = NULL; + DrawMenuBar(hWndMain); + } +} + +void scrnmng_disablemenubar(void) { + + if (ddraw.menuhdl == NULL) { + ddraw.menuhdl = GetMenu(hWndMain); + SetMenu(hWndMain, NULL); + } +} + +void scrnmng_fullscrnmenu(int y) { + + BYTE menudisp; + + if (scrnmng.flag & SCRNFLAG_FULLSCREEN) { + menudisp = ((y >= 0) && (y < ddraw.menusize))?1:0; + if (ddraw.menudisp != menudisp) { + ddraw.menudisp = menudisp; + if (menudisp == 1) { + scrnmng_enablemenubar(); + } + else { + scrnmng_disablemenubar(); + clearoutfullscreen(); + } + } + } +} + void scrnmng_topwinui(void) { mouse_running(MOUSE_STOP); @@ -531,7 +589,9 @@ void scrnmng_clearwinui(void) { } } if (scrnmng.flag & SCRNFLAG_FULLSCREEN) { + scrnmng_disablemenubar(); clearoutfullscreen(); + ddraw.menudisp = 0; } mouse_running(MOUSE_CONT); }