mirror of
https://github.com/SFML/SFML.git
synced 2025-01-19 15:55:13 +08:00
[Win32] Fixed Unicode inconsistency
For Unicode builds this change is more cosmetic, but it should fix SFML's window class being registered as "S" rather than "SFML_Window" for non-Unicode builds.
This commit is contained in:
parent
5b559f1c08
commit
121c3b2fd7
@ -78,8 +78,8 @@ m_mouseInside (false)
|
|||||||
if (m_handle)
|
if (m_handle)
|
||||||
{
|
{
|
||||||
// We change the event procedure of the control (it is important to save the old one)
|
// We change the event procedure of the control (it is important to save the old one)
|
||||||
SetWindowLongPtr(m_handle, GWLP_USERDATA, reinterpret_cast<LONG_PTR>(this));
|
SetWindowLongPtrW(m_handle, GWLP_USERDATA, reinterpret_cast<LONG_PTR>(this));
|
||||||
m_callback = SetWindowLongPtr(m_handle, GWLP_WNDPROC, reinterpret_cast<LONG_PTR>(&WindowImplWin32::globalOnEvent));
|
m_callback = SetWindowLongPtrW(m_handle, GWLP_WNDPROC, reinterpret_cast<LONG_PTR>(&WindowImplWin32::globalOnEvent));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -132,7 +132,7 @@ m_mouseInside (false)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Create the window
|
// Create the window
|
||||||
m_handle = CreateWindow(className, title.toWideString().c_str(), win32Style, left, top, width, height, NULL, NULL, GetModuleHandle(NULL), this);
|
m_handle = CreateWindowW(className, title.toWideString().c_str(), win32Style, left, top, width, height, NULL, NULL, GetModuleHandle(NULL), this);
|
||||||
|
|
||||||
// By default, the OS limits the size of the window the the desktop size,
|
// By default, the OS limits the size of the window the 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
|
||||||
@ -165,12 +165,12 @@ WindowImplWin32::~WindowImplWin32()
|
|||||||
|
|
||||||
// Unregister window class if we were the last window
|
// Unregister window class if we were the last window
|
||||||
if (windowCount == 0)
|
if (windowCount == 0)
|
||||||
UnregisterClass(className, GetModuleHandle(NULL));
|
UnregisterClassW(className, GetModuleHandleW(NULL));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// The window is external : remove the hook on its message callback
|
// The window is external : remove the hook on its message callback
|
||||||
SetWindowLongPtr(m_handle, GWLP_WNDPROC, m_callback);
|
SetWindowLongPtrW(m_handle, GWLP_WNDPROC, m_callback);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -189,10 +189,10 @@ void WindowImplWin32::processEvents()
|
|||||||
if (!m_callback)
|
if (!m_callback)
|
||||||
{
|
{
|
||||||
MSG message;
|
MSG message;
|
||||||
while (PeekMessage(&message, NULL, 0, 0, PM_REMOVE))
|
while (PeekMessageW(&message, NULL, 0, 0, PM_REMOVE))
|
||||||
{
|
{
|
||||||
TranslateMessage(&message);
|
TranslateMessage(&message);
|
||||||
DispatchMessage(&message);
|
DispatchMessageW(&message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -242,7 +242,7 @@ void WindowImplWin32::setSize(const Vector2u& size)
|
|||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void WindowImplWin32::setTitle(const String& title)
|
void WindowImplWin32::setTitle(const String& title)
|
||||||
{
|
{
|
||||||
SetWindowText(m_handle, title.toWideString().c_str());
|
SetWindowTextW(m_handle, title.toWideString().c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -264,13 +264,13 @@ void WindowImplWin32::setIcon(unsigned int width, unsigned int height, const Uin
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Create the icon from the pixel array
|
// Create the icon from the pixel array
|
||||||
m_icon = CreateIcon(GetModuleHandle(NULL), width, height, 1, 32, NULL, &iconPixels[0]);
|
m_icon = CreateIcon(GetModuleHandleW(NULL), width, height, 1, 32, NULL, &iconPixels[0]);
|
||||||
|
|
||||||
// Set it as both big and small icon of the window
|
// Set it as both big and small icon of the window
|
||||||
if (m_icon)
|
if (m_icon)
|
||||||
{
|
{
|
||||||
SendMessage(m_handle, WM_SETICON, ICON_BIG, (LPARAM)m_icon);
|
SendMessageW(m_handle, WM_SETICON, ICON_BIG, (LPARAM)m_icon);
|
||||||
SendMessage(m_handle, WM_SETICON, ICON_SMALL, (LPARAM)m_icon);
|
SendMessageW(m_handle, WM_SETICON, ICON_SMALL, (LPARAM)m_icon);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -290,7 +290,7 @@ void WindowImplWin32::setVisible(bool visible)
|
|||||||
void WindowImplWin32::setMouseCursorVisible(bool visible)
|
void WindowImplWin32::setMouseCursorVisible(bool visible)
|
||||||
{
|
{
|
||||||
if (visible)
|
if (visible)
|
||||||
m_cursor = LoadCursor(NULL, IDC_ARROW);
|
m_cursor = LoadCursorW(NULL, IDC_ARROW);
|
||||||
else
|
else
|
||||||
m_cursor = NULL;
|
m_cursor = NULL;
|
||||||
|
|
||||||
@ -313,13 +313,13 @@ void WindowImplWin32::registerWindowClass()
|
|||||||
windowClass.lpfnWndProc = &WindowImplWin32::globalOnEvent;
|
windowClass.lpfnWndProc = &WindowImplWin32::globalOnEvent;
|
||||||
windowClass.cbClsExtra = 0;
|
windowClass.cbClsExtra = 0;
|
||||||
windowClass.cbWndExtra = 0;
|
windowClass.cbWndExtra = 0;
|
||||||
windowClass.hInstance = GetModuleHandle(NULL);
|
windowClass.hInstance = GetModuleHandleW(NULL);
|
||||||
windowClass.hIcon = NULL;
|
windowClass.hIcon = NULL;
|
||||||
windowClass.hCursor = 0;
|
windowClass.hCursor = 0;
|
||||||
windowClass.hbrBackground = 0;
|
windowClass.hbrBackground = 0;
|
||||||
windowClass.lpszMenuName = NULL;
|
windowClass.lpszMenuName = NULL;
|
||||||
windowClass.lpszClassName = className;
|
windowClass.lpszClassName = className;
|
||||||
RegisterClass(&windowClass);
|
RegisterClassW(&windowClass);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -334,15 +334,15 @@ void WindowImplWin32::switchToFullscreen(const VideoMode& mode)
|
|||||||
devMode.dmFields = DM_PELSWIDTH | DM_PELSHEIGHT | DM_BITSPERPEL;
|
devMode.dmFields = DM_PELSWIDTH | DM_PELSHEIGHT | DM_BITSPERPEL;
|
||||||
|
|
||||||
// Apply fullscreen mode
|
// Apply fullscreen mode
|
||||||
if (ChangeDisplaySettings(&devMode, CDS_FULLSCREEN) != DISP_CHANGE_SUCCESSFUL)
|
if (ChangeDisplaySettingsW(&devMode, CDS_FULLSCREEN) != DISP_CHANGE_SUCCESSFUL)
|
||||||
{
|
{
|
||||||
err() << "Failed to change display mode for fullscreen" << std::endl;
|
err() << "Failed to change display mode for fullscreen" << std::endl;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make the window flags compatible with fullscreen mode
|
// Make the window flags compatible with fullscreen mode
|
||||||
SetWindowLong(m_handle, GWL_STYLE, WS_POPUP | WS_CLIPCHILDREN | WS_CLIPSIBLINGS);
|
SetWindowLongW(m_handle, GWL_STYLE, WS_POPUP | WS_CLIPCHILDREN | WS_CLIPSIBLINGS);
|
||||||
SetWindowLong(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, mode.width, mode.height, SWP_FRAMECHANGED);
|
||||||
@ -359,7 +359,7 @@ void WindowImplWin32::cleanup()
|
|||||||
// Restore the previous video mode (in case we were running in fullscreen)
|
// Restore the previous video mode (in case we were running in fullscreen)
|
||||||
if (fullscreenWindow == this)
|
if (fullscreenWindow == this)
|
||||||
{
|
{
|
||||||
ChangeDisplaySettings(NULL, 0);
|
ChangeDisplaySettingsW(NULL, 0);
|
||||||
fullscreenWindow = NULL;
|
fullscreenWindow = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -774,7 +774,7 @@ Keyboard::Key WindowImplWin32::virtualKeyCodeToSF(WPARAM key, LPARAM flags)
|
|||||||
// Check the scancode to distinguish between left and right shift
|
// Check the scancode to distinguish between left and right shift
|
||||||
case VK_SHIFT :
|
case VK_SHIFT :
|
||||||
{
|
{
|
||||||
static UINT lShift = MapVirtualKey(VK_LSHIFT, MAPVK_VK_TO_VSC);
|
static UINT lShift = MapVirtualKeyW(VK_LSHIFT, MAPVK_VK_TO_VSC);
|
||||||
UINT scancode = static_cast<UINT>((flags & (0xFF << 16)) >> 16);
|
UINT scancode = static_cast<UINT>((flags & (0xFF << 16)) >> 16);
|
||||||
return scancode == lShift ? Keyboard::LShift : Keyboard::RShift;
|
return scancode == lShift ? Keyboard::LShift : Keyboard::RShift;
|
||||||
}
|
}
|
||||||
@ -897,7 +897,7 @@ LRESULT CALLBACK WindowImplWin32::globalOnEvent(HWND handle, UINT message, WPARA
|
|||||||
LONG_PTR window = (LONG_PTR)reinterpret_cast<CREATESTRUCT*>(lParam)->lpCreateParams;
|
LONG_PTR window = (LONG_PTR)reinterpret_cast<CREATESTRUCT*>(lParam)->lpCreateParams;
|
||||||
|
|
||||||
// Set as the "user data" parameter of the window
|
// Set as the "user data" parameter of the window
|
||||||
SetWindowLongPtr(handle, GWLP_USERDATA, window);
|
SetWindowLongPtrW(handle, GWLP_USERDATA, window);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get the WindowImpl instance corresponding to the window handle
|
// Get the WindowImpl instance corresponding to the window handle
|
||||||
@ -909,7 +909,7 @@ LRESULT CALLBACK WindowImplWin32::globalOnEvent(HWND handle, UINT message, WPARA
|
|||||||
window->processEvent(message, wParam, lParam);
|
window->processEvent(message, wParam, lParam);
|
||||||
|
|
||||||
if (window->m_callback)
|
if (window->m_callback)
|
||||||
return CallWindowProc(reinterpret_cast<WNDPROC>(window->m_callback), handle, message, wParam, lParam);
|
return CallWindowProcW(reinterpret_cast<WNDPROC>(window->m_callback), handle, message, wParam, lParam);
|
||||||
}
|
}
|
||||||
|
|
||||||
// We don't forward the WM_CLOSE message to prevent the OS from automatically destroying the window
|
// We don't forward the WM_CLOSE message to prevent the OS from automatically destroying the window
|
||||||
@ -920,7 +920,7 @@ LRESULT CALLBACK WindowImplWin32::globalOnEvent(HWND handle, UINT message, WPARA
|
|||||||
if ((message == WM_SYSCOMMAND) && (wParam == SC_KEYMENU))
|
if ((message == WM_SYSCOMMAND) && (wParam == SC_KEYMENU))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
return DefWindowProc(handle, message, wParam, lParam);
|
return DefWindowProcW(handle, message, wParam, lParam);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace priv
|
} // namespace priv
|
||||||
|
Loading…
Reference in New Issue
Block a user