TGUI 1.11
Loading...
Searching...
No Matches
BackendSDL.hpp
1
2//
3// TGUI - Texus' Graphical User Interface
4// Copyright (C) 2012-2025 Bruno Van de Velde (vdv_b@tgui.eu)
5//
6// This software is provided 'as-is', without any express or implied warranty.
7// In no event will the authors be held liable for any damages arising from the use of this software.
8//
9// Permission is granted to anyone to use this software for any purpose,
10// including commercial applications, and to alter it and redistribute it freely,
11// subject to the following restrictions:
12//
13// 1. The origin of this software must not be misrepresented;
14// you must not claim that you wrote the original software.
15// If you use this software in a product, an acknowledgment
16// in the product documentation would be appreciated but is not required.
17//
18// 2. Altered source versions must be plainly marked as such,
19// and must not be misrepresented as being the original software.
20//
21// 3. This notice may not be removed or altered from any source distribution.
22//
24
25#ifndef TGUI_BACKEND_SDL_HPP
26#define TGUI_BACKEND_SDL_HPP
27
28#include <TGUI/extlibs/IncludeSDL.hpp>
29#include <TGUI/Backend/Window/SDL/BackendGuiSDL.hpp>
30#include <TGUI/Backend/Window/Backend.hpp>
31
32#include <unordered_map>
33#include <map>
34
36
37TGUI_IGNORE_DEPRECATED_WARNINGS_START // Required for VS2017 due to inheriting a function that we deprecated
38
39namespace tgui
40{
41 class TGUI_API BackendSDL : public Backend
42 {
43 public:
44
48 ~BackendSDL() override;
49
58 void setGuiWindow(BackendGui* gui, SDL_Window* window);
59
64 void detatchGui(BackendGui* gui) override;
65
74 void setMouseCursorStyle(Cursor::Type type, const std::uint8_t* pixels, Vector2u size, Vector2u hotspot) override;
75
82
89 void setMouseCursor(BackendGui* gui, Cursor::Type type) override;
90
91#ifndef TGUI_REMOVE_DEPRECATED_CODE
98 TGUI_DEPRECATED("Use BackendGui::startTextInput instead") void openVirtualKeyboard(const FloatRect& inputRect) override;
99
105 TGUI_DEPRECATED("Use BackendGui::stopTextInput instead") void closeVirtualKeyboard() override;
106#endif
107
115 TGUI_DEPRECATED("Use gui.isKeyboardModifierPressed(modifierKey) instead") TGUI_NODISCARD bool isKeyboardModifierPressed(Event::KeyModifier modifierKey) override;
116
122 void setClipboard(const String& contents) override;
123
129 TGUI_NODISCARD String getClipboard() const override;
130
131#ifdef TGUI_SYSTEM_ANDROID
140 TGUI_NODISCARD std::unique_ptr<std::uint8_t[]> readFileFromAndroidAssets(const String& filename, std::size_t& fileSize) const override;
141#endif
142
144 private:
145
147 // Helper function to create a system cursor
149 TGUI_NODISCARD SDL_Cursor* createSystemCursor(Cursor::Type type);
150
152 // Helper function to update the mouse cursors on all attached guis
154 void updateMouseCursorStyle(Cursor::Type type, SDL_Cursor* cursor);
155
157 // Helper function to update the mouse cursor on a window
159 void updateShownMouseCursor(SDL_Window* window, Cursor::Type type);
160
162 private:
163
164 struct GuiResources
165 {
166 SDL_Window* window = nullptr;
167 Cursor::Type mouseCursor = Cursor::Type::Arrow;
168 };
169
170 std::unordered_map<const BackendGui*, GuiResources> m_guiResources;
171 std::unordered_map<Cursor::Type, SDL_Cursor*> m_mouseCursors;
172
173#if defined(TGUI_SYSTEM_LINUX) && defined(TGUI_USE_X11) && (SDL_MAJOR_VERSION < 3) && defined(SDL_VIDEO_DRIVER_X11)
174 bool m_customCursorX11 = false;
175#endif
176 };
177
179}
180
181TGUI_IGNORE_DEPRECATED_WARNINGS_END
182
184
185#endif // TGUI_BACKEND_SDL_HPP
Base class for the Gui.
Definition BackendGui.hpp:45
Definition BackendSDL.hpp:42
void resetMouseCursorStyle(Cursor::Type type) override
Changes the look of a certain mouse cursor back to the system theme.
void closeVirtualKeyboard() override
Closes the virtual keyboard on Android and iOS.
bool isKeyboardModifierPressed(Event::KeyModifier modifierKey) override
Checks the state for one of the modifier keys.
void detatchGui(BackendGui *gui) override
Informs the backend that a gui object is being destroyed.
void setClipboard(const String &contents) override
Changes the contents of the clipboard.
void setMouseCursor(BackendGui *gui, Cursor::Type type) override
Changes the mouse cursor when the mouse is on top of the window to which the gui is attached.
void setMouseCursorStyle(Cursor::Type type, const std::uint8_t *pixels, Vector2u size, Vector2u hotspot) override
Changes the look of a certain mouse cursor by using a bitmap.
String getClipboard() const override
Returns the contents of the clipboard.
~BackendSDL() override
Destructor.
void openVirtualKeyboard(const FloatRect &inputRect) override
Opens the virtual keyboard on Android and iOS.
void setGuiWindow(BackendGui *gui, SDL_Window *window)
Informs the backend which window belongs to the gui.
virtual std::unique_ptr< std::uint8_t[]> readFileFromAndroidAssets(const String &filename, std::size_t &fileSize) const
Uses the AssetManager on Android to read a file and return its contents.
Backend()=default
Default constructor.
Type
List of available cursors.
Definition Cursor.hpp:48
@ Arrow
Arrow cursor (default)
Definition Cursor.hpp:49
Wrapper class to store strings.
Definition String.hpp:94
Namespace that contains all TGUI functions and classes.
Definition AbsoluteOrRelativeValue.hpp:36
Definition Event.hpp:38