Refactor full screen support, fix different behavior when enter full screen between 1 and >=2 times

This commit is contained in:
halx99 2020-08-02 11:54:46 +08:00
parent 8cc189fb4d
commit 106d8e2ecf
2 changed files with 48 additions and 24 deletions

View File

@ -545,7 +545,7 @@ void GLViewImpl::pollEvents()
} }
void GLViewImpl::enableRetina(bool enabled) void GLViewImpl::enableRetina(bool enabled)
{ { // official v4 comment follow sources
// #if (CC_TARGET_PLATFORM == CC_PLATFORM_MAC) // #if (CC_TARGET_PLATFORM == CC_PLATFORM_MAC)
// _isRetinaEnabled = enabled; // _isRetinaEnabled = enabled;
// if (_isRetinaEnabled) // if (_isRetinaEnabled)
@ -673,6 +673,8 @@ void GLViewImpl::setFullscreen(int monitorIndex) {
void GLViewImpl::setFullscreen(const GLFWvidmode &videoMode, GLFWmonitor *monitor) { void GLViewImpl::setFullscreen(const GLFWvidmode &videoMode, GLFWmonitor *monitor) {
_monitor = monitor; _monitor = monitor;
glfwSetWindowMonitor(_mainWindow, _monitor, 0, 0, videoMode.width, videoMode.height, videoMode.refreshRate); glfwSetWindowMonitor(_mainWindow, _monitor, 0, 0, videoMode.width, videoMode.height, videoMode.refreshRate);
updateWindowSize();
} }
void GLViewImpl::setWindowed(int width, int height) { void GLViewImpl::setWindowed(int width, int height) {
@ -690,9 +692,22 @@ void GLViewImpl::setWindowed(int width, int height) {
// on mac window will sometimes lose title when windowed // on mac window will sometimes lose title when windowed
glfwSetWindowTitle(_mainWindow, _viewName.c_str()); glfwSetWindowTitle(_mainWindow, _viewName.c_str());
#endif #endif
updateWindowSize();
} }
} }
void GLViewImpl::updateWindowSize()
{
int w = 0, h = 0;
glfwGetFramebufferSize(_mainWindow, &w, &h);
int frameWidth = w / _frameZoomFactor;
int frameHeight = h / _frameZoomFactor;
setFrameSize(frameWidth, frameHeight);
updateDesignResolutionSize();
Director::getInstance()->getEventDispatcher()->dispatchCustomEvent(GLViewImpl::EVENT_WINDOW_RESIZED, nullptr);
}
int GLViewImpl::getMonitorCount() const { int GLViewImpl::getMonitorCount() const {
int count = 0; int count = 0;
glfwGetMonitors(&count); glfwGetMonitors(&count);
@ -726,21 +741,21 @@ void GLViewImpl::updateFrameSize()
int frameBufferW = 0, frameBufferH = 0; int frameBufferW = 0, frameBufferH = 0;
glfwGetFramebufferSize(_mainWindow, &frameBufferW, &frameBufferH); glfwGetFramebufferSize(_mainWindow, &frameBufferW, &frameBufferH);
// if (frameBufferW == 2 * w && frameBufferH == 2 * h) if (frameBufferW == 2 * w && frameBufferH == 2 * h)
// { {
// if (_isRetinaEnabled) if (_isRetinaEnabled)
// { {
// _retinaFactor = 1; _retinaFactor = 1;
// } }
// else else
// { {
// _retinaFactor = 2; _retinaFactor = 2;
// } }
// glfwSetWindowSize(_mainWindow, _screenSize.width/2 * _retinaFactor * _frameZoomFactor, _screenSize.height/2 * _retinaFactor * _frameZoomFactor); glfwSetWindowSize(_mainWindow, _screenSize.width/2 * _retinaFactor * _frameZoomFactor, _screenSize.height/2 * _retinaFactor * _frameZoomFactor);
// _isInRetinaMonitor = true; _isInRetinaMonitor = true;
// } }
// else else
{ {
if (_isInRetinaMonitor) if (_isInRetinaMonitor)
{ {
@ -966,7 +981,7 @@ void GLViewImpl::onGLFWWindowPosCallback(GLFWwindow* /*window*/, int /*x*/, int
} }
void GLViewImpl::onGLFWFramebufferSizeCallback(GLFWwindow* window, int w, int h) void GLViewImpl::onGLFWFramebufferSizeCallback(GLFWwindow* window, int w, int h)
{ // win32 glfw never invoke this callback { // win32 glfw same with onGLFWWindowSizeCallback
#if CC_TARGET_PLATFORM != CC_PLATFORM_WIN32 #if CC_TARGET_PLATFORM != CC_PLATFORM_WIN32
float frameSizeW = _screenSize.width; float frameSizeW = _screenSize.width;
float frameSizeH = _screenSize.height; float frameSizeH = _screenSize.height;
@ -1000,14 +1015,19 @@ void GLViewImpl::onGLFWWindowSizeCallback(GLFWwindow* /*window*/, int w, int h)
{ {
if (w && h && _resolutionPolicy != ResolutionPolicy::UNKNOWN) if (w && h && _resolutionPolicy != ResolutionPolicy::UNKNOWN)
{ {
Size baseDesignSize = _designResolutionSize; /*
ResolutionPolicy baseResolutionPolicy = _resolutionPolicy; x-studio spec, fix view size incorrect when window size changed.
The original code behavior:
int frameWidth = w / _frameZoomFactor; 1. first time enter full screen: w,h=1920,1080
int frameHeight = h / _frameZoomFactor; 2. second or later enter full screen: will trigger 2 times WindowSizeCallback
setFrameSize(frameWidth, frameHeight); 1). w,h=976,679
setDesignResolutionSize(baseDesignSize.width, baseDesignSize.height, baseResolutionPolicy); 2). w,h=1024,768
@remark: we should use glfwSetWindowMonitor to control the window size in full screen mode
@see also: updateWindowSize (call after enter/exit full screen mode)
*/
updateDesignResolutionSize();
Director::getInstance()->getEventDispatcher()->dispatchCustomEvent(GLViewImpl::EVENT_WINDOW_RESIZED, nullptr); Director::getInstance()->getEventDispatcher()->dispatchCustomEvent(GLViewImpl::EVENT_WINDOW_RESIZED, nullptr);
} }
} }

View File

@ -86,6 +86,7 @@ public:
void setFullscreen(int monitorIndex); void setFullscreen(int monitorIndex);
void setFullscreen(const GLFWvidmode &videoMode, GLFWmonitor *monitor); void setFullscreen(const GLFWvidmode &videoMode, GLFWmonitor *monitor);
void setWindowed(int width, int height); void setWindowed(int width, int height);
int getMonitorCount() const; int getMonitorCount() const;
Size getMonitorSize() const; Size getMonitorSize() const;
@ -139,6 +140,9 @@ protected:
bool loadGL(); bool loadGL();
/* update frame layout when enter/exit full screen mode */
void updateWindowSize();
void updateFrameSize(); void updateFrameSize();
// GLFW callbacks // GLFW callbacks