display_server.h 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569
  1. /**************************************************************************/
  2. /* display_server.h */
  3. /**************************************************************************/
  4. /* This file is part of: */
  5. /* GODOT ENGINE */
  6. /* https://godotengine.org */
  7. /**************************************************************************/
  8. /* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */
  9. /* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur. */
  10. /* */
  11. /* Permission is hereby granted, free of charge, to any person obtaining */
  12. /* a copy of this software and associated documentation files (the */
  13. /* "Software"), to deal in the Software without restriction, including */
  14. /* without limitation the rights to use, copy, modify, merge, publish, */
  15. /* distribute, sublicense, and/or sell copies of the Software, and to */
  16. /* permit persons to whom the Software is furnished to do so, subject to */
  17. /* the following conditions: */
  18. /* */
  19. /* The above copyright notice and this permission notice shall be */
  20. /* included in all copies or substantial portions of the Software. */
  21. /* */
  22. /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
  23. /* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
  24. /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. */
  25. /* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
  26. /* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
  27. /* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
  28. /* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
  29. /**************************************************************************/
  30. #ifndef DISPLAY_SERVER_H
  31. #define DISPLAY_SERVER_H
  32. #include "core/input/input.h"
  33. #include "core/io/resource.h"
  34. #include "core/os/os.h"
  35. #include "core/variant/callable.h"
  36. class Texture2D;
  37. class DisplayServer : public Object {
  38. GDCLASS(DisplayServer, Object)
  39. static DisplayServer *singleton;
  40. static bool hidpi_allowed;
  41. public:
  42. _FORCE_INLINE_ static DisplayServer *get_singleton() {
  43. return singleton;
  44. }
  45. enum WindowMode {
  46. WINDOW_MODE_WINDOWED,
  47. WINDOW_MODE_MINIMIZED,
  48. WINDOW_MODE_MAXIMIZED,
  49. WINDOW_MODE_FULLSCREEN,
  50. WINDOW_MODE_EXCLUSIVE_FULLSCREEN,
  51. };
  52. // Keep the VSyncMode enum values in sync with the `display/window/vsync/vsync_mode`
  53. // project setting hint.
  54. enum VSyncMode {
  55. VSYNC_DISABLED,
  56. VSYNC_ENABLED,
  57. VSYNC_ADAPTIVE,
  58. VSYNC_MAILBOX
  59. };
  60. enum HandleType {
  61. DISPLAY_HANDLE,
  62. WINDOW_HANDLE,
  63. WINDOW_VIEW,
  64. OPENGL_CONTEXT,
  65. };
  66. typedef DisplayServer *(*CreateFunction)(const String &, WindowMode, VSyncMode, uint32_t, const Point2i *, const Size2i &, int p_screen, Error &r_error);
  67. typedef Vector<String> (*GetRenderingDriversFunction)();
  68. private:
  69. static void _input_set_mouse_mode(Input::MouseMode p_mode);
  70. static Input::MouseMode _input_get_mouse_mode();
  71. static void _input_warp(const Vector2 &p_to_pos);
  72. static Input::CursorShape _input_get_current_cursor_shape();
  73. static void _input_set_custom_mouse_cursor_func(const Ref<Resource> &, Input::CursorShape, const Vector2 &p_hostspot);
  74. protected:
  75. static void _bind_methods();
  76. enum {
  77. MAX_SERVERS = 64
  78. };
  79. struct DisplayServerCreate {
  80. const char *name;
  81. CreateFunction create_function;
  82. GetRenderingDriversFunction get_rendering_drivers_function;
  83. };
  84. static DisplayServerCreate server_create_functions[MAX_SERVERS];
  85. static int server_create_count;
  86. friend class RendererViewport;
  87. public:
  88. enum Feature {
  89. FEATURE_GLOBAL_MENU,
  90. FEATURE_SUBWINDOWS,
  91. FEATURE_TOUCHSCREEN,
  92. FEATURE_MOUSE,
  93. FEATURE_MOUSE_WARP,
  94. FEATURE_CLIPBOARD,
  95. FEATURE_VIRTUAL_KEYBOARD,
  96. FEATURE_CURSOR_SHAPE,
  97. FEATURE_CUSTOM_CURSOR_SHAPE,
  98. FEATURE_NATIVE_DIALOG,
  99. FEATURE_IME,
  100. FEATURE_WINDOW_TRANSPARENCY,
  101. FEATURE_HIDPI,
  102. FEATURE_ICON,
  103. FEATURE_NATIVE_ICON,
  104. FEATURE_ORIENTATION,
  105. FEATURE_SWAP_BUFFERS,
  106. FEATURE_KEEP_SCREEN_ON,
  107. FEATURE_CLIPBOARD_PRIMARY,
  108. FEATURE_TEXT_TO_SPEECH,
  109. FEATURE_EXTEND_TO_TITLE,
  110. FEATURE_SCREEN_CAPTURE,
  111. };
  112. virtual bool has_feature(Feature p_feature) const = 0;
  113. virtual String get_name() const = 0;
  114. virtual void global_menu_set_popup_callbacks(const String &p_menu_root, const Callable &p_open_callback = Callable(), const Callable &p_close_callback = Callable());
  115. virtual int global_menu_add_submenu_item(const String &p_menu_root, const String &p_label, const String &p_submenu, int p_index = -1);
  116. virtual int global_menu_add_item(const String &p_menu_root, const String &p_label, const Callable &p_callback = Callable(), const Callable &p_key_callback = Callable(), const Variant &p_tag = Variant(), Key p_accel = Key::NONE, int p_index = -1);
  117. virtual int global_menu_add_check_item(const String &p_menu_root, const String &p_label, const Callable &p_callback = Callable(), const Callable &p_key_callback = Callable(), const Variant &p_tag = Variant(), Key p_accel = Key::NONE, int p_index = -1);
  118. virtual int global_menu_add_icon_item(const String &p_menu_root, const Ref<Texture2D> &p_icon, const String &p_label, const Callable &p_callback = Callable(), const Callable &p_key_callback = Callable(), const Variant &p_tag = Variant(), Key p_accel = Key::NONE, int p_index = -1);
  119. virtual int global_menu_add_icon_check_item(const String &p_menu_root, const Ref<Texture2D> &p_icon, const String &p_label, const Callable &p_callback = Callable(), const Callable &p_key_callback = Callable(), const Variant &p_tag = Variant(), Key p_accel = Key::NONE, int p_index = -1);
  120. virtual int global_menu_add_radio_check_item(const String &p_menu_root, const String &p_label, const Callable &p_callback = Callable(), const Callable &p_key_callback = Callable(), const Variant &p_tag = Variant(), Key p_accel = Key::NONE, int p_index = -1);
  121. virtual int global_menu_add_icon_radio_check_item(const String &p_menu_root, const Ref<Texture2D> &p_icon, const String &p_label, const Callable &p_callback = Callable(), const Callable &p_key_callback = Callable(), const Variant &p_tag = Variant(), Key p_accel = Key::NONE, int p_index = -1);
  122. virtual int global_menu_add_multistate_item(const String &p_menu_root, const String &p_label, int p_max_states, int p_default_state, const Callable &p_callback = Callable(), const Callable &p_key_callback = Callable(), const Variant &p_tag = Variant(), Key p_accel = Key::NONE, int p_index = -1);
  123. virtual int global_menu_add_separator(const String &p_menu_root, int p_index = -1);
  124. virtual int global_menu_get_item_index_from_text(const String &p_menu_root, const String &p_text) const;
  125. virtual int global_menu_get_item_index_from_tag(const String &p_menu_root, const Variant &p_tag) const;
  126. virtual bool global_menu_is_item_checked(const String &p_menu_root, int p_idx) const;
  127. virtual bool global_menu_is_item_checkable(const String &p_menu_root, int p_idx) const;
  128. virtual bool global_menu_is_item_radio_checkable(const String &p_menu_root, int p_idx) const;
  129. virtual Callable global_menu_get_item_callback(const String &p_menu_root, int p_idx) const;
  130. virtual Callable global_menu_get_item_key_callback(const String &p_menu_root, int p_idx) const;
  131. virtual Variant global_menu_get_item_tag(const String &p_menu_root, int p_idx) const;
  132. virtual String global_menu_get_item_text(const String &p_menu_root, int p_idx) const;
  133. virtual String global_menu_get_item_submenu(const String &p_menu_root, int p_idx) const;
  134. virtual Key global_menu_get_item_accelerator(const String &p_menu_root, int p_idx) const;
  135. virtual bool global_menu_is_item_disabled(const String &p_menu_root, int p_idx) const;
  136. virtual bool global_menu_is_item_hidden(const String &p_menu_root, int p_idx) const;
  137. virtual String global_menu_get_item_tooltip(const String &p_menu_root, int p_idx) const;
  138. virtual int global_menu_get_item_state(const String &p_menu_root, int p_idx) const;
  139. virtual int global_menu_get_item_max_states(const String &p_menu_root, int p_idx) const;
  140. virtual Ref<Texture2D> global_menu_get_item_icon(const String &p_menu_root, int p_idx) const;
  141. virtual int global_menu_get_item_indentation_level(const String &p_menu_root, int p_idx) const;
  142. virtual void global_menu_set_item_checked(const String &p_menu_root, int p_idx, bool p_checked);
  143. virtual void global_menu_set_item_checkable(const String &p_menu_root, int p_idx, bool p_checkable);
  144. virtual void global_menu_set_item_radio_checkable(const String &p_menu_root, int p_idx, bool p_checkable);
  145. virtual void global_menu_set_item_callback(const String &p_menu_root, int p_idx, const Callable &p_callback);
  146. virtual void global_menu_set_item_key_callback(const String &p_menu_root, int p_idx, const Callable &p_key_callback);
  147. virtual void global_menu_set_item_hover_callbacks(const String &p_menu_root, int p_idx, const Callable &p_callback);
  148. virtual void global_menu_set_item_tag(const String &p_menu_root, int p_idx, const Variant &p_tag);
  149. virtual void global_menu_set_item_text(const String &p_menu_root, int p_idx, const String &p_text);
  150. virtual void global_menu_set_item_submenu(const String &p_menu_root, int p_idx, const String &p_submenu);
  151. virtual void global_menu_set_item_accelerator(const String &p_menu_root, int p_idx, Key p_keycode);
  152. virtual void global_menu_set_item_disabled(const String &p_menu_root, int p_idx, bool p_disabled);
  153. virtual void global_menu_set_item_hidden(const String &p_menu_root, int p_idx, bool p_hidden);
  154. virtual void global_menu_set_item_tooltip(const String &p_menu_root, int p_idx, const String &p_tooltip);
  155. virtual void global_menu_set_item_state(const String &p_menu_root, int p_idx, int p_state);
  156. virtual void global_menu_set_item_max_states(const String &p_menu_root, int p_idx, int p_max_states);
  157. virtual void global_menu_set_item_icon(const String &p_menu_root, int p_idx, const Ref<Texture2D> &p_icon);
  158. virtual void global_menu_set_item_indentation_level(const String &p_menu_root, int p_idx, int p_level);
  159. virtual int global_menu_get_item_count(const String &p_menu_root) const;
  160. virtual void global_menu_remove_item(const String &p_menu_root, int p_idx);
  161. virtual void global_menu_clear(const String &p_menu_root);
  162. struct TTSUtterance {
  163. String text;
  164. String voice;
  165. int volume = 50;
  166. float pitch = 1.f;
  167. float rate = 1.f;
  168. int id = 0;
  169. };
  170. enum TTSUtteranceEvent {
  171. TTS_UTTERANCE_STARTED,
  172. TTS_UTTERANCE_ENDED,
  173. TTS_UTTERANCE_CANCELED,
  174. TTS_UTTERANCE_BOUNDARY,
  175. TTS_UTTERANCE_MAX,
  176. };
  177. private:
  178. Callable utterance_callback[TTS_UTTERANCE_MAX];
  179. public:
  180. virtual bool tts_is_speaking() const;
  181. virtual bool tts_is_paused() const;
  182. virtual TypedArray<Dictionary> tts_get_voices() const;
  183. virtual PackedStringArray tts_get_voices_for_language(const String &p_language) const;
  184. virtual void tts_speak(const String &p_text, const String &p_voice, int p_volume = 50, float p_pitch = 1.f, float p_rate = 1.f, int p_utterance_id = 0, bool p_interrupt = false);
  185. virtual void tts_pause();
  186. virtual void tts_resume();
  187. virtual void tts_stop();
  188. virtual void tts_set_utterance_callback(TTSUtteranceEvent p_event, const Callable &p_callable);
  189. virtual void tts_post_utterance_event(TTSUtteranceEvent p_event, int p_id, int p_pos = 0);
  190. virtual bool is_dark_mode_supported() const { return false; };
  191. virtual bool is_dark_mode() const { return false; };
  192. virtual Color get_accent_color() const { return Color(0, 0, 0, 0); };
  193. private:
  194. static bool window_early_clear_override_enabled;
  195. static Color window_early_clear_override_color;
  196. protected:
  197. static bool _get_window_early_clear_override(Color &r_color);
  198. public:
  199. static void set_early_window_clear_color_override(bool p_enabled, Color p_color = Color(0, 0, 0, 0));
  200. enum MouseMode {
  201. MOUSE_MODE_VISIBLE,
  202. MOUSE_MODE_HIDDEN,
  203. MOUSE_MODE_CAPTURED,
  204. MOUSE_MODE_CONFINED,
  205. MOUSE_MODE_CONFINED_HIDDEN,
  206. };
  207. virtual void mouse_set_mode(MouseMode p_mode);
  208. virtual MouseMode mouse_get_mode() const;
  209. virtual void warp_mouse(const Point2i &p_position);
  210. virtual Point2i mouse_get_position() const;
  211. virtual BitField<MouseButtonMask> mouse_get_button_state() const;
  212. virtual void clipboard_set(const String &p_text);
  213. virtual String clipboard_get() const;
  214. virtual Ref<Image> clipboard_get_image() const;
  215. virtual bool clipboard_has() const;
  216. virtual bool clipboard_has_image() const;
  217. virtual void clipboard_set_primary(const String &p_text);
  218. virtual String clipboard_get_primary() const;
  219. virtual TypedArray<Rect2> get_display_cutouts() const { return TypedArray<Rect2>(); }
  220. virtual Rect2i get_display_safe_area() const { return screen_get_usable_rect(); }
  221. enum {
  222. SCREEN_WITH_MOUSE_FOCUS = -4,
  223. SCREEN_WITH_KEYBOARD_FOCUS = -3,
  224. SCREEN_PRIMARY = -2,
  225. SCREEN_OF_MAIN_WINDOW = -1, // Note: for the main window, determine screen from position.
  226. };
  227. const float SCREEN_REFRESH_RATE_FALLBACK = -1.0; // Returned by screen_get_refresh_rate if the method fails.
  228. int _get_screen_index(int p_screen) const {
  229. switch (p_screen) {
  230. case SCREEN_WITH_MOUSE_FOCUS: {
  231. const Rect2i rect = Rect2i(mouse_get_position(), Vector2i(1, 1));
  232. return get_screen_from_rect(rect);
  233. } break;
  234. case SCREEN_WITH_KEYBOARD_FOCUS: {
  235. return get_keyboard_focus_screen();
  236. } break;
  237. case SCREEN_PRIMARY: {
  238. return get_primary_screen();
  239. } break;
  240. case SCREEN_OF_MAIN_WINDOW: {
  241. return window_get_current_screen(MAIN_WINDOW_ID);
  242. } break;
  243. default: {
  244. return p_screen;
  245. } break;
  246. }
  247. }
  248. virtual int get_screen_count() const = 0;
  249. virtual int get_primary_screen() const = 0;
  250. virtual int get_keyboard_focus_screen() const { return get_primary_screen(); }
  251. virtual int get_screen_from_rect(const Rect2 &p_rect) const;
  252. virtual Point2i screen_get_position(int p_screen = SCREEN_OF_MAIN_WINDOW) const = 0;
  253. virtual Size2i screen_get_size(int p_screen = SCREEN_OF_MAIN_WINDOW) const = 0;
  254. virtual Rect2i screen_get_usable_rect(int p_screen = SCREEN_OF_MAIN_WINDOW) const = 0;
  255. virtual int screen_get_dpi(int p_screen = SCREEN_OF_MAIN_WINDOW) const = 0;
  256. virtual float screen_get_scale(int p_screen = SCREEN_OF_MAIN_WINDOW) const;
  257. virtual float screen_get_max_scale() const {
  258. float scale = 1.f;
  259. int screen_count = get_screen_count();
  260. for (int i = 0; i < screen_count; i++) {
  261. scale = fmax(scale, screen_get_scale(i));
  262. }
  263. return scale;
  264. }
  265. virtual float screen_get_refresh_rate(int p_screen = SCREEN_OF_MAIN_WINDOW) const = 0;
  266. virtual Color screen_get_pixel(const Point2i &p_position) const { return Color(); };
  267. virtual Ref<Image> screen_get_image(int p_screen = SCREEN_OF_MAIN_WINDOW) const { return Ref<Image>(); };
  268. virtual bool is_touchscreen_available() const;
  269. // Keep the ScreenOrientation enum values in sync with the `display/window/handheld/orientation`
  270. // project setting hint.
  271. enum ScreenOrientation {
  272. SCREEN_LANDSCAPE,
  273. SCREEN_PORTRAIT,
  274. SCREEN_REVERSE_LANDSCAPE,
  275. SCREEN_REVERSE_PORTRAIT,
  276. SCREEN_SENSOR_LANDSCAPE,
  277. SCREEN_SENSOR_PORTRAIT,
  278. SCREEN_SENSOR,
  279. };
  280. virtual void screen_set_orientation(ScreenOrientation p_orientation, int p_screen = SCREEN_OF_MAIN_WINDOW);
  281. virtual ScreenOrientation screen_get_orientation(int p_screen = SCREEN_OF_MAIN_WINDOW) const;
  282. virtual void screen_set_keep_on(bool p_enable); //disable screensaver
  283. virtual bool screen_is_kept_on() const;
  284. enum {
  285. MAIN_WINDOW_ID = 0,
  286. INVALID_WINDOW_ID = -1
  287. };
  288. typedef int WindowID;
  289. virtual Vector<DisplayServer::WindowID> get_window_list() const = 0;
  290. enum WindowFlags {
  291. WINDOW_FLAG_RESIZE_DISABLED,
  292. WINDOW_FLAG_BORDERLESS,
  293. WINDOW_FLAG_ALWAYS_ON_TOP,
  294. WINDOW_FLAG_TRANSPARENT,
  295. WINDOW_FLAG_NO_FOCUS,
  296. WINDOW_FLAG_POPUP,
  297. WINDOW_FLAG_EXTEND_TO_TITLE,
  298. WINDOW_FLAG_MOUSE_PASSTHROUGH,
  299. WINDOW_FLAG_MAX,
  300. };
  301. // Separate enum otherwise we get warnings in switches not handling all values.
  302. enum WindowFlagsBit {
  303. WINDOW_FLAG_RESIZE_DISABLED_BIT = (1 << WINDOW_FLAG_RESIZE_DISABLED),
  304. WINDOW_FLAG_BORDERLESS_BIT = (1 << WINDOW_FLAG_BORDERLESS),
  305. WINDOW_FLAG_ALWAYS_ON_TOP_BIT = (1 << WINDOW_FLAG_ALWAYS_ON_TOP),
  306. WINDOW_FLAG_TRANSPARENT_BIT = (1 << WINDOW_FLAG_TRANSPARENT),
  307. WINDOW_FLAG_NO_FOCUS_BIT = (1 << WINDOW_FLAG_NO_FOCUS),
  308. WINDOW_FLAG_POPUP_BIT = (1 << WINDOW_FLAG_POPUP),
  309. WINDOW_FLAG_EXTEND_TO_TITLE_BIT = (1 << WINDOW_FLAG_EXTEND_TO_TITLE),
  310. WINDOW_FLAG_MOUSE_PASSTHROUGH_BIT = (1 << WINDOW_FLAG_MOUSE_PASSTHROUGH),
  311. };
  312. virtual WindowID create_sub_window(WindowMode p_mode, VSyncMode p_vsync_mode, uint32_t p_flags, const Rect2i &p_rect = Rect2i());
  313. virtual void show_window(WindowID p_id);
  314. virtual void delete_sub_window(WindowID p_id);
  315. virtual WindowID window_get_active_popup() const { return INVALID_WINDOW_ID; };
  316. virtual void window_set_popup_safe_rect(WindowID p_window, const Rect2i &p_rect){};
  317. virtual Rect2i window_get_popup_safe_rect(WindowID p_window) const { return Rect2i(); };
  318. virtual int64_t window_get_native_handle(HandleType p_handle_type, WindowID p_window = MAIN_WINDOW_ID) const;
  319. virtual WindowID get_window_at_screen_position(const Point2i &p_position) const = 0;
  320. virtual void window_attach_instance_id(ObjectID p_instance, WindowID p_window = MAIN_WINDOW_ID) = 0;
  321. virtual ObjectID window_get_attached_instance_id(WindowID p_window = MAIN_WINDOW_ID) const = 0;
  322. virtual void window_set_rect_changed_callback(const Callable &p_callable, WindowID p_window = MAIN_WINDOW_ID) = 0;
  323. enum WindowEvent {
  324. WINDOW_EVENT_MOUSE_ENTER,
  325. WINDOW_EVENT_MOUSE_EXIT,
  326. WINDOW_EVENT_FOCUS_IN,
  327. WINDOW_EVENT_FOCUS_OUT,
  328. WINDOW_EVENT_CLOSE_REQUEST,
  329. WINDOW_EVENT_GO_BACK_REQUEST,
  330. WINDOW_EVENT_DPI_CHANGE,
  331. WINDOW_EVENT_TITLEBAR_CHANGE,
  332. };
  333. virtual void window_set_window_event_callback(const Callable &p_callable, WindowID p_window = MAIN_WINDOW_ID) = 0;
  334. virtual void window_set_input_event_callback(const Callable &p_callable, WindowID p_window = MAIN_WINDOW_ID) = 0;
  335. virtual void window_set_input_text_callback(const Callable &p_callable, WindowID p_window = MAIN_WINDOW_ID) = 0;
  336. virtual void window_set_drop_files_callback(const Callable &p_callable, WindowID p_window = MAIN_WINDOW_ID) = 0;
  337. virtual void window_set_title(const String &p_title, WindowID p_window = MAIN_WINDOW_ID) = 0;
  338. virtual Size2i window_get_title_size(const String &p_title, WindowID p_window = MAIN_WINDOW_ID) const { return Size2i(); }
  339. virtual void window_set_mouse_passthrough(const Vector<Vector2> &p_region, WindowID p_window = MAIN_WINDOW_ID);
  340. virtual int window_get_current_screen(WindowID p_window = MAIN_WINDOW_ID) const = 0;
  341. virtual void window_set_current_screen(int p_screen, WindowID p_window = MAIN_WINDOW_ID) = 0;
  342. virtual Point2i window_get_position(WindowID p_window = MAIN_WINDOW_ID) const = 0;
  343. virtual Point2i window_get_position_with_decorations(WindowID p_window = MAIN_WINDOW_ID) const = 0;
  344. virtual void window_set_position(const Point2i &p_position, WindowID p_window = MAIN_WINDOW_ID) = 0;
  345. virtual void window_set_transient(WindowID p_window, WindowID p_parent) = 0;
  346. virtual void window_set_exclusive(WindowID p_window, bool p_exclusive);
  347. virtual void window_set_max_size(const Size2i p_size, WindowID p_window = MAIN_WINDOW_ID) = 0;
  348. virtual Size2i window_get_max_size(WindowID p_window = MAIN_WINDOW_ID) const = 0;
  349. virtual void window_set_min_size(const Size2i p_size, WindowID p_window = MAIN_WINDOW_ID) = 0;
  350. virtual Size2i window_get_min_size(WindowID p_window = MAIN_WINDOW_ID) const = 0;
  351. virtual void window_set_size(const Size2i p_size, WindowID p_window = MAIN_WINDOW_ID) = 0;
  352. virtual Size2i window_get_size(WindowID p_window = MAIN_WINDOW_ID) const = 0;
  353. virtual Size2i window_get_size_with_decorations(WindowID p_window = MAIN_WINDOW_ID) const = 0;
  354. virtual void window_set_mode(WindowMode p_mode, WindowID p_window = MAIN_WINDOW_ID) = 0;
  355. virtual WindowMode window_get_mode(WindowID p_window = MAIN_WINDOW_ID) const = 0;
  356. virtual void window_set_vsync_mode(VSyncMode p_vsync_mode, WindowID p_window = MAIN_WINDOW_ID);
  357. virtual VSyncMode window_get_vsync_mode(WindowID p_window) const;
  358. virtual bool window_is_maximize_allowed(WindowID p_window = MAIN_WINDOW_ID) const = 0;
  359. virtual void window_set_flag(WindowFlags p_flag, bool p_enabled, WindowID p_window = MAIN_WINDOW_ID) = 0;
  360. virtual bool window_get_flag(WindowFlags p_flag, WindowID p_window = MAIN_WINDOW_ID) const = 0;
  361. virtual void window_request_attention(WindowID p_window = MAIN_WINDOW_ID) = 0;
  362. virtual void window_move_to_foreground(WindowID p_window = MAIN_WINDOW_ID) = 0;
  363. virtual bool window_is_focused(WindowID p_window = MAIN_WINDOW_ID) const = 0;
  364. virtual void window_set_window_buttons_offset(const Vector2i &p_offset, WindowID p_window = MAIN_WINDOW_ID) {}
  365. virtual Vector3i window_get_safe_title_margins(WindowID p_window = MAIN_WINDOW_ID) const { return Vector3i(); }
  366. virtual bool window_can_draw(WindowID p_window = MAIN_WINDOW_ID) const = 0;
  367. virtual bool can_any_window_draw() const = 0;
  368. virtual void window_set_ime_active(const bool p_active, WindowID p_window = MAIN_WINDOW_ID);
  369. virtual void window_set_ime_position(const Point2i &p_pos, WindowID p_window = MAIN_WINDOW_ID);
  370. virtual bool window_maximize_on_title_dbl_click() const { return false; }
  371. virtual bool window_minimize_on_title_dbl_click() const { return false; }
  372. // necessary for GL focus, may be able to use one of the existing functions for this, not sure yet
  373. virtual void gl_window_make_current(DisplayServer::WindowID p_window_id);
  374. virtual Point2i ime_get_selection() const;
  375. virtual String ime_get_text() const;
  376. enum VirtualKeyboardType {
  377. KEYBOARD_TYPE_DEFAULT,
  378. KEYBOARD_TYPE_MULTILINE,
  379. KEYBOARD_TYPE_NUMBER,
  380. KEYBOARD_TYPE_NUMBER_DECIMAL,
  381. KEYBOARD_TYPE_PHONE,
  382. KEYBOARD_TYPE_EMAIL_ADDRESS,
  383. KEYBOARD_TYPE_PASSWORD,
  384. KEYBOARD_TYPE_URL
  385. };
  386. virtual void virtual_keyboard_show(const String &p_existing_text, const Rect2 &p_screen_rect = Rect2(), VirtualKeyboardType p_type = KEYBOARD_TYPE_DEFAULT, int p_max_length = -1, int p_cursor_start = -1, int p_cursor_end = -1);
  387. virtual void virtual_keyboard_hide();
  388. // returns height of the currently shown virtual keyboard (0 if keyboard is hidden)
  389. virtual int virtual_keyboard_get_height() const;
  390. enum CursorShape {
  391. CURSOR_ARROW,
  392. CURSOR_IBEAM,
  393. CURSOR_POINTING_HAND,
  394. CURSOR_CROSS,
  395. CURSOR_WAIT,
  396. CURSOR_BUSY,
  397. CURSOR_DRAG,
  398. CURSOR_CAN_DROP,
  399. CURSOR_FORBIDDEN,
  400. CURSOR_VSIZE,
  401. CURSOR_HSIZE,
  402. CURSOR_BDIAGSIZE,
  403. CURSOR_FDIAGSIZE,
  404. CURSOR_MOVE,
  405. CURSOR_VSPLIT,
  406. CURSOR_HSPLIT,
  407. CURSOR_HELP,
  408. CURSOR_MAX
  409. };
  410. virtual void cursor_set_shape(CursorShape p_shape);
  411. virtual CursorShape cursor_get_shape() const;
  412. virtual void cursor_set_custom_image(const Ref<Resource> &p_cursor, CursorShape p_shape = CURSOR_ARROW, const Vector2 &p_hotspot = Vector2());
  413. virtual bool get_swap_cancel_ok();
  414. virtual void enable_for_stealing_focus(OS::ProcessID pid);
  415. virtual Error dialog_show(String p_title, String p_description, Vector<String> p_buttons, const Callable &p_callback);
  416. virtual Error dialog_input_text(String p_title, String p_description, String p_partial, const Callable &p_callback);
  417. enum FileDialogMode {
  418. FILE_DIALOG_MODE_OPEN_FILE,
  419. FILE_DIALOG_MODE_OPEN_FILES,
  420. FILE_DIALOG_MODE_OPEN_DIR,
  421. FILE_DIALOG_MODE_OPEN_ANY,
  422. FILE_DIALOG_MODE_SAVE_FILE,
  423. FILE_DIALOG_MODE_SAVE_MAX
  424. };
  425. virtual Error file_dialog_show(const String &p_title, const String &p_current_directory, const String &p_filename, bool p_show_hidden, FileDialogMode p_mode, const Vector<String> &p_filters, const Callable &p_callback);
  426. virtual int keyboard_get_layout_count() const;
  427. virtual int keyboard_get_current_layout() const;
  428. virtual void keyboard_set_current_layout(int p_index);
  429. virtual String keyboard_get_layout_language(int p_index) const;
  430. virtual String keyboard_get_layout_name(int p_index) const;
  431. virtual Key keyboard_get_keycode_from_physical(Key p_keycode) const;
  432. virtual Key keyboard_get_label_from_physical(Key p_keycode) const;
  433. virtual int tablet_get_driver_count() const { return 1; };
  434. virtual String tablet_get_driver_name(int p_driver) const { return "default"; };
  435. virtual String tablet_get_current_driver() const { return "default"; };
  436. virtual void tablet_set_current_driver(const String &p_driver){};
  437. virtual void process_events() = 0;
  438. virtual void force_process_and_drop_events();
  439. virtual void release_rendering_thread();
  440. virtual void make_rendering_thread();
  441. virtual void swap_buffers();
  442. virtual void set_native_icon(const String &p_filename);
  443. virtual void set_icon(const Ref<Image> &p_icon);
  444. enum Context {
  445. CONTEXT_EDITOR,
  446. CONTEXT_PROJECTMAN,
  447. CONTEXT_ENGINE,
  448. };
  449. virtual void set_context(Context p_context);
  450. static void register_create_function(const char *p_name, CreateFunction p_function, GetRenderingDriversFunction p_get_drivers);
  451. static int get_create_function_count();
  452. static const char *get_create_function_name(int p_index);
  453. static Vector<String> get_create_function_rendering_drivers(int p_index);
  454. static DisplayServer *create(int p_index, const String &p_rendering_driver, WindowMode p_mode, VSyncMode p_vsync_mode, uint32_t p_flags, const Vector2i *p_position, const Vector2i &p_resolution, int p_screen, Error &r_error);
  455. DisplayServer();
  456. ~DisplayServer();
  457. };
  458. VARIANT_ENUM_CAST(DisplayServer::WindowEvent)
  459. VARIANT_ENUM_CAST(DisplayServer::Feature)
  460. VARIANT_ENUM_CAST(DisplayServer::MouseMode)
  461. VARIANT_ENUM_CAST(DisplayServer::ScreenOrientation)
  462. VARIANT_ENUM_CAST(DisplayServer::WindowMode)
  463. VARIANT_ENUM_CAST(DisplayServer::WindowFlags)
  464. VARIANT_ENUM_CAST(DisplayServer::HandleType)
  465. VARIANT_ENUM_CAST(DisplayServer::VirtualKeyboardType);
  466. VARIANT_ENUM_CAST(DisplayServer::CursorShape)
  467. VARIANT_ENUM_CAST(DisplayServer::VSyncMode)
  468. VARIANT_ENUM_CAST(DisplayServer::TTSUtteranceEvent)
  469. VARIANT_ENUM_CAST(DisplayServer::FileDialogMode)
  470. #endif // DISPLAY_SERVER_H