2015-06-21 23:33:46 +08:00
|
|
|
/*
|
|
|
|
Simple DirectMedia Layer
|
2024-01-02 05:15:26 +08:00
|
|
|
Copyright (C) 1997-2024 Sam Lantinga <slouken@libsdl.org>
|
2015-06-21 23:33:46 +08:00
|
|
|
|
|
|
|
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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2024-05-16 22:44:37 +08:00
|
|
|
* # CategoryKeyboard
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-05-16 22:44:37 +08:00
|
|
|
* SDL keyboard management.
|
2015-06-21 23:33:46 +08:00
|
|
|
*/
|
|
|
|
|
2016-11-21 13:34:54 +08:00
|
|
|
#ifndef SDL_keyboard_h_
|
|
|
|
#define SDL_keyboard_h_
|
2015-06-21 23:33:46 +08:00
|
|
|
|
2022-11-27 12:43:38 +08:00
|
|
|
#include <SDL3/SDL_stdinc.h>
|
|
|
|
#include <SDL3/SDL_error.h>
|
|
|
|
#include <SDL3/SDL_keycode.h>
|
2024-09-07 23:20:59 +08:00
|
|
|
#include <SDL3/SDL_properties.h>
|
|
|
|
#include <SDL3/SDL_rect.h>
|
|
|
|
#include <SDL3/SDL_scancode.h>
|
2022-11-27 12:43:38 +08:00
|
|
|
#include <SDL3/SDL_video.h>
|
2015-06-21 23:33:46 +08:00
|
|
|
|
2022-12-23 00:38:59 +08:00
|
|
|
#include <SDL3/SDL_begin_code.h>
|
2015-06-21 23:33:46 +08:00
|
|
|
/* Set up for C function definitions, even when using C++ */
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2024-05-03 10:53:08 +08:00
|
|
|
/**
|
|
|
|
* This is a unique ID for a keyboard for the time it is connected to the
|
|
|
|
* system, and is never reused for the lifetime of the application.
|
|
|
|
*
|
|
|
|
* If the keyboard is disconnected and reconnected, it will get a new ID.
|
|
|
|
*
|
2024-08-17 06:20:11 +08:00
|
|
|
* The value 0 is an invalid ID.
|
2024-05-03 10:53:08 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This datatype is available since SDL 3.1.3.
|
2024-05-03 10:53:08 +08:00
|
|
|
*/
|
2024-03-20 21:58:00 +08:00
|
|
|
typedef Uint32 SDL_KeyboardID;
|
|
|
|
|
2015-06-21 23:33:46 +08:00
|
|
|
/* Function prototypes */
|
|
|
|
|
2024-03-20 21:58:00 +08:00
|
|
|
/**
|
|
|
|
* Return whether a keyboard is currently connected.
|
|
|
|
*
|
2024-09-18 22:52:28 +08:00
|
|
|
* \returns true if a keyboard is connected, false otherwise.
|
2024-03-20 21:58:00 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2024-03-20 21:58:00 +08:00
|
|
|
*
|
|
|
|
* \sa SDL_GetKeyboards
|
|
|
|
*/
|
2024-09-18 22:52:28 +08:00
|
|
|
extern SDL_DECLSPEC bool SDLCALL SDL_HasKeyboard(void);
|
2024-03-20 21:58:00 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a list of currently connected keyboards.
|
|
|
|
*
|
2024-03-24 07:32:24 +08:00
|
|
|
* Note that this will include any device or virtual driver that includes
|
|
|
|
* keyboard functionality, including some mice, KVM switches, motherboard
|
|
|
|
* power buttons, etc. You should wait for input from a device before you
|
|
|
|
* consider it actively in use.
|
2024-03-23 01:58:27 +08:00
|
|
|
*
|
2024-07-20 03:23:24 +08:00
|
|
|
* \param count a pointer filled in with the number of keyboards returned, may
|
|
|
|
* be NULL.
|
|
|
|
* \returns a 0 terminated array of keyboards instance IDs or NULL on failure;
|
2024-07-27 11:59:43 +08:00
|
|
|
* call SDL_GetError() for more information. This should be freed
|
|
|
|
* with SDL_free() when it is no longer needed.
|
2024-03-20 21:58:00 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2024-03-20 21:58:00 +08:00
|
|
|
*
|
2024-07-15 06:22:03 +08:00
|
|
|
* \sa SDL_GetKeyboardNameForID
|
2024-03-20 21:58:00 +08:00
|
|
|
* \sa SDL_HasKeyboard
|
|
|
|
*/
|
2024-07-28 22:06:22 +08:00
|
|
|
extern SDL_DECLSPEC SDL_KeyboardID * SDLCALL SDL_GetKeyboards(int *count);
|
2024-03-20 21:58:00 +08:00
|
|
|
|
2024-03-23 00:17:17 +08:00
|
|
|
/**
|
|
|
|
* Get the name of a keyboard.
|
|
|
|
*
|
|
|
|
* This function returns "" if the keyboard doesn't have a name.
|
|
|
|
*
|
2024-06-14 14:09:55 +08:00
|
|
|
* \param instance_id the keyboard instance ID.
|
2024-07-18 15:30:33 +08:00
|
|
|
* \returns the name of the selected keyboard or NULL on failure; call
|
2024-03-24 07:32:24 +08:00
|
|
|
* SDL_GetError() for more information.
|
2024-03-23 00:17:17 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2024-03-23 00:17:17 +08:00
|
|
|
*
|
|
|
|
* \sa SDL_GetKeyboards
|
|
|
|
*/
|
2024-07-27 09:57:18 +08:00
|
|
|
extern SDL_DECLSPEC const char * SDLCALL SDL_GetKeyboardNameForID(SDL_KeyboardID instance_id);
|
2024-03-23 00:17:17 +08:00
|
|
|
|
2015-06-21 23:33:46 +08:00
|
|
|
/**
|
2021-03-22 02:18:39 +08:00
|
|
|
* Query the window which currently has keyboard focus.
|
|
|
|
*
|
|
|
|
* \returns the window with keyboard focus.
|
2021-10-27 09:36:05 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2015-06-21 23:33:46 +08:00
|
|
|
*/
|
2024-05-18 07:52:36 +08:00
|
|
|
extern SDL_DECLSPEC SDL_Window * SDLCALL SDL_GetKeyboardFocus(void);
|
2015-06-21 23:33:46 +08:00
|
|
|
|
|
|
|
/**
|
2021-03-22 02:18:39 +08:00
|
|
|
* Get a snapshot of the current state of the keyboard.
|
|
|
|
*
|
|
|
|
* The pointer returned is a pointer to an internal SDL array. It will be
|
2021-07-15 05:07:04 +08:00
|
|
|
* valid for the whole lifetime of the application and should not be freed by
|
|
|
|
* the caller.
|
2021-03-22 02:18:39 +08:00
|
|
|
*
|
2024-09-18 23:33:11 +08:00
|
|
|
* A array element with a value of true means that the key is pressed and a
|
|
|
|
* value of false means that it is not. Indexes into this array are obtained
|
|
|
|
* by using SDL_Scancode values.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2021-03-22 02:18:39 +08:00
|
|
|
* Use SDL_PumpEvents() to update the state array.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2021-03-22 02:18:39 +08:00
|
|
|
* This function gives you the current state after all events have been
|
|
|
|
* processed, so if a key or button has been pressed and released before you
|
|
|
|
* process events, then the pressed state will never show up in the
|
|
|
|
* SDL_GetKeyboardState() calls.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2021-03-22 02:18:39 +08:00
|
|
|
* Note: This function doesn't take into account whether shift has been
|
|
|
|
* pressed or not.
|
|
|
|
*
|
2024-06-14 14:09:55 +08:00
|
|
|
* \param numkeys if non-NULL, receives the length of the returned array.
|
2021-03-22 02:18:39 +08:00
|
|
|
* \returns a pointer to an array of key states.
|
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2021-10-27 09:36:05 +08:00
|
|
|
*
|
2021-03-22 02:18:39 +08:00
|
|
|
* \sa SDL_PumpEvents
|
2022-07-12 00:49:00 +08:00
|
|
|
* \sa SDL_ResetKeyboard
|
2015-06-21 23:33:46 +08:00
|
|
|
*/
|
2024-09-18 22:52:28 +08:00
|
|
|
extern SDL_DECLSPEC const bool * SDLCALL SDL_GetKeyboardState(int *numkeys);
|
2015-06-21 23:33:46 +08:00
|
|
|
|
2022-07-12 00:49:00 +08:00
|
|
|
/**
|
2024-04-09 10:36:57 +08:00
|
|
|
* Clear the state of the keyboard.
|
2022-07-12 00:49:00 +08:00
|
|
|
*
|
|
|
|
* This function will generate key up events for all pressed keys.
|
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2022-07-12 00:49:00 +08:00
|
|
|
*
|
|
|
|
* \sa SDL_GetKeyboardState
|
|
|
|
*/
|
2024-05-18 07:52:36 +08:00
|
|
|
extern SDL_DECLSPEC void SDLCALL SDL_ResetKeyboard(void);
|
2022-07-12 00:49:00 +08:00
|
|
|
|
2015-06-21 23:33:46 +08:00
|
|
|
/**
|
2021-03-22 02:18:39 +08:00
|
|
|
* Get the current key modifier state for the keyboard.
|
|
|
|
*
|
|
|
|
* \returns an OR'd combination of the modifier keys for the keyboard. See
|
|
|
|
* SDL_Keymod for details.
|
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2021-10-27 09:36:05 +08:00
|
|
|
*
|
2021-03-22 02:18:39 +08:00
|
|
|
* \sa SDL_GetKeyboardState
|
|
|
|
* \sa SDL_SetModState
|
2015-06-21 23:33:46 +08:00
|
|
|
*/
|
2024-05-18 07:52:36 +08:00
|
|
|
extern SDL_DECLSPEC SDL_Keymod SDLCALL SDL_GetModState(void);
|
2015-06-21 23:33:46 +08:00
|
|
|
|
|
|
|
/**
|
2021-03-22 02:18:39 +08:00
|
|
|
* Set the current key modifier state for the keyboard.
|
|
|
|
*
|
|
|
|
* The inverse of SDL_GetModState(), SDL_SetModState() allows you to impose
|
|
|
|
* modifier key states on your application. Simply pass your desired modifier
|
|
|
|
* states into `modstate`. This value may be a bitwise, OR'd combination of
|
|
|
|
* SDL_Keymod values.
|
|
|
|
*
|
|
|
|
* This does not change the keyboard state, only the key modifier flags that
|
|
|
|
* SDL reports.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-06-14 14:09:55 +08:00
|
|
|
* \param modstate the desired SDL_Keymod for the keyboard.
|
2021-03-22 02:18:39 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2021-10-27 09:36:05 +08:00
|
|
|
*
|
2021-03-22 02:18:39 +08:00
|
|
|
* \sa SDL_GetModState
|
2015-06-21 23:33:46 +08:00
|
|
|
*/
|
2024-05-18 07:52:36 +08:00
|
|
|
extern SDL_DECLSPEC void SDLCALL SDL_SetModState(SDL_Keymod modstate);
|
2015-06-21 23:33:46 +08:00
|
|
|
|
2024-05-29 10:47:17 +08:00
|
|
|
/**
|
2024-08-06 09:04:17 +08:00
|
|
|
* Get the key code corresponding to the given scancode according to the
|
|
|
|
* current keyboard layout.
|
2024-05-29 10:47:17 +08:00
|
|
|
*
|
2024-08-06 10:47:18 +08:00
|
|
|
* If you want to get the keycode as it would be delivered in key events,
|
|
|
|
* including options specified in SDL_HINT_KEYCODE_OPTIONS, then you should
|
2024-09-18 22:52:28 +08:00
|
|
|
* pass `key_event` as true. Otherwise this function simply translates the
|
2024-08-06 10:47:18 +08:00
|
|
|
* scancode based on the given modifier state.
|
2024-05-29 10:47:17 +08:00
|
|
|
*
|
2024-08-06 09:04:17 +08:00
|
|
|
* \param scancode the desired SDL_Scancode to query.
|
2024-06-22 13:06:38 +08:00
|
|
|
* \param modstate the modifier state to use when translating the scancode to
|
|
|
|
* a keycode.
|
2024-09-18 22:52:28 +08:00
|
|
|
* \param key_event true if the keycode will be used in key events.
|
2021-03-22 02:18:39 +08:00
|
|
|
* \returns the SDL_Keycode that corresponds to the given SDL_Scancode.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2021-10-27 09:36:05 +08:00
|
|
|
*
|
2024-08-06 09:04:17 +08:00
|
|
|
* \sa SDL_GetKeyName
|
2024-08-06 10:09:18 +08:00
|
|
|
* \sa SDL_GetScancodeFromKey
|
2024-08-06 07:37:24 +08:00
|
|
|
*/
|
2024-09-18 22:52:28 +08:00
|
|
|
extern SDL_DECLSPEC SDL_Keycode SDLCALL SDL_GetKeyFromScancode(SDL_Scancode scancode, SDL_Keymod modstate, bool key_event);
|
2015-06-21 23:33:46 +08:00
|
|
|
|
2024-08-06 10:09:18 +08:00
|
|
|
/**
|
|
|
|
* Get the scancode corresponding to the given key code according to the
|
|
|
|
* current keyboard layout.
|
|
|
|
*
|
|
|
|
* Note that there may be multiple scancode+modifier states that can generate
|
|
|
|
* this keycode, this will just return the first one found.
|
|
|
|
*
|
|
|
|
* \param key the desired SDL_Keycode to query.
|
|
|
|
* \param modstate a pointer to the modifier state that would be used when the
|
|
|
|
* scancode generates this key, may be NULL.
|
|
|
|
* \returns the SDL_Scancode that corresponds to the given SDL_Keycode.
|
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2024-08-06 10:09:18 +08:00
|
|
|
*
|
|
|
|
* \sa SDL_GetKeyFromScancode
|
|
|
|
* \sa SDL_GetScancodeName
|
|
|
|
*/
|
|
|
|
extern SDL_DECLSPEC SDL_Scancode SDLCALL SDL_GetScancodeFromKey(SDL_Keycode key, SDL_Keymod *modstate);
|
|
|
|
|
2015-06-21 23:33:46 +08:00
|
|
|
/**
|
2024-06-20 06:00:12 +08:00
|
|
|
* Set a human-readable name for a scancode.
|
|
|
|
*
|
|
|
|
* \param scancode the desired SDL_Scancode.
|
2024-06-22 13:06:38 +08:00
|
|
|
* \param name the name to use for the scancode, encoded as UTF-8. The string
|
|
|
|
* is not copied, so the pointer given to this function must stay
|
|
|
|
* valid while SDL is being used.
|
2024-09-18 23:33:11 +08:00
|
|
|
* \returns true on success or false on failure; call SDL_GetError() for more
|
|
|
|
* information.
|
2021-03-22 02:18:39 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2024-06-20 06:00:12 +08:00
|
|
|
*
|
|
|
|
* \sa SDL_GetScancodeName
|
|
|
|
*/
|
2024-09-18 22:52:28 +08:00
|
|
|
extern SDL_DECLSPEC bool SDLCALL SDL_SetScancodeName(SDL_Scancode scancode, const char *name);
|
2024-06-20 06:00:12 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a human-readable name for a scancode.
|
2021-03-22 02:18:39 +08:00
|
|
|
*
|
|
|
|
* **Warning**: The returned name is by design not stable across platforms,
|
|
|
|
* e.g. the name for `SDL_SCANCODE_LGUI` is "Left GUI" under Linux but "Left
|
|
|
|
* Windows" under Microsoft Windows, and some scancodes like
|
|
|
|
* `SDL_SCANCODE_NONUSBACKSLASH` don't have any name at all. There are even
|
|
|
|
* scancodes that share names, e.g. `SDL_SCANCODE_RETURN` and
|
|
|
|
* `SDL_SCANCODE_RETURN2` (both called "Return"). This function is therefore
|
|
|
|
* unsuitable for creating a stable cross-platform two-way mapping between
|
|
|
|
* strings and scancodes.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-06-14 14:09:55 +08:00
|
|
|
* \param scancode the desired SDL_Scancode to query.
|
2021-03-22 02:18:39 +08:00
|
|
|
* \returns a pointer to the name for the scancode. If the scancode doesn't
|
|
|
|
* have a name this function returns an empty string ("").
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2021-03-22 02:18:39 +08:00
|
|
|
*
|
|
|
|
* \sa SDL_GetScancodeFromKey
|
|
|
|
* \sa SDL_GetScancodeFromName
|
2024-06-20 06:00:12 +08:00
|
|
|
* \sa SDL_SetScancodeName
|
2015-06-21 23:33:46 +08:00
|
|
|
*/
|
2024-07-27 09:57:18 +08:00
|
|
|
extern SDL_DECLSPEC const char * SDLCALL SDL_GetScancodeName(SDL_Scancode scancode);
|
2015-06-21 23:33:46 +08:00
|
|
|
|
|
|
|
/**
|
2021-03-22 02:18:39 +08:00
|
|
|
* Get a scancode from a human-readable name.
|
|
|
|
*
|
2024-06-14 14:09:55 +08:00
|
|
|
* \param name the human-readable scancode name.
|
2021-03-22 02:18:39 +08:00
|
|
|
* \returns the SDL_Scancode, or `SDL_SCANCODE_UNKNOWN` if the name wasn't
|
|
|
|
* recognized; call SDL_GetError() for more information.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2021-03-22 02:18:39 +08:00
|
|
|
* \sa SDL_GetKeyFromName
|
|
|
|
* \sa SDL_GetScancodeFromKey
|
|
|
|
* \sa SDL_GetScancodeName
|
2015-06-21 23:33:46 +08:00
|
|
|
*/
|
2024-05-18 07:52:36 +08:00
|
|
|
extern SDL_DECLSPEC SDL_Scancode SDLCALL SDL_GetScancodeFromName(const char *name);
|
2015-06-21 23:33:46 +08:00
|
|
|
|
|
|
|
/**
|
2021-03-22 02:18:39 +08:00
|
|
|
* Get a human-readable name for a key.
|
|
|
|
*
|
2024-07-03 00:29:33 +08:00
|
|
|
* If the key doesn't have a name, this function returns an empty string ("").
|
|
|
|
*
|
2024-06-14 14:09:55 +08:00
|
|
|
* \param key the desired SDL_Keycode to query.
|
2024-07-03 00:29:33 +08:00
|
|
|
* \returns a UTF-8 encoded string of the key name.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2021-10-27 09:36:05 +08:00
|
|
|
*
|
2021-03-22 02:18:39 +08:00
|
|
|
* \sa SDL_GetKeyFromName
|
|
|
|
* \sa SDL_GetKeyFromScancode
|
|
|
|
* \sa SDL_GetScancodeFromKey
|
2015-06-21 23:33:46 +08:00
|
|
|
*/
|
2024-08-06 11:58:41 +08:00
|
|
|
extern SDL_DECLSPEC const char * SDLCALL SDL_GetKeyName(SDL_Keycode key);
|
2015-06-21 23:33:46 +08:00
|
|
|
|
|
|
|
/**
|
2021-03-22 02:18:39 +08:00
|
|
|
* Get a key code from a human-readable name.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-06-14 14:09:55 +08:00
|
|
|
* \param name the human-readable key name.
|
2021-03-22 02:18:39 +08:00
|
|
|
* \returns key code, or `SDLK_UNKNOWN` if the name wasn't recognized; call
|
|
|
|
* SDL_GetError() for more information.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2021-10-27 09:36:05 +08:00
|
|
|
*
|
2021-03-22 02:18:39 +08:00
|
|
|
* \sa SDL_GetKeyFromScancode
|
|
|
|
* \sa SDL_GetKeyName
|
|
|
|
* \sa SDL_GetScancodeFromName
|
2015-06-21 23:33:46 +08:00
|
|
|
*/
|
2024-08-06 11:58:41 +08:00
|
|
|
extern SDL_DECLSPEC SDL_Keycode SDLCALL SDL_GetKeyFromName(const char *name);
|
2015-06-21 23:33:46 +08:00
|
|
|
|
|
|
|
/**
|
2024-06-22 21:16:19 +08:00
|
|
|
* Start accepting Unicode text input events in a window.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-06-25 02:21:18 +08:00
|
|
|
* This function will enable text input (SDL_EVENT_TEXT_INPUT and
|
|
|
|
* SDL_EVENT_TEXT_EDITING events) in the specified window. Please use this
|
|
|
|
* function paired with SDL_StopTextInput().
|
2021-03-22 02:18:39 +08:00
|
|
|
*
|
2024-04-28 20:29:13 +08:00
|
|
|
* Text input events are not received by default.
|
2024-01-25 12:14:30 +08:00
|
|
|
*
|
2024-10-08 21:59:10 +08:00
|
|
|
* On some platforms using this function shows the screen keyboard and/or
|
|
|
|
* activates an IME, which can prevent some key press events from being passed
|
|
|
|
* through.
|
2024-06-22 21:16:19 +08:00
|
|
|
*
|
|
|
|
* \param window the window to enable text input.
|
2024-09-18 23:33:11 +08:00
|
|
|
* \returns true on success or false on failure; call SDL_GetError() for more
|
|
|
|
* information.
|
2021-03-22 02:18:39 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2021-10-27 09:36:05 +08:00
|
|
|
*
|
2024-06-29 04:17:04 +08:00
|
|
|
* \sa SDL_SetTextInputArea
|
2024-08-02 21:56:51 +08:00
|
|
|
* \sa SDL_StartTextInputWithProperties
|
2021-03-22 02:18:39 +08:00
|
|
|
* \sa SDL_StopTextInput
|
2024-06-22 21:16:19 +08:00
|
|
|
* \sa SDL_TextInputActive
|
2015-06-21 23:33:46 +08:00
|
|
|
*/
|
2024-09-18 22:52:28 +08:00
|
|
|
extern SDL_DECLSPEC bool SDLCALL SDL_StartTextInput(SDL_Window *window);
|
2015-06-21 23:33:46 +08:00
|
|
|
|
2024-08-02 21:56:51 +08:00
|
|
|
/**
|
|
|
|
* Text input type.
|
|
|
|
*
|
2024-08-03 05:50:11 +08:00
|
|
|
* These are the valid values for SDL_PROP_TEXTINPUT_TYPE_NUMBER. Not every
|
|
|
|
* value is valid on every platform, but where a value isn't supported, a
|
|
|
|
* reasonable fallback will be used.
|
2024-08-02 21:56:51 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This enum is available since SDL 3.1.3.
|
2024-08-02 21:56:51 +08:00
|
|
|
*
|
|
|
|
* \sa SDL_StartTextInputWithProperties
|
|
|
|
*/
|
|
|
|
typedef enum SDL_TextInputType
|
|
|
|
{
|
|
|
|
SDL_TEXTINPUT_TYPE_TEXT, /**< The input is text */
|
|
|
|
SDL_TEXTINPUT_TYPE_TEXT_NAME, /**< The input is a person's name */
|
|
|
|
SDL_TEXTINPUT_TYPE_TEXT_EMAIL, /**< The input is an e-mail address */
|
|
|
|
SDL_TEXTINPUT_TYPE_TEXT_USERNAME, /**< The input is a username */
|
|
|
|
SDL_TEXTINPUT_TYPE_TEXT_PASSWORD_HIDDEN, /**< The input is a secure password that is hidden */
|
|
|
|
SDL_TEXTINPUT_TYPE_TEXT_PASSWORD_VISIBLE, /**< The input is a secure password that is visible */
|
|
|
|
SDL_TEXTINPUT_TYPE_NUMBER, /**< The input is a number */
|
|
|
|
SDL_TEXTINPUT_TYPE_NUMBER_PASSWORD_HIDDEN, /**< The input is a secure PIN that is hidden */
|
|
|
|
SDL_TEXTINPUT_TYPE_NUMBER_PASSWORD_VISIBLE /**< The input is a secure PIN that is visible */
|
|
|
|
} SDL_TextInputType;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Auto capitalization type.
|
|
|
|
*
|
2024-11-23 04:53:04 +08:00
|
|
|
* These are the valid values for SDL_PROP_TEXTINPUT_CAPITALIZATION_NUMBER.
|
|
|
|
* Not every value is valid on every platform, but where a value isn't
|
|
|
|
* supported, a reasonable fallback will be used.
|
2024-08-02 21:56:51 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This enum is available since SDL 3.1.3.
|
2024-08-02 21:56:51 +08:00
|
|
|
*
|
|
|
|
* \sa SDL_StartTextInputWithProperties
|
|
|
|
*/
|
|
|
|
typedef enum SDL_Capitalization
|
|
|
|
{
|
|
|
|
SDL_CAPITALIZE_NONE, /**< No auto-capitalization will be done */
|
|
|
|
SDL_CAPITALIZE_SENTENCES, /**< The first letter of sentences will be capitalized */
|
|
|
|
SDL_CAPITALIZE_WORDS, /**< The first letter of words will be capitalized */
|
|
|
|
SDL_CAPITALIZE_LETTERS /**< All letters will be capitalized */
|
|
|
|
} SDL_Capitalization;
|
|
|
|
|
|
|
|
/**
|
2024-08-03 05:50:11 +08:00
|
|
|
* Start accepting Unicode text input events in a window, with properties
|
|
|
|
* describing the input.
|
2024-08-02 21:56:51 +08:00
|
|
|
*
|
|
|
|
* This function will enable text input (SDL_EVENT_TEXT_INPUT and
|
|
|
|
* SDL_EVENT_TEXT_EDITING events) in the specified window. Please use this
|
|
|
|
* function paired with SDL_StopTextInput().
|
|
|
|
*
|
|
|
|
* Text input events are not received by default.
|
|
|
|
*
|
2024-10-08 21:59:10 +08:00
|
|
|
* On some platforms using this function shows the screen keyboard and/or
|
|
|
|
* activates an IME, which can prevent some key press events from being passed
|
|
|
|
* through.
|
2024-08-02 21:56:51 +08:00
|
|
|
*
|
|
|
|
* These are the supported properties:
|
|
|
|
*
|
2024-08-03 05:50:11 +08:00
|
|
|
* - `SDL_PROP_TEXTINPUT_TYPE_NUMBER` - an SDL_TextInputType value that
|
|
|
|
* describes text being input, defaults to SDL_TEXTINPUT_TYPE_TEXT.
|
|
|
|
* - `SDL_PROP_TEXTINPUT_CAPITALIZATION_NUMBER` - an SDL_Capitalization value
|
|
|
|
* that describes how text should be capitalized, defaults to
|
|
|
|
* SDL_CAPITALIZE_SENTENCES for normal text entry, SDL_CAPITALIZE_WORDS for
|
|
|
|
* SDL_TEXTINPUT_TYPE_TEXT_NAME, and SDL_CAPITALIZE_NONE for e-mail
|
|
|
|
* addresses, usernames, and passwords.
|
|
|
|
* - `SDL_PROP_TEXTINPUT_AUTOCORRECT_BOOLEAN` - true to enable auto completion
|
2024-09-18 22:52:28 +08:00
|
|
|
* and auto correction, defaults to true.
|
2024-08-03 05:50:11 +08:00
|
|
|
* - `SDL_PROP_TEXTINPUT_MULTILINE_BOOLEAN` - true if multiple lines of text
|
2024-09-18 23:33:11 +08:00
|
|
|
* are allowed. This defaults to true if SDL_HINT_RETURN_KEY_HIDES_IME is
|
|
|
|
* "0" or is not set, and defaults to false if SDL_HINT_RETURN_KEY_HIDES_IME
|
|
|
|
* is "1".
|
2024-08-02 21:56:51 +08:00
|
|
|
*
|
|
|
|
* On Android you can directly specify the input type:
|
|
|
|
*
|
2024-08-03 05:50:11 +08:00
|
|
|
* - `SDL_PROP_TEXTINPUT_ANDROID_INPUTTYPE_NUMBER` - the text input type to
|
|
|
|
* use, overriding other properties. This is documented at
|
|
|
|
* https://developer.android.com/reference/android/text/InputType
|
2024-08-02 21:56:51 +08:00
|
|
|
*
|
|
|
|
* \param window the window to enable text input.
|
|
|
|
* \param props the properties to use.
|
2024-09-18 23:33:11 +08:00
|
|
|
* \returns true on success or false on failure; call SDL_GetError() for more
|
|
|
|
* information.
|
2024-08-02 21:56:51 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2024-08-02 21:56:51 +08:00
|
|
|
*
|
|
|
|
* \sa SDL_SetTextInputArea
|
|
|
|
* \sa SDL_StartTextInput
|
|
|
|
* \sa SDL_StopTextInput
|
|
|
|
* \sa SDL_TextInputActive
|
|
|
|
*/
|
2024-09-18 22:52:28 +08:00
|
|
|
extern SDL_DECLSPEC bool SDLCALL SDL_StartTextInputWithProperties(SDL_Window *window, SDL_PropertiesID props);
|
2024-08-02 21:56:51 +08:00
|
|
|
|
|
|
|
#define SDL_PROP_TEXTINPUT_TYPE_NUMBER "SDL.textinput.type"
|
|
|
|
#define SDL_PROP_TEXTINPUT_CAPITALIZATION_NUMBER "SDL.textinput.capitalization"
|
|
|
|
#define SDL_PROP_TEXTINPUT_AUTOCORRECT_BOOLEAN "SDL.textinput.autocorrect"
|
|
|
|
#define SDL_PROP_TEXTINPUT_MULTILINE_BOOLEAN "SDL.textinput.multiline"
|
|
|
|
#define SDL_PROP_TEXTINPUT_ANDROID_INPUTTYPE_NUMBER "SDL.textinput.android.inputtype"
|
|
|
|
|
2015-06-21 23:33:46 +08:00
|
|
|
/**
|
2024-06-22 21:16:19 +08:00
|
|
|
* Check whether or not Unicode text input events are enabled for a window.
|
2021-03-22 02:18:39 +08:00
|
|
|
*
|
2024-06-22 21:16:19 +08:00
|
|
|
* \param window the window to check.
|
2024-09-18 22:52:28 +08:00
|
|
|
* \returns true if text input events are enabled else false.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2021-03-22 02:18:39 +08:00
|
|
|
*
|
|
|
|
* \sa SDL_StartTextInput
|
2015-06-21 23:33:46 +08:00
|
|
|
*/
|
2024-09-18 22:52:28 +08:00
|
|
|
extern SDL_DECLSPEC bool SDLCALL SDL_TextInputActive(SDL_Window *window);
|
2015-06-21 23:33:46 +08:00
|
|
|
|
|
|
|
/**
|
2024-06-22 21:16:19 +08:00
|
|
|
* Stop receiving any text input events in a window.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-06-25 02:21:18 +08:00
|
|
|
* If SDL_StartTextInput() showed the screen keyboard, this function will hide
|
|
|
|
* it.
|
2024-06-22 21:16:19 +08:00
|
|
|
*
|
|
|
|
* \param window the window to disable text input.
|
2024-09-18 23:33:11 +08:00
|
|
|
* \returns true on success or false on failure; call SDL_GetError() for more
|
|
|
|
* information.
|
2024-01-25 12:14:30 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2021-10-27 09:36:05 +08:00
|
|
|
*
|
2021-03-22 02:18:39 +08:00
|
|
|
* \sa SDL_StartTextInput
|
2015-06-21 23:33:46 +08:00
|
|
|
*/
|
2024-09-18 22:52:28 +08:00
|
|
|
extern SDL_DECLSPEC bool SDLCALL SDL_StopTextInput(SDL_Window *window);
|
2015-06-21 23:33:46 +08:00
|
|
|
|
2022-03-12 06:45:17 +08:00
|
|
|
/**
|
|
|
|
* Dismiss the composition window/IME without disabling the subsystem.
|
|
|
|
*
|
2024-06-22 21:16:19 +08:00
|
|
|
* \param window the window to affect.
|
2024-09-18 23:33:11 +08:00
|
|
|
* \returns true on success or false on failure; call SDL_GetError() for more
|
|
|
|
* information.
|
2024-06-22 21:16:19 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2022-03-12 06:45:17 +08:00
|
|
|
*
|
|
|
|
* \sa SDL_StartTextInput
|
|
|
|
* \sa SDL_StopTextInput
|
|
|
|
*/
|
2024-09-18 22:52:28 +08:00
|
|
|
extern SDL_DECLSPEC bool SDLCALL SDL_ClearComposition(SDL_Window *window);
|
2022-03-12 06:45:17 +08:00
|
|
|
|
2015-06-21 23:33:46 +08:00
|
|
|
/**
|
2024-06-29 04:17:04 +08:00
|
|
|
* Set the area used to type Unicode text input.
|
2023-11-30 23:22:19 +08:00
|
|
|
*
|
2024-06-29 08:09:51 +08:00
|
|
|
* Native input methods may place a window with word suggestions near the
|
|
|
|
* cursor, without covering the text being entered.
|
2024-06-22 21:16:19 +08:00
|
|
|
*
|
2024-06-29 04:17:04 +08:00
|
|
|
* \param window the window for which to set the text input area.
|
2024-06-29 08:09:51 +08:00
|
|
|
* \param rect the SDL_Rect representing the text input area, in window
|
|
|
|
* coordinates, or NULL to clear it.
|
|
|
|
* \param cursor the offset of the current cursor location relative to
|
|
|
|
* `rect->x`, in window coordinates.
|
2024-09-18 23:33:11 +08:00
|
|
|
* \returns true on success or false on failure; call SDL_GetError() for more
|
|
|
|
* information.
|
2023-11-30 23:22:19 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2022-07-04 21:42:05 +08:00
|
|
|
*
|
2024-06-29 04:17:04 +08:00
|
|
|
* \sa SDL_GetTextInputArea
|
|
|
|
* \sa SDL_StartTextInput
|
|
|
|
*/
|
2024-09-18 22:52:28 +08:00
|
|
|
extern SDL_DECLSPEC bool SDLCALL SDL_SetTextInputArea(SDL_Window *window, const SDL_Rect *rect, int cursor);
|
2024-06-29 04:17:04 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the area used to type Unicode text input.
|
2022-02-24 00:18:05 +08:00
|
|
|
*
|
2024-06-29 04:17:04 +08:00
|
|
|
* This returns the values previously set by SDL_SetTextInputArea().
|
|
|
|
*
|
|
|
|
* \param window the window for which to query the text input area.
|
2024-06-29 08:09:51 +08:00
|
|
|
* \param rect a pointer to an SDL_Rect filled in with the text input area,
|
|
|
|
* may be NULL.
|
|
|
|
* \param cursor a pointer to the offset of the current cursor location
|
|
|
|
* relative to `rect->x`, may be NULL.
|
2024-09-18 23:33:11 +08:00
|
|
|
* \returns true on success or false on failure; call SDL_GetError() for more
|
|
|
|
* information.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2021-10-27 09:36:05 +08:00
|
|
|
*
|
2024-06-29 04:17:04 +08:00
|
|
|
* \sa SDL_SetTextInputArea
|
2015-06-21 23:33:46 +08:00
|
|
|
*/
|
2024-09-18 22:52:28 +08:00
|
|
|
extern SDL_DECLSPEC bool SDLCALL SDL_GetTextInputArea(SDL_Window *window, SDL_Rect *rect, int *cursor);
|
2015-06-21 23:33:46 +08:00
|
|
|
|
|
|
|
/**
|
2021-03-22 02:18:39 +08:00
|
|
|
* Check whether the platform has screen keyboard support.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-09-18 23:33:11 +08:00
|
|
|
* \returns true if the platform has some screen keyboard support or false if
|
|
|
|
* not.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2021-03-22 02:18:39 +08:00
|
|
|
* \sa SDL_StartTextInput
|
2022-12-29 11:34:01 +08:00
|
|
|
* \sa SDL_ScreenKeyboardShown
|
2015-06-21 23:33:46 +08:00
|
|
|
*/
|
2024-09-18 22:52:28 +08:00
|
|
|
extern SDL_DECLSPEC bool SDLCALL SDL_HasScreenKeyboardSupport(void);
|
2015-06-21 23:33:46 +08:00
|
|
|
|
|
|
|
/**
|
2021-03-22 02:18:39 +08:00
|
|
|
* Check whether the screen keyboard is shown for given window.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-06-14 14:09:55 +08:00
|
|
|
* \param window the window for which screen keyboard should be queried.
|
2024-09-18 22:52:28 +08:00
|
|
|
* \returns true if screen keyboard is shown or false if not.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2024-10-24 00:19:38 +08:00
|
|
|
* \since This function is available since SDL 3.1.3.
|
2015-06-21 23:33:46 +08:00
|
|
|
*
|
2021-03-22 02:18:39 +08:00
|
|
|
* \sa SDL_HasScreenKeyboardSupport
|
2015-06-21 23:33:46 +08:00
|
|
|
*/
|
2024-09-18 22:52:28 +08:00
|
|
|
extern SDL_DECLSPEC bool SDLCALL SDL_ScreenKeyboardShown(SDL_Window *window);
|
2015-06-21 23:33:46 +08:00
|
|
|
|
|
|
|
/* Ends C function definitions when using C++ */
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
2022-12-23 00:38:59 +08:00
|
|
|
#include <SDL3/SDL_close_code.h>
|
2015-06-21 23:33:46 +08:00
|
|
|
|
2016-11-21 13:34:54 +08:00
|
|
|
#endif /* SDL_keyboard_h_ */
|