disable fullscreen GDI objects (menu & mode confirm dialog) for D3D & OpenGL
git-svn-id: https://svn.code.sf.net/p/vbam/code/trunk@180 a31d4220-a93d-0410-bf67-fe4944624d44
This commit is contained in:
parent
c963116c6f
commit
a9b8ab92f9
|
@ -152,11 +152,6 @@ void Direct3DDisplay::prepareDisplayMode()
|
||||||
dpp.PresentationInterval = theApp.vsync ? D3DPRESENT_INTERVAL_ONE : D3DPRESENT_INTERVAL_IMMEDIATE;
|
dpp.PresentationInterval = theApp.vsync ? D3DPRESENT_INTERVAL_ONE : D3DPRESENT_INTERVAL_IMMEDIATE;
|
||||||
// D3DPRESENT_INTERVAL_ONE means VSync ON
|
// D3DPRESENT_INTERVAL_ONE means VSync ON
|
||||||
|
|
||||||
if( theApp.vsync && ( dpp.Windowed == FALSE ) && theApp.menuToggle ) {
|
|
||||||
// HACK: VSync will be disabled when the menu is opened in full screen mode
|
|
||||||
dpp.PresentationInterval = D3DPRESENT_INTERVAL_IMMEDIATE;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
// make debugging full screen easier
|
// make debugging full screen easier
|
||||||
|
|
|
@ -697,6 +697,12 @@ void MainWnd::OnFileTogglemenu()
|
||||||
if(theApp.videoOption <= VIDEO_4X)
|
if(theApp.videoOption <= VIDEO_4X)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if( theApp.renderMethod != DIRECT_DRAW ) {
|
||||||
|
// display API does not support GDI objects in fullscreen
|
||||||
|
theApp.updateWindowSize( theApp.lastWindowed );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
theApp.menuToggle = !theApp.menuToggle;
|
theApp.menuToggle = !theApp.menuToggle;
|
||||||
|
|
||||||
if(theApp.menuToggle) {
|
if(theApp.menuToggle) {
|
||||||
|
|
|
@ -313,7 +313,9 @@ void MainWnd::OnUpdateOptionsVideoFullscreen1280x1024(CCmdUI *pCmdUI)
|
||||||
BOOL MainWnd::OnOptionVideoSize(UINT nID)
|
BOOL MainWnd::OnOptionVideoSize(UINT nID)
|
||||||
{
|
{
|
||||||
theApp.updateVideoSize(nID);
|
theApp.updateVideoSize(nID);
|
||||||
|
if( theApp.renderMethod == DIRECT_DRAW ) {
|
||||||
theApp.m_pMainWnd->PostMessage(VBA_CONFIRM_MODE);
|
theApp.m_pMainWnd->PostMessage(VBA_CONFIRM_MODE);
|
||||||
|
}
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -372,9 +374,11 @@ void MainWnd::OnOptionsVideoFullscreen()
|
||||||
regSetDwordValue("defaultVideoDriver", TRUE);
|
regSetDwordValue("defaultVideoDriver", TRUE);
|
||||||
}
|
}
|
||||||
theApp.updateVideoSize(ID_OPTIONS_VIDEO_FULLSCREEN);
|
theApp.updateVideoSize(ID_OPTIONS_VIDEO_FULLSCREEN);
|
||||||
|
if( theApp.renderMethod == DIRECT_DRAW ) {
|
||||||
theApp.m_pMainWnd->PostMessage(VBA_CONFIRM_MODE);
|
theApp.m_pMainWnd->PostMessage(VBA_CONFIRM_MODE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
theApp.winAccelMgr.UpdateMenu(theApp.menu);
|
theApp.winAccelMgr.UpdateMenu(theApp.menu);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -332,6 +332,7 @@ VBA::VBA()
|
||||||
autoLoadMostRecent = false;
|
autoLoadMostRecent = false;
|
||||||
fsMaxScale = 0;
|
fsMaxScale = 0;
|
||||||
romSize = 0;
|
romSize = 0;
|
||||||
|
lastWindowed = VIDEO_3X;
|
||||||
|
|
||||||
updateCount = 0;
|
updateCount = 0;
|
||||||
|
|
||||||
|
@ -932,6 +933,10 @@ void VBA::updateMenuBar()
|
||||||
popup = NULL;
|
popup = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if( ( renderMethod != DIRECT_DRAW ) && ( videoOption >= VIDEO_320x240 ) ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
m_menu.Attach(winResLoadMenu(MAKEINTRESOURCE(IDR_MENU)));
|
m_menu.Attach(winResLoadMenu(MAKEINTRESOURCE(IDR_MENU)));
|
||||||
menu = (HMENU)m_menu;
|
menu = (HMENU)m_menu;
|
||||||
|
|
||||||
|
@ -1794,6 +1799,9 @@ void VBA::updateWindowSize(int value)
|
||||||
fsForceChange) {
|
fsForceChange) {
|
||||||
fsForceChange = false;
|
fsForceChange = false;
|
||||||
changingVideoSize = true;
|
changingVideoSize = true;
|
||||||
|
if( videoOption <= VIDEO_4X ) {
|
||||||
|
lastWindowed = (VIDEO_SIZE)videoOption; // save for when leaving full screen
|
||||||
|
}
|
||||||
shutdownDisplay();
|
shutdownDisplay();
|
||||||
if(input) {
|
if(input) {
|
||||||
delete input;
|
delete input;
|
||||||
|
@ -1826,7 +1834,10 @@ void VBA::updateWindowSize(int value)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
input->checkKeys();
|
input->checkKeys();
|
||||||
|
|
||||||
|
if( renderMethod == DIRECT_DRAW ) {
|
||||||
updateMenuBar();
|
updateMenuBar();
|
||||||
|
}
|
||||||
changingVideoSize = FALSE;
|
changingVideoSize = FALSE;
|
||||||
updateWindowSize(videoOption);
|
updateWindowSize(videoOption);
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -45,7 +45,7 @@
|
||||||
// See VBA.cpp for the implementation of this class
|
// See VBA.cpp for the implementation of this class
|
||||||
//
|
//
|
||||||
|
|
||||||
enum {
|
enum VIDEO_SIZE{
|
||||||
VIDEO_1X, VIDEO_2X, VIDEO_3X, VIDEO_4X,
|
VIDEO_1X, VIDEO_2X, VIDEO_3X, VIDEO_4X,
|
||||||
VIDEO_320x240, VIDEO_640x480, VIDEO_800x600, VIDEO_1024x768, VIDEO_1280x1024,
|
VIDEO_320x240, VIDEO_640x480, VIDEO_800x600, VIDEO_1024x768, VIDEO_1280x1024,
|
||||||
VIDEO_OTHER
|
VIDEO_OTHER
|
||||||
|
@ -209,6 +209,7 @@ class VBA : public CWinApp
|
||||||
bool autoLoadMostRecent;
|
bool autoLoadMostRecent;
|
||||||
int fsMaxScale;
|
int fsMaxScale;
|
||||||
int romSize;
|
int romSize;
|
||||||
|
VIDEO_SIZE lastWindowed;
|
||||||
|
|
||||||
CList<IUpdateListener *, IUpdateListener*&> updateList;
|
CList<IUpdateListener *, IUpdateListener*&> updateList;
|
||||||
int updateCount;
|
int updateCount;
|
||||||
|
|
Loading…
Reference in New Issue