Compare commits
3 commits
master
...
feature/wi
Author | SHA1 | Date | |
---|---|---|---|
![]() |
2e4a791bd6 | ||
![]() |
0317f83b70 | ||
![]() |
c793b81235 |
|
@ -34,6 +34,7 @@
|
||||||
#include <SFML/Window/GlResource.hpp>
|
#include <SFML/Window/GlResource.hpp>
|
||||||
#include <SFML/Window/VideoMode.hpp>
|
#include <SFML/Window/VideoMode.hpp>
|
||||||
#include <SFML/Window/WindowHandle.hpp>
|
#include <SFML/Window/WindowHandle.hpp>
|
||||||
|
#include <SFML/Window/WindowState.hpp>
|
||||||
#include <SFML/Window/WindowStyle.hpp>
|
#include <SFML/Window/WindowStyle.hpp>
|
||||||
#include <SFML/System/Clock.hpp>
|
#include <SFML/System/Clock.hpp>
|
||||||
#include <SFML/System/NonCopyable.hpp>
|
#include <SFML/System/NonCopyable.hpp>
|
||||||
|
@ -472,6 +473,30 @@ public:
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
bool hasFocus() const;
|
bool hasFocus() const;
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Set the window state
|
||||||
|
///
|
||||||
|
/// Set the window state.
|
||||||
|
///
|
||||||
|
/// \param state The new state
|
||||||
|
///
|
||||||
|
/// \see getState
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
void setState(State state);
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Get the windows state
|
||||||
|
///
|
||||||
|
/// Get the window state.
|
||||||
|
///
|
||||||
|
/// \return The window state
|
||||||
|
///
|
||||||
|
/// \see setState
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
State getState() const;
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
/// \brief Display on screen what has been rendered to the window so far
|
/// \brief Display on screen what has been rendered to the window so far
|
||||||
///
|
///
|
||||||
|
@ -537,7 +562,7 @@ private:
|
||||||
/// \brief Perform some common internal initializations
|
/// \brief Perform some common internal initializations
|
||||||
///
|
///
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void initialize();
|
void initialize(Uint32 style);
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
// Member data
|
// Member data
|
||||||
|
|
47
include/SFML/Window/WindowState.hpp
Normal file
47
include/SFML/Window/WindowState.hpp
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// SFML - Simple and Fast Multimedia Library
|
||||||
|
// Copyright (C) 2018 Foaly (foaly@posteo.de)
|
||||||
|
//
|
||||||
|
// This software is provided 'as-is', without any express or implied warranty.
|
||||||
|
// In no event will the authors be held liable for any damages arising from the use of this software.
|
||||||
|
//
|
||||||
|
// Permission is granted to anyone to use this software for any purpose,
|
||||||
|
// including commercial applications, and to alter it and redistribute it freely,
|
||||||
|
// subject to the following restrictions:
|
||||||
|
//
|
||||||
|
// 1. The origin of this software must not be misrepresented;
|
||||||
|
// you must not claim that you wrote the original software.
|
||||||
|
// If you use this software in a product, an acknowledgment
|
||||||
|
// in the product documentation would be appreciated but is not required.
|
||||||
|
//
|
||||||
|
// 2. Altered source versions must be plainly marked as such,
|
||||||
|
// and must not be misrepresented as being the original software.
|
||||||
|
//
|
||||||
|
// 3. This notice may not be removed or altered from any source distribution.
|
||||||
|
//
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
#ifndef SFML_WINDOWSTATE_HPP
|
||||||
|
#define SFML_WINDOWSTATE_HPP
|
||||||
|
|
||||||
|
|
||||||
|
namespace sf
|
||||||
|
{
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \ingroup window
|
||||||
|
/// \brief Enumeration of the window states
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
enum State
|
||||||
|
{
|
||||||
|
Windowed,
|
||||||
|
Minimized,
|
||||||
|
Maximized,
|
||||||
|
Fullscreen
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace sf
|
||||||
|
|
||||||
|
|
||||||
|
#endif // SFML_WINDOWSTATE_HPP
|
|
@ -42,6 +42,7 @@ namespace Style
|
||||||
Resize = 1 << 1, ///< Title bar + resizable border + maximize button
|
Resize = 1 << 1, ///< Title bar + resizable border + maximize button
|
||||||
Close = 1 << 2, ///< Title bar + close button
|
Close = 1 << 2, ///< Title bar + close button
|
||||||
Fullscreen = 1 << 3, ///< Fullscreen mode (this flag and all others are mutually exclusive)
|
Fullscreen = 1 << 3, ///< Fullscreen mode (this flag and all others are mutually exclusive)
|
||||||
|
Hidden = 1 << 4, ///< Hidden window
|
||||||
|
|
||||||
Default = Titlebar | Resize | Close ///< Default window style
|
Default = Titlebar | Resize | Close ///< Default window style
|
||||||
};
|
};
|
||||||
|
|
|
@ -45,6 +45,7 @@ set(SRC
|
||||||
${SRCROOT}/WindowImpl.cpp
|
${SRCROOT}/WindowImpl.cpp
|
||||||
${SRCROOT}/WindowImpl.hpp
|
${SRCROOT}/WindowImpl.hpp
|
||||||
${INCROOT}/WindowStyle.hpp
|
${INCROOT}/WindowStyle.hpp
|
||||||
|
${INCROOT}/WindowState.hpp
|
||||||
)
|
)
|
||||||
if(SFML_OPENGL_ES AND NOT SFML_OS_IOS)
|
if(SFML_OPENGL_ES AND NOT SFML_OS_IOS)
|
||||||
list(APPEND SRC ${SRCROOT}/EGLCheck.cpp)
|
list(APPEND SRC ${SRCROOT}/EGLCheck.cpp)
|
||||||
|
|
|
@ -158,6 +158,9 @@
|
||||||
[self setupWindowWithMode:mode andStyle:style];
|
[self setupWindowWithMode:mode andStyle:style];
|
||||||
|
|
||||||
[m_oglView finishInit];
|
[m_oglView finishInit];
|
||||||
|
|
||||||
|
if (style & sf::Style::Hidden)
|
||||||
|
[m_window orderOut:self];
|
||||||
}
|
}
|
||||||
return self;
|
return self;
|
||||||
}
|
}
|
||||||
|
@ -492,7 +495,7 @@
|
||||||
////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////
|
||||||
-(void)hideWindow
|
-(void)hideWindow
|
||||||
{
|
{
|
||||||
[m_window orderOut:nil];
|
[m_window orderOut:self];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -530,6 +533,54 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////
|
||||||
|
-(void)minimize
|
||||||
|
{
|
||||||
|
[m_window miniaturize:self];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////
|
||||||
|
-(void)unminimize
|
||||||
|
{
|
||||||
|
[m_window deminiaturize:self];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////
|
||||||
|
-(void)toogleMaximize
|
||||||
|
{
|
||||||
|
[m_window zoom:self];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////
|
||||||
|
-(BOOL)isMinimized
|
||||||
|
{
|
||||||
|
return [m_window isMiniaturized];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////
|
||||||
|
-(BOOL)isMaximized
|
||||||
|
{
|
||||||
|
// isZoomed is always true when the windows has the style NSBorderlessWindowMask or is fullscreen
|
||||||
|
// also the other SFML styles besides Resize can't be maximized, so we filter here
|
||||||
|
NSUInteger style = [m_window styleMask];
|
||||||
|
if ( !(style & NSResizableWindowMask) )
|
||||||
|
return NO;
|
||||||
|
|
||||||
|
return [m_window isZoomed];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////
|
||||||
|
-(BOOL)isFullscreen
|
||||||
|
{
|
||||||
|
return m_fullscreen;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////
|
||||||
-(void)enableKeyRepeat
|
-(void)enableKeyRepeat
|
||||||
{
|
{
|
||||||
|
|
|
@ -352,6 +352,23 @@ public:
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
virtual bool hasFocus() const;
|
virtual bool hasFocus() const;
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Set the window state
|
||||||
|
///
|
||||||
|
/// \param state The new state
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
virtual void setState(State state);
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Get the window state
|
||||||
|
///
|
||||||
|
/// \return The window state
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
virtual State getState() const;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
|
|
|
@ -524,6 +524,53 @@ bool WindowImplCocoa::hasFocus() const
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
void WindowImplCocoa::setState(State state)
|
||||||
|
{
|
||||||
|
State currentState = getState();
|
||||||
|
|
||||||
|
switch(state)
|
||||||
|
{
|
||||||
|
case State::Minimized:
|
||||||
|
[m_delegate minimize];
|
||||||
|
break;
|
||||||
|
|
||||||
|
case State::Maximized:
|
||||||
|
if (currentState == State::Windowed)
|
||||||
|
[m_delegate toogleMaximize];
|
||||||
|
if (currentState == State::Minimized)
|
||||||
|
{
|
||||||
|
[m_delegate unminimize];
|
||||||
|
[m_delegate toogleMaximize];
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case State::Windowed:
|
||||||
|
if (currentState == State::Minimized)
|
||||||
|
[m_delegate unminimize];
|
||||||
|
else if (currentState == State::Maximized)
|
||||||
|
[m_delegate toogleMaximize];
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Fullscreen:
|
||||||
|
sf::err() << "Switching to fullscreen is not implemtent on OSX yet." << std::endl;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
State WindowImplCocoa::getState() const
|
||||||
|
{
|
||||||
|
if ([m_delegate isFullscreen])
|
||||||
|
return State::Fullscreen;
|
||||||
|
if ([m_delegate isMinimized])
|
||||||
|
return State::Minimized;
|
||||||
|
if ([m_delegate isMaximized])
|
||||||
|
return State::Maximized;
|
||||||
|
return State::Windowed;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace priv
|
} // namespace priv
|
||||||
|
|
||||||
} // namespace sf
|
} // namespace sf
|
||||||
|
|
|
@ -195,6 +195,48 @@ namespace sf {
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
-(BOOL)hasFocus;
|
-(BOOL)hasFocus;
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Minimize the window
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
-(void)minimize;
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Unminimize the window
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
-(void)unminimize;
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Maximize or unmaximizes the window
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
-(void)toogleMaximize;
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Check whether the window is minimized
|
||||||
|
///
|
||||||
|
/// \return True if window is minimized, false otherwise
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
-(BOOL)isMinimized;
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Check whether the window is maximized
|
||||||
|
///
|
||||||
|
/// \return True if window is maximized, false otherwise
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
-(BOOL)isMaximized;
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Check whether the window is fullscreen
|
||||||
|
///
|
||||||
|
/// \return True if window is fullscreen, false otherwise
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
-(BOOL)isFullscreen;
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
/// \brief Enable key repeat
|
/// \brief Enable key repeat
|
||||||
///
|
///
|
||||||
|
|
|
@ -123,6 +123,28 @@ namespace
|
||||||
FreeLibrary(user32Dll);
|
FreeLibrary(user32Dll);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DWORD translateStyle(sf::Uint32 style)
|
||||||
|
{
|
||||||
|
// Choose the window style according to the Style parameter
|
||||||
|
DWORD win32Style = 0;
|
||||||
|
if (style == sf::Style::None)
|
||||||
|
{
|
||||||
|
win32Style |= WS_POPUP;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (style & sf::Style::Titlebar) win32Style |= WS_CAPTION | WS_MINIMIZEBOX;
|
||||||
|
if (style & sf::Style::Resize) win32Style |= WS_THICKFRAME | WS_MAXIMIZEBOX;
|
||||||
|
if (style & sf::Style::Close) win32Style |= WS_SYSMENU;
|
||||||
|
}
|
||||||
|
if (!(style & sf::Style::Hidden))
|
||||||
|
{
|
||||||
|
win32Style |= WS_VISIBLE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return win32Style;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace sf
|
namespace sf
|
||||||
|
@ -141,8 +163,9 @@ m_lastSize (0, 0),
|
||||||
m_resizing (false),
|
m_resizing (false),
|
||||||
m_surrogate (0),
|
m_surrogate (0),
|
||||||
m_mouseInside (false),
|
m_mouseInside (false),
|
||||||
m_fullscreen (false),
|
m_cursorGrabbed (false),
|
||||||
m_cursorGrabbed (false)
|
m_win32Style (translateStyle(Style::None)),
|
||||||
|
m_mode (VideoMode::getDesktopMode())
|
||||||
{
|
{
|
||||||
// Set that this process is DPI aware and can handle DPI scaling
|
// Set that this process is DPI aware and can handle DPI scaling
|
||||||
setProcessDpiAware();
|
setProcessDpiAware();
|
||||||
|
@ -174,8 +197,9 @@ m_lastSize (mode.width, mode.height),
|
||||||
m_resizing (false),
|
m_resizing (false),
|
||||||
m_surrogate (0),
|
m_surrogate (0),
|
||||||
m_mouseInside (false),
|
m_mouseInside (false),
|
||||||
m_fullscreen ((style & Style::Fullscreen) != 0),
|
m_cursorGrabbed ((style & Style::Fullscreen) != 0),
|
||||||
m_cursorGrabbed (m_fullscreen)
|
m_win32Style (translateStyle(style)),
|
||||||
|
m_mode (mode)
|
||||||
{
|
{
|
||||||
// Set that this process is DPI aware and can handle DPI scaling
|
// Set that this process is DPI aware and can handle DPI scaling
|
||||||
setProcessDpiAware();
|
setProcessDpiAware();
|
||||||
|
@ -192,30 +216,17 @@ m_cursorGrabbed (m_fullscreen)
|
||||||
int height = mode.height;
|
int height = mode.height;
|
||||||
ReleaseDC(NULL, screenDC);
|
ReleaseDC(NULL, screenDC);
|
||||||
|
|
||||||
// Choose the window style according to the Style parameter
|
|
||||||
DWORD win32Style = WS_VISIBLE;
|
|
||||||
if (style == Style::None)
|
|
||||||
{
|
|
||||||
win32Style |= WS_POPUP;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (style & Style::Titlebar) win32Style |= WS_CAPTION | WS_MINIMIZEBOX;
|
|
||||||
if (style & Style::Resize) win32Style |= WS_THICKFRAME | WS_MAXIMIZEBOX;
|
|
||||||
if (style & Style::Close) win32Style |= WS_SYSMENU;
|
|
||||||
}
|
|
||||||
|
|
||||||
// In windowed mode, adjust width and height so that window will have the requested client area
|
// In windowed mode, adjust width and height so that window will have the requested client area
|
||||||
if (!m_fullscreen)
|
if (!(style & Style::Fullscreen))
|
||||||
{
|
{
|
||||||
RECT rectangle = {0, 0, width, height};
|
RECT rectangle = {0, 0, width, height};
|
||||||
AdjustWindowRect(&rectangle, win32Style, false);
|
AdjustWindowRect(&rectangle, m_win32Style, false);
|
||||||
width = rectangle.right - rectangle.left;
|
width = rectangle.right - rectangle.left;
|
||||||
height = rectangle.bottom - rectangle.top;
|
height = rectangle.bottom - rectangle.top;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create the window
|
// Create the window
|
||||||
m_handle = CreateWindowW(className, title.toWideString().c_str(), win32Style, left, top, width, height, NULL, NULL, GetModuleHandle(NULL), this);
|
m_handle = CreateWindowW(className, title.toWideString().c_str(), m_win32Style, left, top, width, height, NULL, NULL, GetModuleHandle(NULL), this);
|
||||||
|
|
||||||
// Register to receive device interface change notifications (used for joystick connection handling)
|
// Register to receive device interface change notifications (used for joystick connection handling)
|
||||||
DEV_BROADCAST_DEVICEINTERFACE deviceInterface = {sizeof(DEV_BROADCAST_DEVICEINTERFACE), DBT_DEVTYP_DEVICEINTERFACE, 0, GUID_DEVINTERFACE_HID, 0};
|
DEV_BROADCAST_DEVICEINTERFACE deviceInterface = {sizeof(DEV_BROADCAST_DEVICEINTERFACE), DBT_DEVTYP_DEVICEINTERFACE, 0, GUID_DEVINTERFACE_HID, 0};
|
||||||
|
@ -230,13 +241,13 @@ m_cursorGrabbed (m_fullscreen)
|
||||||
++handleCount;
|
++handleCount;
|
||||||
}
|
}
|
||||||
|
|
||||||
// By default, the OS limits the size of the window the the desktop size,
|
// By default, the OS limits the size of the window to the desktop size,
|
||||||
// we have to resize it after creation to apply the real size
|
// we have to resize it after creation to apply the real size
|
||||||
setSize(Vector2u(mode.width, mode.height));
|
setSize(Vector2u(mode.width, mode.height));
|
||||||
|
|
||||||
// Switch to fullscreen if requested
|
// Switch to fullscreen if requested
|
||||||
if (m_fullscreen)
|
if (style & Style::Fullscreen)
|
||||||
switchToFullscreen(mode);
|
switchToFullscreen();
|
||||||
|
|
||||||
// Increment window count
|
// Increment window count
|
||||||
windowCount++;
|
windowCount++;
|
||||||
|
@ -467,6 +478,51 @@ bool WindowImplWin32::hasFocus() const
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
void WindowImplWin32::setState(State state)
|
||||||
|
{
|
||||||
|
State currentState = getState();
|
||||||
|
|
||||||
|
switch (state)
|
||||||
|
{
|
||||||
|
case State::Windowed:
|
||||||
|
if (currentState == State::Fullscreen)
|
||||||
|
switchToWindowed();
|
||||||
|
else
|
||||||
|
ShowWindow(m_handle, SW_RESTORE);
|
||||||
|
break;
|
||||||
|
case State::Minimized:
|
||||||
|
ShowWindow(m_handle, SW_MINIMIZE);
|
||||||
|
break;
|
||||||
|
case State::Maximized:
|
||||||
|
ShowWindow(m_handle, SW_MAXIMIZE);
|
||||||
|
break;
|
||||||
|
case State::Fullscreen:
|
||||||
|
if (currentState != State::Fullscreen)
|
||||||
|
switchToFullscreen();
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
State WindowImplWin32::getState() const
|
||||||
|
{
|
||||||
|
WINDOWPLACEMENT currentState;
|
||||||
|
currentState.length = sizeof(WINDOWPLACEMENT);
|
||||||
|
GetWindowPlacement(m_handle, ¤tState);
|
||||||
|
|
||||||
|
if ((currentState.showCmd == SW_MINIMIZE) || (currentState.showCmd == SW_SHOWMINIMIZED))
|
||||||
|
return State::Minimized;
|
||||||
|
if ((currentState.showCmd == SW_MAXIMIZE) || (currentState.showCmd == SW_SHOWMAXIMIZED))
|
||||||
|
return State::Maximized;
|
||||||
|
if (fullscreenWindow == this)
|
||||||
|
return State::Fullscreen;
|
||||||
|
|
||||||
|
return State::Windowed;
|
||||||
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void WindowImplWin32::registerWindowClass()
|
void WindowImplWin32::registerWindowClass()
|
||||||
{
|
{
|
||||||
|
@ -486,13 +542,13 @@ void WindowImplWin32::registerWindowClass()
|
||||||
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void WindowImplWin32::switchToFullscreen(const VideoMode& mode)
|
void WindowImplWin32::switchToFullscreen()
|
||||||
{
|
{
|
||||||
DEVMODE devMode;
|
DEVMODE devMode;
|
||||||
devMode.dmSize = sizeof(devMode);
|
devMode.dmSize = sizeof(devMode);
|
||||||
devMode.dmPelsWidth = mode.width;
|
devMode.dmPelsWidth = m_mode.width;
|
||||||
devMode.dmPelsHeight = mode.height;
|
devMode.dmPelsHeight = m_mode.height;
|
||||||
devMode.dmBitsPerPel = mode.bitsPerPixel;
|
devMode.dmBitsPerPel = m_mode.bitsPerPixel;
|
||||||
devMode.dmFields = DM_PELSWIDTH | DM_PELSHEIGHT | DM_BITSPERPEL;
|
devMode.dmFields = DM_PELSWIDTH | DM_PELSHEIGHT | DM_BITSPERPEL;
|
||||||
|
|
||||||
// Apply fullscreen mode
|
// Apply fullscreen mode
|
||||||
|
@ -507,7 +563,7 @@ void WindowImplWin32::switchToFullscreen(const VideoMode& mode)
|
||||||
SetWindowLongW(m_handle, GWL_EXSTYLE, WS_EX_APPWINDOW);
|
SetWindowLongW(m_handle, GWL_EXSTYLE, WS_EX_APPWINDOW);
|
||||||
|
|
||||||
// Resize the window so that it fits the entire screen
|
// Resize the window so that it fits the entire screen
|
||||||
SetWindowPos(m_handle, HWND_TOP, 0, 0, mode.width, mode.height, SWP_FRAMECHANGED);
|
SetWindowPos(m_handle, HWND_TOP, 0, 0, m_mode.width, m_mode.height, SWP_FRAMECHANGED);
|
||||||
ShowWindow(m_handle, SW_SHOW);
|
ShowWindow(m_handle, SW_SHOW);
|
||||||
|
|
||||||
// Set "this" as the current fullscreen window
|
// Set "this" as the current fullscreen window
|
||||||
|
@ -515,6 +571,32 @@ void WindowImplWin32::switchToFullscreen(const VideoMode& mode)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
void WindowImplWin32::switchToWindowed()
|
||||||
|
{
|
||||||
|
// Restore the graphics mode of the display device back to the values from the registry
|
||||||
|
ChangeDisplaySettings(NULL, 0);
|
||||||
|
|
||||||
|
// Set the window flags to what the user requested before switching to fullscreen
|
||||||
|
SetWindowLongW(m_handle, GWL_STYLE, m_win32Style);
|
||||||
|
|
||||||
|
// Compute position and size
|
||||||
|
HDC screenDC = GetDC(NULL);
|
||||||
|
int left = (GetDeviceCaps(screenDC, HORZRES) - static_cast<int>(m_mode.width)) / 2;
|
||||||
|
int top = (GetDeviceCaps(screenDC, VERTRES) - static_cast<int>(m_mode.height)) / 2;
|
||||||
|
ReleaseDC(NULL, screenDC);
|
||||||
|
|
||||||
|
RECT rectangle = {0, 0, static_cast<LONG>(m_mode.width), static_cast<LONG>(m_mode.height)};
|
||||||
|
AdjustWindowRect(&rectangle, m_win32Style, false);
|
||||||
|
int width = rectangle.right - rectangle.left;
|
||||||
|
int height = rectangle.bottom - rectangle.top;
|
||||||
|
|
||||||
|
SetWindowPos(m_handle, HWND_TOP, left, top, width, height, SWP_FRAMECHANGED);
|
||||||
|
|
||||||
|
fullscreenWindow = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void WindowImplWin32::cleanup()
|
void WindowImplWin32::cleanup()
|
||||||
{
|
{
|
||||||
|
|
|
@ -184,6 +184,22 @@ public:
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
virtual bool hasFocus() const;
|
virtual bool hasFocus() const;
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Set the window state
|
||||||
|
///
|
||||||
|
/// \param state The new state
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
virtual void setState(State state);
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Get the window state
|
||||||
|
///
|
||||||
|
/// \return The window state
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
virtual State getState() const;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
|
@ -201,12 +217,16 @@ private:
|
||||||
void registerWindowClass();
|
void registerWindowClass();
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
/// \brief Switch to fullscreen mode
|
/// \brief Switch to fullscreen state
|
||||||
///
|
|
||||||
/// \param mode Video mode to switch to
|
|
||||||
///
|
///
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void switchToFullscreen(const VideoMode& mode);
|
void switchToFullscreen();
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Switch to windowed state
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
void switchToWindowed();
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
/// \brief Free all the graphical resources attached to the window
|
/// \brief Free all the graphical resources attached to the window
|
||||||
|
@ -282,8 +302,10 @@ private:
|
||||||
bool m_resizing; ///< Is the window being resized?
|
bool m_resizing; ///< Is the window being resized?
|
||||||
Uint16 m_surrogate; ///< First half of the surrogate pair, in case we're receiving a Unicode character in two events
|
Uint16 m_surrogate; ///< First half of the surrogate pair, in case we're receiving a Unicode character in two events
|
||||||
bool m_mouseInside; ///< Mouse is inside the window?
|
bool m_mouseInside; ///< Mouse is inside the window?
|
||||||
bool m_fullscreen; ///< Is the window fullscreen?
|
|
||||||
bool m_cursorGrabbed; ///< Is the mouse cursor trapped?
|
bool m_cursorGrabbed; ///< Is the mouse cursor trapped?
|
||||||
|
|
||||||
|
const DWORD m_win32Style; ///< Window style in the windows format
|
||||||
|
const VideoMode m_mode; ///< Video mode of the window
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace priv
|
} // namespace priv
|
||||||
|
|
|
@ -31,6 +31,8 @@
|
||||||
#include <SFML/System/Sleep.hpp>
|
#include <SFML/System/Sleep.hpp>
|
||||||
#include <SFML/System/Err.hpp>
|
#include <SFML/System/Err.hpp>
|
||||||
|
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
|
||||||
namespace
|
namespace
|
||||||
{
|
{
|
||||||
|
@ -127,7 +129,7 @@ void Window::create(VideoMode mode, const String& title, Uint32 style, const Con
|
||||||
m_context = priv::GlContext::create(settings, m_impl, mode.bitsPerPixel);
|
m_context = priv::GlContext::create(settings, m_impl, mode.bitsPerPixel);
|
||||||
|
|
||||||
// Perform common initializations
|
// Perform common initializations
|
||||||
initialize();
|
initialize(style);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -144,7 +146,7 @@ void Window::create(WindowHandle handle, const ContextSettings& settings)
|
||||||
m_context = priv::GlContext::create(settings, m_impl, VideoMode::getDesktopMode().bitsPerPixel);
|
m_context = priv::GlContext::create(settings, m_impl, VideoMode::getDesktopMode().bitsPerPixel);
|
||||||
|
|
||||||
// Perform common initializations
|
// Perform common initializations
|
||||||
initialize();
|
initialize(sf::Style::Default);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -368,7 +370,42 @@ bool Window::hasFocus() const
|
||||||
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
|
void Window::setState(State state)
|
||||||
|
{
|
||||||
|
if (m_impl)
|
||||||
|
{
|
||||||
|
// TODO: this if never evaluates to true, even if state IS State::Windowed
|
||||||
|
// I can't figure out why. This is ehy you can only switch to fullscreen once
|
||||||
|
if (state == State::Windowed)
|
||||||
|
{
|
||||||
|
if (this == fullscreenWindow)
|
||||||
|
fullscreenWindow = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (state == State::Fullscreen)
|
||||||
|
if (fullscreenWindow != NULL)
|
||||||
|
{
|
||||||
|
err() << "Creating more than one fullscreen window is not allowed" << std::endl;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
fullscreenWindow = this;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_impl->setState(state);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
State Window::getState() const
|
||||||
|
{
|
||||||
|
return m_impl ? m_impl->getState() : State::Windowed;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
void Window::display()
|
void Window::display()
|
||||||
{
|
{
|
||||||
// Display the backbuffer on screen
|
// Display the backbuffer on screen
|
||||||
|
@ -424,15 +461,16 @@ bool Window::filterEvent(const Event& event)
|
||||||
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void Window::initialize()
|
void Window::initialize(Uint32 style)
|
||||||
{
|
{
|
||||||
// Setup default behaviors (to get a consistent behavior across different implementations)
|
// Setup default behaviors (to get a consistent behavior across different implementations)
|
||||||
setVisible(true);
|
|
||||||
setMouseCursorVisible(true);
|
|
||||||
setVerticalSyncEnabled(false);
|
setVerticalSyncEnabled(false);
|
||||||
setKeyRepeatEnabled(true);
|
setKeyRepeatEnabled(true);
|
||||||
setFramerateLimit(0);
|
setFramerateLimit(0);
|
||||||
|
|
||||||
|
if (!(style & Style::Hidden))
|
||||||
|
setVisible(true);
|
||||||
|
|
||||||
// Get and cache the initial size of the window
|
// Get and cache the initial size of the window
|
||||||
m_size = m_impl->getSize();
|
m_size = m_impl->getSize();
|
||||||
|
|
||||||
|
|
|
@ -39,8 +39,9 @@
|
||||||
#include <SFML/Window/Sensor.hpp>
|
#include <SFML/Window/Sensor.hpp>
|
||||||
#include <SFML/Window/SensorImpl.hpp>
|
#include <SFML/Window/SensorImpl.hpp>
|
||||||
#include <SFML/Window/VideoMode.hpp>
|
#include <SFML/Window/VideoMode.hpp>
|
||||||
#include <SFML/Window/WindowHandle.hpp>
|
|
||||||
#include <SFML/Window/Window.hpp>
|
#include <SFML/Window/Window.hpp>
|
||||||
|
#include <SFML/Window/WindowHandle.hpp>
|
||||||
|
#include <SFML/Window/WindowState.hpp>
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include <set>
|
#include <set>
|
||||||
|
|
||||||
|
@ -227,6 +228,22 @@ public:
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
virtual bool hasFocus() const = 0;
|
virtual bool hasFocus() const = 0;
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Set the window state
|
||||||
|
///
|
||||||
|
/// \param state The new state
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
virtual void setState(State state) = 0;
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Get the window state
|
||||||
|
///
|
||||||
|
/// \return The window state
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
virtual State getState() const = 0;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
|
|
Loading…
Reference in a new issue