mirror of
https://github.com/Relintai/sdl2_frt.git
synced 2025-01-17 14:47:19 +01:00
WinRT: more "Windows RT" to "WinRT" renaming
This commit is contained in:
parent
3070086431
commit
1e78c4a5d1
@ -40,7 +40,7 @@
|
|||||||
#define SDL_MAIN_AVAILABLE
|
#define SDL_MAIN_AVAILABLE
|
||||||
|
|
||||||
#elif defined(__WINRT__)
|
#elif defined(__WINRT__)
|
||||||
/* On Windows RT, SDL provides a main function that initializes CoreApplication,
|
/* On WinRT, SDL provides a main function that initializes CoreApplication,
|
||||||
creating an instance of IFrameworkView in the process.
|
creating an instance of IFrameworkView in the process.
|
||||||
|
|
||||||
Please note that #include'ing SDL_main.h is not enough to get a main()
|
Please note that #include'ing SDL_main.h is not enough to get a main()
|
||||||
|
@ -73,7 +73,7 @@
|
|||||||
#ifdef HAVE_MATH_H
|
#ifdef HAVE_MATH_H
|
||||||
# if defined(__WINRT__)
|
# if defined(__WINRT__)
|
||||||
/* Defining _USE_MATH_DEFINES is required to get M_PI to be defined on
|
/* Defining _USE_MATH_DEFINES is required to get M_PI to be defined on
|
||||||
Windows RT. See http://msdn.microsoft.com/en-us/library/4hwaceh6.aspx
|
WinRT. See http://msdn.microsoft.com/en-us/library/4hwaceh6.aspx
|
||||||
for more information.
|
for more information.
|
||||||
*/
|
*/
|
||||||
# define _USE_MATH_DEFINES
|
# define _USE_MATH_DEFINES
|
||||||
|
@ -94,11 +94,11 @@ extern DECLSPEC const char * SDLCALL SDL_AndroidGetExternalStoragePath();
|
|||||||
#endif /* __ANDROID__ */
|
#endif /* __ANDROID__ */
|
||||||
|
|
||||||
|
|
||||||
/* Platform specific functions for Windows RT */
|
/* Platform specific functions for WinRT */
|
||||||
#if defined(__WINRT__) && __WINRT__
|
#if defined(__WINRT__) && __WINRT__
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Windows RT / Windows Phone path types
|
* \brief WinRT / Windows Phone path types
|
||||||
*/
|
*/
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
@ -122,9 +122,9 @@ typedef enum
|
|||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Retrieves a Windows RT defined path on the local file system
|
* \brief Retrieves a WinRT defined path on the local file system
|
||||||
*
|
*
|
||||||
* \note Documentation on most app-specific path types on Windows RT
|
* \note Documentation on most app-specific path types on WinRT
|
||||||
* can be found on MSDN, at the URL:
|
* can be found on MSDN, at the URL:
|
||||||
* http://msdn.microsoft.com/en-us/library/windows/apps/hh464917.aspx
|
* http://msdn.microsoft.com/en-us/library/windows/apps/hh464917.aspx
|
||||||
*
|
*
|
||||||
@ -139,9 +139,9 @@ typedef enum
|
|||||||
extern DECLSPEC const wchar_t * SDLCALL SDL_WinRTGetFSPathUNICODE(SDL_WinRT_Path pathType);
|
extern DECLSPEC const wchar_t * SDLCALL SDL_WinRTGetFSPathUNICODE(SDL_WinRT_Path pathType);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Retrieves a Windows RT defined path on the local file system
|
* \brief Retrieves a WinRT defined path on the local file system
|
||||||
*
|
*
|
||||||
* \note Documentation on most app-specific path types on Windows RT
|
* \note Documentation on most app-specific path types on WinRT
|
||||||
* can be found on MSDN, at the URL:
|
* can be found on MSDN, at the URL:
|
||||||
* http://msdn.microsoft.com/en-us/library/windows/apps/hh464917.aspx
|
* http://msdn.microsoft.com/en-us/library/windows/apps/hh464917.aspx
|
||||||
*
|
*
|
||||||
|
@ -177,7 +177,7 @@ struct SDL_SysWMinfo
|
|||||||
#if defined(SDL_VIDEO_DRIVER_WINRT)
|
#if defined(SDL_VIDEO_DRIVER_WINRT)
|
||||||
struct
|
struct
|
||||||
{
|
{
|
||||||
IUnknown * window; /**< The Windows RT CoreWindow */
|
IUnknown * window; /**< The WinRT CoreWindow */
|
||||||
} winrt;
|
} winrt;
|
||||||
#endif
|
#endif
|
||||||
#if defined(SDL_VIDEO_DRIVER_X11)
|
#if defined(SDL_VIDEO_DRIVER_X11)
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
/* WinRT NOTICE:
|
/* WinRT NOTICE:
|
||||||
|
|
||||||
A number of changes were warranted to SDL's XAudio2 backend in order to
|
A number of changes were warranted to SDL's XAudio2 backend in order to
|
||||||
get it compiling for Windows RT.
|
get it compiling for WinRT.
|
||||||
|
|
||||||
When compiling for WinRT, XAudio2.h requires that it be compiled in a C++
|
When compiling for WinRT, XAudio2.h requires that it be compiled in a C++
|
||||||
file, and not a straight C file. Trying to compile it as C leads to lots
|
file, and not a straight C file. Trying to compile it as C leads to lots
|
||||||
@ -57,13 +57,13 @@
|
|||||||
http://blogs.msdn.com/b/chuckw/archive/2012/04/02/xaudio2-and-windows-8-consumer-preview.aspx
|
http://blogs.msdn.com/b/chuckw/archive/2012/04/02/xaudio2-and-windows-8-consumer-preview.aspx
|
||||||
|
|
||||||
1. Windows' thread synchronization function, CreateSemaphore, was removed
|
1. Windows' thread synchronization function, CreateSemaphore, was removed
|
||||||
from Windows RT. SDL's semaphore API was substituted instead.
|
from WinRT. SDL's semaphore API was substituted instead.
|
||||||
2. The method calls, IXAudio2::GetDeviceCount and IXAudio2::GetDeviceDetails
|
2. The method calls, IXAudio2::GetDeviceCount and IXAudio2::GetDeviceDetails
|
||||||
were removed from the XAudio2 API. Microsoft is telling developers to
|
were removed from the XAudio2 API. Microsoft is telling developers to
|
||||||
use APIs in Windows::Foundation instead.
|
use APIs in Windows::Foundation instead.
|
||||||
For SDL, the missing methods were reimplemented using the APIs Microsoft
|
For SDL, the missing methods were reimplemented using the APIs Microsoft
|
||||||
said to use.
|
said to use.
|
||||||
3. CoInitialize and CoUninitialize are not available in Windows RT.
|
3. CoInitialize and CoUninitialize are not available in WinRT.
|
||||||
These calls were removed, as COM will have been initialized earlier,
|
These calls were removed, as COM will have been initialized earlier,
|
||||||
at least by the call to the WinRT app's main function
|
at least by the call to the WinRT app's main function
|
||||||
(aka 'int main(Platform::Array<Platform::String^>^)). (DLudwig:
|
(aka 'int main(Platform::Array<Platform::String^>^)). (DLudwig:
|
||||||
@ -71,7 +71,7 @@
|
|||||||
a tag of [MTAThread], which should initialize COM. My understanding
|
a tag of [MTAThread], which should initialize COM. My understanding
|
||||||
of COM is somewhat limited, and I may be incorrect here.)
|
of COM is somewhat limited, and I may be incorrect here.)
|
||||||
4. IXAudio2::CreateMasteringVoice changed its integer-based 'DeviceIndex'
|
4. IXAudio2::CreateMasteringVoice changed its integer-based 'DeviceIndex'
|
||||||
argument to a string-based one, 'szDeviceId'. In Windows RT, the
|
argument to a string-based one, 'szDeviceId'. In WinRT, the
|
||||||
string-based argument will be used.
|
string-based argument will be used.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
//
|
//
|
||||||
// Re-implementation of methods removed from XAudio2 (in Windows RT):
|
// Re-implementation of methods removed from XAudio2 (in WinRT):
|
||||||
//
|
//
|
||||||
|
|
||||||
typedef struct XAUDIO2_DEVICE_DETAILS
|
typedef struct XAUDIO2_DEVICE_DETAILS
|
||||||
@ -22,19 +22,19 @@ HRESULT IXAudio2_GetDeviceDetails(IXAudio2 * unused, UINT32 index, XAUDIO2_DEVIC
|
|||||||
// C-style macros to call XAudio2's methods in C++:
|
// C-style macros to call XAudio2's methods in C++:
|
||||||
//
|
//
|
||||||
|
|
||||||
#define IXAudio2_CreateMasteringVoice(A, B, C, D, E, F, G) (A)->CreateMasteringVoice((B), (C), (D), (E), (F), (G))
|
#define IXAudio2_CreateMasteringVoice(A, B, C, D, E, F, G) (A)->CreateMasteringVoice((B), (C), (D), (E), (F), (G))
|
||||||
#define IXAudio2_CreateSourceVoice(A, B, C, D, E, F, G, H) (A)->CreateSourceVoice((B), (C), (D), (E), (F), (G), (H))
|
#define IXAudio2_CreateSourceVoice(A, B, C, D, E, F, G, H) (A)->CreateSourceVoice((B), (C), (D), (E), (F), (G), (H))
|
||||||
#define IXAudio2_QueryInterface(A, B, C) (A)->QueryInterface((B), (C))
|
#define IXAudio2_QueryInterface(A, B, C) (A)->QueryInterface((B), (C))
|
||||||
#define IXAudio2_Release(A) (A)->Release()
|
#define IXAudio2_Release(A) (A)->Release()
|
||||||
#define IXAudio2_StartEngine(A) (A)->StartEngine()
|
#define IXAudio2_StartEngine(A) (A)->StartEngine()
|
||||||
#define IXAudio2_StopEngine(A) (A)->StopEngine()
|
#define IXAudio2_StopEngine(A) (A)->StopEngine()
|
||||||
|
|
||||||
#define IXAudio2MasteringVoice_DestroyVoice(A) (A)->DestroyVoice()
|
#define IXAudio2MasteringVoice_DestroyVoice(A) (A)->DestroyVoice()
|
||||||
|
|
||||||
#define IXAudio2SourceVoice_DestroyVoice(A) (A)->DestroyVoice()
|
#define IXAudio2SourceVoice_DestroyVoice(A) (A)->DestroyVoice()
|
||||||
#define IXAudio2SourceVoice_Discontinuity(A) (A)->Discontinuity()
|
#define IXAudio2SourceVoice_Discontinuity(A) (A)->Discontinuity()
|
||||||
#define IXAudio2SourceVoice_FlushSourceBuffers(A) (A)->FlushSourceBuffers()
|
#define IXAudio2SourceVoice_FlushSourceBuffers(A) (A)->FlushSourceBuffers()
|
||||||
#define IXAudio2SourceVoice_GetState(A, B) (A)->GetState((B))
|
#define IXAudio2SourceVoice_GetState(A, B) (A)->GetState((B))
|
||||||
#define IXAudio2SourceVoice_Start(A, B, C) (A)->Start((B), (C))
|
#define IXAudio2SourceVoice_Start(A, B, C) (A)->Start((B), (C))
|
||||||
#define IXAudio2SourceVoice_Stop(A, B, C) (A)->Stop((B), (C))
|
#define IXAudio2SourceVoice_Stop(A, B, C) (A)->Stop((B), (C))
|
||||||
#define IXAudio2SourceVoice_SubmitSourceBuffer(A, B, C) (A)->SubmitSourceBuffer((B), (C))
|
#define IXAudio2SourceVoice_SubmitSourceBuffer(A, B, C) (A)->SubmitSourceBuffer((B), (C))
|
||||||
|
@ -56,7 +56,7 @@ extern SDL_VideoDevice * WINRT_GlobalSDLVideoDevice;
|
|||||||
typedef int (*SDL_WinRT_MainFunction)(int, char **);
|
typedef int (*SDL_WinRT_MainFunction)(int, char **);
|
||||||
static SDL_WinRT_MainFunction SDL_WinRT_main = nullptr;
|
static SDL_WinRT_MainFunction SDL_WinRT_main = nullptr;
|
||||||
|
|
||||||
// HACK, DLudwig: record a reference to the global, Windows RT 'app'/view.
|
// HACK, DLudwig: record a reference to the global, WinRT 'app'/view.
|
||||||
// SDL/WinRT will use this throughout its code.
|
// SDL/WinRT will use this throughout its code.
|
||||||
//
|
//
|
||||||
// TODO, WinRT: consider replacing SDL_WinRTGlobalApp with something
|
// TODO, WinRT: consider replacing SDL_WinRTGlobalApp with something
|
||||||
@ -129,7 +129,7 @@ static void WINRT_SetDisplayOrientationsPreference(void *userdata, const char *n
|
|||||||
|
|
||||||
// Set the orientation/rotation preferences. Please note that this does
|
// Set the orientation/rotation preferences. Please note that this does
|
||||||
// not constitute a 100%-certain lock of a given set of possible
|
// not constitute a 100%-certain lock of a given set of possible
|
||||||
// orientations. According to Microsoft's documentation on Windows RT [1]
|
// orientations. According to Microsoft's documentation on WinRT [1]
|
||||||
// when a device is not capable of being rotated, Windows may ignore
|
// when a device is not capable of being rotated, Windows may ignore
|
||||||
// the orientation preferences, and stick to what the device is capable of
|
// the orientation preferences, and stick to what the device is capable of
|
||||||
// displaying.
|
// displaying.
|
||||||
|
@ -1,159 +1,159 @@
|
|||||||
/*
|
/*
|
||||||
Simple DirectMedia Layer
|
Simple DirectMedia Layer
|
||||||
Copyright (C) 1997-2012 Sam Lantinga <slouken@libsdl.org>
|
Copyright (C) 1997-2012 Sam Lantinga <slouken@libsdl.org>
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied
|
This software is provided 'as-is', without any express or implied
|
||||||
warranty. In no event will the authors be held liable for any damages
|
warranty. In no event will the authors be held liable for any damages
|
||||||
arising from the use of this software.
|
arising from the use of this software.
|
||||||
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
Permission is granted to anyone to use this software for any purpose,
|
||||||
including commercial applications, and to alter it and redistribute it
|
including commercial applications, and to alter it and redistribute it
|
||||||
freely, subject to the following restrictions:
|
freely, subject to the following restrictions:
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not
|
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
|
claim that you wrote the original software. If you use this software
|
||||||
in a product, an acknowledgment in the product documentation would be
|
in a product, an acknowledgment in the product documentation would be
|
||||||
appreciated but is not required.
|
appreciated but is not required.
|
||||||
2. Altered source versions must be plainly marked as such, and must not be
|
2. Altered source versions must be plainly marked as such, and must not be
|
||||||
misrepresented as being the original software.
|
misrepresented as being the original software.
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
3. This notice may not be removed or altered from any source distribution.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "SDL_config.h"
|
#include "SDL_config.h"
|
||||||
|
|
||||||
#if SDL_VIDEO_DRIVER_WINRT
|
#if SDL_VIDEO_DRIVER_WINRT
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Windows includes:
|
* Windows includes:
|
||||||
*/
|
*/
|
||||||
#include <Windows.h>
|
#include <Windows.h>
|
||||||
using namespace Windows::UI::Core;
|
using namespace Windows::UI::Core;
|
||||||
using Windows::UI::Core::CoreCursor;
|
using Windows::UI::Core::CoreCursor;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* SDL includes:
|
* SDL includes:
|
||||||
*/
|
*/
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#include "SDL_assert.h"
|
#include "SDL_assert.h"
|
||||||
#include "../../events/SDL_mouse_c.h"
|
#include "../../events/SDL_mouse_c.h"
|
||||||
#include "../SDL_sysvideo.h"
|
#include "../SDL_sysvideo.h"
|
||||||
#include "SDL_events.h"
|
#include "SDL_events.h"
|
||||||
#include "SDL_log.h"
|
#include "SDL_log.h"
|
||||||
}
|
}
|
||||||
|
|
||||||
#include "../../core/winrt/SDL_winrtapp.h"
|
#include "../../core/winrt/SDL_winrtapp.h"
|
||||||
#include "SDL_winrtmouse.h"
|
#include "SDL_winrtmouse.h"
|
||||||
|
|
||||||
|
|
||||||
static SDL_bool WINRT_UseRelativeMouseMode = SDL_FALSE;
|
static SDL_bool WINRT_UseRelativeMouseMode = SDL_FALSE;
|
||||||
|
|
||||||
|
|
||||||
static SDL_Cursor *
|
static SDL_Cursor *
|
||||||
WINRT_CreateSystemCursor(SDL_SystemCursor id)
|
WINRT_CreateSystemCursor(SDL_SystemCursor id)
|
||||||
{
|
{
|
||||||
SDL_Cursor *cursor;
|
SDL_Cursor *cursor;
|
||||||
CoreCursorType cursorType = CoreCursorType::Arrow;
|
CoreCursorType cursorType = CoreCursorType::Arrow;
|
||||||
|
|
||||||
switch(id)
|
switch(id)
|
||||||
{
|
{
|
||||||
default:
|
default:
|
||||||
SDL_assert(0);
|
SDL_assert(0);
|
||||||
return NULL;
|
return NULL;
|
||||||
case SDL_SYSTEM_CURSOR_ARROW: cursorType = CoreCursorType::Arrow; break;
|
case SDL_SYSTEM_CURSOR_ARROW: cursorType = CoreCursorType::Arrow; break;
|
||||||
case SDL_SYSTEM_CURSOR_IBEAM: cursorType = CoreCursorType::IBeam; break;
|
case SDL_SYSTEM_CURSOR_IBEAM: cursorType = CoreCursorType::IBeam; break;
|
||||||
case SDL_SYSTEM_CURSOR_WAIT: cursorType = CoreCursorType::Wait; break;
|
case SDL_SYSTEM_CURSOR_WAIT: cursorType = CoreCursorType::Wait; break;
|
||||||
case SDL_SYSTEM_CURSOR_CROSSHAIR: cursorType = CoreCursorType::Cross; break;
|
case SDL_SYSTEM_CURSOR_CROSSHAIR: cursorType = CoreCursorType::Cross; break;
|
||||||
case SDL_SYSTEM_CURSOR_WAITARROW: cursorType = CoreCursorType::Wait; break;
|
case SDL_SYSTEM_CURSOR_WAITARROW: cursorType = CoreCursorType::Wait; break;
|
||||||
case SDL_SYSTEM_CURSOR_SIZENWSE: cursorType = CoreCursorType::SizeNorthwestSoutheast; break;
|
case SDL_SYSTEM_CURSOR_SIZENWSE: cursorType = CoreCursorType::SizeNorthwestSoutheast; break;
|
||||||
case SDL_SYSTEM_CURSOR_SIZENESW: cursorType = CoreCursorType::SizeNortheastSouthwest; break;
|
case SDL_SYSTEM_CURSOR_SIZENESW: cursorType = CoreCursorType::SizeNortheastSouthwest; break;
|
||||||
case SDL_SYSTEM_CURSOR_SIZEWE: cursorType = CoreCursorType::SizeWestEast; break;
|
case SDL_SYSTEM_CURSOR_SIZEWE: cursorType = CoreCursorType::SizeWestEast; break;
|
||||||
case SDL_SYSTEM_CURSOR_SIZENS: cursorType = CoreCursorType::SizeNorthSouth; break;
|
case SDL_SYSTEM_CURSOR_SIZENS: cursorType = CoreCursorType::SizeNorthSouth; break;
|
||||||
case SDL_SYSTEM_CURSOR_SIZEALL: cursorType = CoreCursorType::SizeAll; break;
|
case SDL_SYSTEM_CURSOR_SIZEALL: cursorType = CoreCursorType::SizeAll; break;
|
||||||
case SDL_SYSTEM_CURSOR_NO: cursorType = CoreCursorType::UniversalNo; break;
|
case SDL_SYSTEM_CURSOR_NO: cursorType = CoreCursorType::UniversalNo; break;
|
||||||
case SDL_SYSTEM_CURSOR_HAND: cursorType = CoreCursorType::Hand; break;
|
case SDL_SYSTEM_CURSOR_HAND: cursorType = CoreCursorType::Hand; break;
|
||||||
}
|
}
|
||||||
|
|
||||||
cursor = (SDL_Cursor *) SDL_calloc(1, sizeof(*cursor));
|
cursor = (SDL_Cursor *) SDL_calloc(1, sizeof(*cursor));
|
||||||
if (cursor) {
|
if (cursor) {
|
||||||
/* Create a pointer to a COM reference to a cursor. The extra
|
/* Create a pointer to a COM reference to a cursor. The extra
|
||||||
pointer is used (on top of the COM reference) to allow the cursor
|
pointer is used (on top of the COM reference) to allow the cursor
|
||||||
to be referenced by the SDL_cursor's driverdata field, which is
|
to be referenced by the SDL_cursor's driverdata field, which is
|
||||||
a void pointer.
|
a void pointer.
|
||||||
*/
|
*/
|
||||||
CoreCursor ^* theCursor = new CoreCursor^(nullptr);
|
CoreCursor ^* theCursor = new CoreCursor^(nullptr);
|
||||||
*theCursor = ref new CoreCursor(cursorType, 0);
|
*theCursor = ref new CoreCursor(cursorType, 0);
|
||||||
cursor->driverdata = (void *) theCursor;
|
cursor->driverdata = (void *) theCursor;
|
||||||
} else {
|
} else {
|
||||||
SDL_OutOfMemory();
|
SDL_OutOfMemory();
|
||||||
}
|
}
|
||||||
|
|
||||||
return cursor;
|
return cursor;
|
||||||
}
|
}
|
||||||
|
|
||||||
static SDL_Cursor *
|
static SDL_Cursor *
|
||||||
WINRT_CreateDefaultCursor()
|
WINRT_CreateDefaultCursor()
|
||||||
{
|
{
|
||||||
return WINRT_CreateSystemCursor(SDL_SYSTEM_CURSOR_ARROW);
|
return WINRT_CreateSystemCursor(SDL_SYSTEM_CURSOR_ARROW);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
WINRT_FreeCursor(SDL_Cursor * cursor)
|
WINRT_FreeCursor(SDL_Cursor * cursor)
|
||||||
{
|
{
|
||||||
if (cursor->driverdata) {
|
if (cursor->driverdata) {
|
||||||
CoreCursor ^* theCursor = (CoreCursor ^*) cursor->driverdata;
|
CoreCursor ^* theCursor = (CoreCursor ^*) cursor->driverdata;
|
||||||
*theCursor = nullptr; // Release the COM reference to the CoreCursor
|
*theCursor = nullptr; // Release the COM reference to the CoreCursor
|
||||||
delete theCursor; // Delete the pointer to the COM reference
|
delete theCursor; // Delete the pointer to the COM reference
|
||||||
}
|
}
|
||||||
SDL_free(cursor);
|
SDL_free(cursor);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
WINRT_ShowCursor(SDL_Cursor * cursor)
|
WINRT_ShowCursor(SDL_Cursor * cursor)
|
||||||
{
|
{
|
||||||
if (cursor) {
|
if (cursor) {
|
||||||
CoreCursor ^* theCursor = (CoreCursor ^*) cursor->driverdata;
|
CoreCursor ^* theCursor = (CoreCursor ^*) cursor->driverdata;
|
||||||
CoreWindow::GetForCurrentThread()->PointerCursor = *theCursor;
|
CoreWindow::GetForCurrentThread()->PointerCursor = *theCursor;
|
||||||
} else {
|
} else {
|
||||||
CoreWindow::GetForCurrentThread()->PointerCursor = nullptr;
|
CoreWindow::GetForCurrentThread()->PointerCursor = nullptr;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
WINRT_SetRelativeMouseMode(SDL_bool enabled)
|
WINRT_SetRelativeMouseMode(SDL_bool enabled)
|
||||||
{
|
{
|
||||||
WINRT_UseRelativeMouseMode = enabled;
|
WINRT_UseRelativeMouseMode = enabled;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
WINRT_InitMouse(_THIS)
|
WINRT_InitMouse(_THIS)
|
||||||
{
|
{
|
||||||
SDL_Mouse *mouse = SDL_GetMouse();
|
SDL_Mouse *mouse = SDL_GetMouse();
|
||||||
|
|
||||||
/* DLudwig, Dec 3, 2012: Windows RT does not currently provide APIs for
|
/* DLudwig, Dec 3, 2012: WinRT does not currently provide APIs for
|
||||||
the following features, AFAIK:
|
the following features, AFAIK:
|
||||||
- custom cursors (multiple system cursors are, however, available)
|
- custom cursors (multiple system cursors are, however, available)
|
||||||
- programmatically moveable cursors
|
- programmatically moveable cursors
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if WINAPI_FAMILY != WINAPI_FAMILY_PHONE_APP
|
#if WINAPI_FAMILY != WINAPI_FAMILY_PHONE_APP
|
||||||
//mouse->CreateCursor = WINRT_CreateCursor;
|
//mouse->CreateCursor = WINRT_CreateCursor;
|
||||||
mouse->CreateSystemCursor = WINRT_CreateSystemCursor;
|
mouse->CreateSystemCursor = WINRT_CreateSystemCursor;
|
||||||
mouse->ShowCursor = WINRT_ShowCursor;
|
mouse->ShowCursor = WINRT_ShowCursor;
|
||||||
mouse->FreeCursor = WINRT_FreeCursor;
|
mouse->FreeCursor = WINRT_FreeCursor;
|
||||||
//mouse->WarpMouse = WINRT_WarpMouse;
|
//mouse->WarpMouse = WINRT_WarpMouse;
|
||||||
mouse->SetRelativeMouseMode = WINRT_SetRelativeMouseMode;
|
mouse->SetRelativeMouseMode = WINRT_SetRelativeMouseMode;
|
||||||
|
|
||||||
SDL_SetDefaultCursor(WINRT_CreateDefaultCursor());
|
SDL_SetDefaultCursor(WINRT_CreateDefaultCursor());
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
WINRT_QuitMouse(_THIS)
|
WINRT_QuitMouse(_THIS)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
// Applies necessary geometric transformations to raw cursor positions:
|
// Applies necessary geometric transformations to raw cursor positions:
|
||||||
static Windows::Foundation::Point
|
static Windows::Foundation::Point
|
||||||
TransformCursor(SDL_Window * window, Windows::Foundation::Point rawPosition)
|
TransformCursor(SDL_Window * window, Windows::Foundation::Point rawPosition)
|
||||||
@ -166,8 +166,8 @@ TransformCursor(SDL_Window * window, Windows::Foundation::Point rawPosition)
|
|||||||
outputPosition.X = rawPosition.X * (((float32)window->w) / nativeWindow->Bounds.Width);
|
outputPosition.X = rawPosition.X * (((float32)window->w) / nativeWindow->Bounds.Width);
|
||||||
outputPosition.Y = rawPosition.Y * (((float32)window->h) / nativeWindow->Bounds.Height);
|
outputPosition.Y = rawPosition.Y * (((float32)window->h) / nativeWindow->Bounds.Height);
|
||||||
return outputPosition;
|
return outputPosition;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int
|
static inline int
|
||||||
_lround(float arg)
|
_lround(float arg)
|
||||||
{
|
{
|
||||||
@ -176,15 +176,15 @@ _lround(float arg)
|
|||||||
} else {
|
} else {
|
||||||
return (int)ceil(arg - 0.5f);
|
return (int)ceil(arg - 0.5f);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
WINRT_ProcessMouseMovedEvent(SDL_Window * window, Windows::Devices::Input::MouseEventArgs ^args)
|
WINRT_ProcessMouseMovedEvent(SDL_Window * window, Windows::Devices::Input::MouseEventArgs ^args)
|
||||||
{
|
{
|
||||||
if (!window || !WINRT_UseRelativeMouseMode) {
|
if (!window || !WINRT_UseRelativeMouseMode) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// DLudwig, 2012-12-28: On some systems, namely Visual Studio's Windows
|
// DLudwig, 2012-12-28: On some systems, namely Visual Studio's Windows
|
||||||
// Simulator, as well as Windows 8 in a Parallels 8 VM, MouseEventArgs'
|
// Simulator, as well as Windows 8 in a Parallels 8 VM, MouseEventArgs'
|
||||||
// MouseDelta field often reports very large values. More information
|
// MouseDelta field often reports very large values. More information
|
||||||
@ -228,7 +228,7 @@ WINRT_ProcessMouseMovedEvent(SDL_Window * window, Windows::Devices::Input::Mouse
|
|||||||
//
|
//
|
||||||
// One possible workaround would be to programmatically set the cursor's
|
// One possible workaround would be to programmatically set the cursor's
|
||||||
// position to the screen's center (when SDL's relative mouse mode is enabled),
|
// position to the screen's center (when SDL's relative mouse mode is enabled),
|
||||||
// however Windows RT does not yet seem to have the ability to set the cursor's
|
// however WinRT does not yet seem to have the ability to set the cursor's
|
||||||
// position via a public API. Win32 did this via an API call, SetCursorPos,
|
// position via a public API. Win32 did this via an API call, SetCursorPos,
|
||||||
// however WinRT makes this function be private. Apps that use it won't get
|
// however WinRT makes this function be private. Apps that use it won't get
|
||||||
// approved for distribution in the Windows Store. I've yet to be able to find
|
// approved for distribution in the Windows Store. I've yet to be able to find
|
||||||
@ -249,8 +249,8 @@ WINRT_ProcessMouseMovedEvent(SDL_Window * window, Windows::Devices::Input::Mouse
|
|||||||
1,
|
1,
|
||||||
_lround(mouseDeltaInSDLWindowCoords.X),
|
_lround(mouseDeltaInSDLWindowCoords.X),
|
||||||
_lround(mouseDeltaInSDLWindowCoords.Y));
|
_lround(mouseDeltaInSDLWindowCoords.Y));
|
||||||
}
|
}
|
||||||
|
|
||||||
static Uint8
|
static Uint8
|
||||||
WINRT_GetSDLButtonForPointerPoint(Windows::UI::Input::PointerPoint ^pt)
|
WINRT_GetSDLButtonForPointerPoint(Windows::UI::Input::PointerPoint ^pt)
|
||||||
{
|
{
|
||||||
@ -331,10 +331,10 @@ WINRT_LogPointerEvent(const char * header, PointerEventArgs ^ args, Windows::Fou
|
|||||||
pt->FrameId,
|
pt->FrameId,
|
||||||
pt->PointerId,
|
pt->PointerId,
|
||||||
WINRT_ConvertPointerUpdateKindToString(args->CurrentPoint->Properties->PointerUpdateKind));
|
WINRT_ConvertPointerUpdateKindToString(args->CurrentPoint->Properties->PointerUpdateKind));
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
WINRT_ProcessPointerMovedEvent(SDL_Window *window, Windows::UI::Core::PointerEventArgs ^args)
|
WINRT_ProcessPointerMovedEvent(SDL_Window *window, Windows::UI::Core::PointerEventArgs ^args)
|
||||||
{
|
{
|
||||||
#if LOG_POINTER_EVENTS
|
#if LOG_POINTER_EVENTS
|
||||||
WINRT_LogPointerEvent("pointer moved", args, TransformCursor(args->CurrentPoint->Position));
|
WINRT_LogPointerEvent("pointer moved", args, TransformCursor(args->CurrentPoint->Position));
|
||||||
@ -346,9 +346,9 @@ WINRT_ProcessPointerMovedEvent(SDL_Window *window, Windows::UI::Core::PointerEve
|
|||||||
|
|
||||||
Windows::Foundation::Point transformedPoint = TransformCursor(window, args->CurrentPoint->Position);
|
Windows::Foundation::Point transformedPoint = TransformCursor(window, args->CurrentPoint->Position);
|
||||||
SDL_SendMouseMotion(window, 0, 0, (int)transformedPoint.X, (int)transformedPoint.Y);
|
SDL_SendMouseMotion(window, 0, 0, (int)transformedPoint.X, (int)transformedPoint.Y);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
WINRT_ProcessPointerWheelChangedEvent(SDL_Window *window, Windows::UI::Core::PointerEventArgs ^args)
|
WINRT_ProcessPointerWheelChangedEvent(SDL_Window *window, Windows::UI::Core::PointerEventArgs ^args)
|
||||||
{
|
{
|
||||||
#if LOG_POINTER_EVENTS
|
#if LOG_POINTER_EVENTS
|
||||||
@ -362,8 +362,8 @@ WINRT_ProcessPointerWheelChangedEvent(SDL_Window *window, Windows::UI::Core::Poi
|
|||||||
// FIXME: This may need to accumulate deltas up to WHEEL_DELTA
|
// FIXME: This may need to accumulate deltas up to WHEEL_DELTA
|
||||||
short motion = args->CurrentPoint->Properties->MouseWheelDelta / WHEEL_DELTA;
|
short motion = args->CurrentPoint->Properties->MouseWheelDelta / WHEEL_DELTA;
|
||||||
SDL_SendMouseWheel(window, 0, 0, motion);
|
SDL_SendMouseWheel(window, 0, 0, motion);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WINRT_ProcessPointerReleasedEvent(SDL_Window *window, Windows::UI::Core::PointerEventArgs ^args)
|
void WINRT_ProcessPointerReleasedEvent(SDL_Window *window, Windows::UI::Core::PointerEventArgs ^args)
|
||||||
{
|
{
|
||||||
#if LOG_POINTER_EVENTS
|
#if LOG_POINTER_EVENTS
|
||||||
@ -378,8 +378,8 @@ void WINRT_ProcessPointerReleasedEvent(SDL_Window *window, Windows::UI::Core::Po
|
|||||||
if (button) {
|
if (button) {
|
||||||
SDL_SendMouseButton(window, 0, SDL_RELEASED, button);
|
SDL_SendMouseButton(window, 0, SDL_RELEASED, button);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void WINRT_ProcessPointerPressedEvent(SDL_Window *window, Windows::UI::Core::PointerEventArgs ^args)
|
void WINRT_ProcessPointerPressedEvent(SDL_Window *window, Windows::UI::Core::PointerEventArgs ^args)
|
||||||
{
|
{
|
||||||
#if LOG_POINTER_EVENTS
|
#if LOG_POINTER_EVENTS
|
||||||
@ -394,8 +394,8 @@ void WINRT_ProcessPointerPressedEvent(SDL_Window *window, Windows::UI::Core::Poi
|
|||||||
if (button) {
|
if (button) {
|
||||||
SDL_SendMouseButton(window, 0, SDL_PRESSED, button);
|
SDL_SendMouseButton(window, 0, SDL_PRESSED, button);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* SDL_VIDEO_DRIVER_WINRT */
|
#endif /* SDL_VIDEO_DRIVER_WINRT */
|
||||||
|
|
||||||
/* vi: set ts=4 sw=4 expandtab: */
|
/* vi: set ts=4 sw=4 expandtab: */
|
||||||
|
@ -132,7 +132,7 @@ WINRT_CreateDevice(int devindex)
|
|||||||
|
|
||||||
#define WINRTVID_DRIVER_NAME "winrt"
|
#define WINRTVID_DRIVER_NAME "winrt"
|
||||||
VideoBootStrap WINRT_bootstrap = {
|
VideoBootStrap WINRT_bootstrap = {
|
||||||
WINRTVID_DRIVER_NAME, "SDL Windows RT video driver",
|
WINRTVID_DRIVER_NAME, "SDL WinRT video driver",
|
||||||
WINRT_Available, WINRT_CreateDevice
|
WINRT_Available, WINRT_CreateDevice
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user