TGUI 1.13
Loading...
Searching...
No Matches
Backend.hpp
1
2//
3// TGUI - Texus' Graphical User Interface
4// Copyright (C) 2012-2026 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_HPP
26#define TGUI_BACKEND_HPP
27
28#include <TGUI/Backend/Font/BackendFont.hpp>
29#include <TGUI/Backend/Font/BackendFontFactory.hpp>
30#include <TGUI/Backend/Renderer/BackendRenderer.hpp>
31#include <TGUI/Backend/Renderer/BackendText.hpp>
32#include <TGUI/Backend/Renderer/BackendTexture.hpp>
33
34#include <TGUI/Cursor.hpp>
35#include <TGUI/Event.hpp>
36#include <TGUI/Font.hpp>
37
38#include <cstdint>
39#include <memory>
40#include <set>
41
43
44namespace tgui
45{
46 class Sprite;
47 class Backend;
48 class BackendGui;
49 class BackendRenderer;
51
56 [[nodiscard]] TGUI_API bool isBackendSet();
57
69 TGUI_API void setBackend(std::shared_ptr<Backend> backend);
70
79 TGUI_API std::shared_ptr<Backend> getBackend();
80
84 class TGUI_API Backend
85 {
86 public:
90 Backend() = default;
91
93 // The object cannot be copied
95 Backend(const Backend&) = delete;
96
98 // The object cannot be copied
100 Backend& operator=(const Backend&) = delete;
101
105 virtual ~Backend() = default;
106
114 void setDestroyOnLastGuiDetatch(bool destroyOnDetatch);
115
120 virtual void attachGui(BackendGui* gui);
121
126 virtual void detatchGui(BackendGui* gui);
127
132 [[nodiscard]] virtual Font createDefaultFont();
133
138 [[nodiscard]] std::shared_ptr<BackendFont> createFont();
139
144 [[nodiscard]] std::shared_ptr<BackendText> createText();
145
150 [[nodiscard]] std::shared_ptr<BackendTexture> createTexture();
151
162 void setFontScale(float scale);
163
171 [[nodiscard]] float getFontScale() const;
172
181 virtual void setMouseCursorStyle(Cursor::Type type, const std::uint8_t* pixels, Vector2u size, Vector2u hotspot) = 0;
182
188 virtual void resetMouseCursorStyle(Cursor::Type type) = 0;
189
196 virtual void setMouseCursor(BackendGui* gui, Cursor::Type type) = 0;
197
198#ifndef TGUI_REMOVE_DEPRECATED_CODE
207 TGUI_DEPRECATED("Use BackendGui::startTextInput instead") virtual void openVirtualKeyboard(const FloatRect& inputRect);
208
216 TGUI_DEPRECATED("Use BackendGui::stopTextInput instead") virtual void closeVirtualKeyboard();
217#endif
218
226 TGUI_DEPRECATED("Use gui.isKeyboardModifierPressed(modifierKey) instead")
227 [[nodiscard]] virtual bool isKeyboardModifierPressed(Event::KeyModifier modifierKey);
228
234 virtual void setClipboard(const String& contents);
235
241 [[nodiscard]] virtual String getClipboard() const;
242
251 [[nodiscard]] virtual std::unique_ptr<std::uint8_t[]> readFileFromAndroidAssets(const String& filename,
252 std::size_t& fileSize) const;
253
258 [[nodiscard]] bool hasRenderer() const;
259
268 [[nodiscard]] std::shared_ptr<BackendRenderer> getRenderer() const;
269
275 virtual void setRenderer(std::shared_ptr<BackendRenderer> renderer);
276
281 [[nodiscard]] bool hasFontBackend() const;
282
291 [[nodiscard]] std::shared_ptr<BackendFontFactory> getFontBackend() const;
292
298 virtual void setFontBackend(std::shared_ptr<BackendFontFactory> fontBackend);
299
307 void registerFont(BackendFont* font);
308
316 void unregisterFont(BackendFont* font);
317
325 void registerSvgSprite(Sprite* sprite);
326
334 void unregisterSvgSprite(Sprite* sprite);
335
337
338 protected:
339 bool m_destroyOnLastGuiDetatch = false;
340 String m_clipboardContents;
341 float m_fontScale = 1;
342
343 std::shared_ptr<BackendRenderer> m_renderer;
344 std::shared_ptr<BackendFontFactory> m_fontBackend;
345
346 std::set<BackendGui*> m_guis;
347 std::set<BackendFont*> m_registeredFonts;
348 std::set<Sprite*> m_registeredSvgSprites;
349 };
350
352} // namespace tgui
353
355
356#endif // TGUI_BACKEND_HPP
Base class for the font factory that is responsible for creating a font object specific to the font b...
Definition BackendFontFactory.hpp:40
Base class for font implementations that depend on the backend.
Definition BackendFont.hpp:45
Base class for the Gui.
Definition BackendGui.hpp:45
Base class for the backend renderer, which is responsible for creating text and texture objects.
Definition BackendRenderer.hpp:41
Base class for the backend.
Definition Backend.hpp:85
virtual void setClipboard(const String &contents)
Changes the contents of the clipboard.
std::shared_ptr< BackendFontFactory > getFontBackend() const
Returns the font factory.
std::shared_ptr< BackendFont > createFont()
Creates a new font object.
float getFontScale() const
Returns the scale factor to render text at a higher quality, e.g. to scale for DPI awareness.
virtual void setRenderer(std::shared_ptr< BackendRenderer > renderer)
Sets the renderer that the backend should use.
virtual void setMouseCursorStyle(Cursor::Type type, const std::uint8_t *pixels, Vector2u size, Vector2u hotspot)=0
Changes the look of a certain mouse cursor by using a bitmap.
virtual void setMouseCursor(BackendGui *gui, Cursor::Type type)=0
Changes the mouse cursor when the mouse is on top of the window to which the gui is attached.
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.
virtual void resetMouseCursorStyle(Cursor::Type type)=0
Changes the look of a certain mouse cursor back to the system theme.
virtual String getClipboard() const
Returns the contents of the clipboard.
virtual void closeVirtualKeyboard()
Closes the virtual keyboard on Android and iOS.
virtual void attachGui(BackendGui *gui)
Informs the backend that a new gui object has been created.
virtual ~Backend()=default
Virtual destructor.
virtual void openVirtualKeyboard(const FloatRect &inputRect)
Opens the virtual keyboard on Android and iOS.
virtual void detatchGui(BackendGui *gui)
Informs the backend that a gui object is being destroyed.
std::shared_ptr< BackendTexture > createTexture()
Creates a new texture object.
std::shared_ptr< BackendRenderer > getRenderer() const
Returns the renderer.
std::shared_ptr< BackendText > createText()
Creates a new text object.
virtual void setFontBackend(std::shared_ptr< BackendFontFactory > fontBackend)
Sets the font factory that the backend should use.
bool hasFontBackend() const
Checks whether a font factory has been attached to the backend.
void setDestroyOnLastGuiDetatch(bool destroyOnDetatch)
Informs the backend whether it should destroy itself when the last Gui is detached from it.
void setFontScale(float scale)
Sets the scale factor to render text at a higher quality, e.g. to scale for DPI awareness.
virtual Font createDefaultFont()
Creates and returns the default font for all widgets.
bool hasRenderer() const
Checks whether a renderer has been attached to the backend.
Backend()=default
Default constructor.
virtual bool isKeyboardModifierPressed(Event::KeyModifier modifierKey)
Checks the state for one of the modifier keys.
Type
List of available cursors.
Definition Cursor.hpp:48
Wrapper around the backend-specific font. All copies of the font will share the same internal font re...
Definition Font.hpp:54
Definition Sprite.hpp:45
Wrapper class to store strings.
Definition String.hpp:94
Namespace that contains all TGUI functions and classes.
Definition AbsoluteOrRelativeValue.hpp:37
TGUI_API void setBackend(std::shared_ptr< Backend > backend)
Changes the global backend.
TGUI_API std::shared_ptr< Backend > getBackend()
Returns the global backend.
TGUI_API bool isBackendSet()
Checks whether the backend differs from a nullptr.
KeyModifier
Modifiers keys.
Definition Event.hpp:155