2020-03-04 09:51:12 +08:00
|
|
|
/*************************************************************************/
|
|
|
|
/* window.h */
|
|
|
|
/*************************************************************************/
|
|
|
|
/* This file is part of: */
|
|
|
|
/* GODOT ENGINE */
|
|
|
|
/* https://godotengine.org */
|
|
|
|
/*************************************************************************/
|
2022-01-04 04:27:34 +08:00
|
|
|
/* Copyright (c) 2007-2022 Juan Linietsky, Ariel Manzur. */
|
|
|
|
/* Copyright (c) 2014-2022 Godot Engine contributors (cf. AUTHORS.md). */
|
2020-03-04 09:51:12 +08:00
|
|
|
/* */
|
|
|
|
/* Permission is hereby granted, free of charge, to any person obtaining */
|
|
|
|
/* a copy of this software and associated documentation files (the */
|
|
|
|
/* "Software"), to deal in the Software without restriction, including */
|
|
|
|
/* without limitation the rights to use, copy, modify, merge, publish, */
|
|
|
|
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
|
|
|
/* permit persons to whom the Software is furnished to do so, subject to */
|
|
|
|
/* the following conditions: */
|
|
|
|
/* */
|
|
|
|
/* The above copyright notice and this permission notice shall be */
|
|
|
|
/* included in all copies or substantial portions of the Software. */
|
|
|
|
/* */
|
|
|
|
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
|
|
|
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
|
|
|
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
|
|
|
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
|
|
|
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
|
|
|
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
|
|
|
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
|
|
|
/*************************************************************************/
|
|
|
|
|
|
|
|
#ifndef WINDOW_H
|
|
|
|
#define WINDOW_H
|
|
|
|
|
|
|
|
#include "scene/main/viewport.h"
|
|
|
|
|
2020-03-07 01:00:16 +08:00
|
|
|
class Control;
|
2021-08-13 07:05:59 +08:00
|
|
|
class Font;
|
2022-08-30 19:32:34 +08:00
|
|
|
class Shortcut;
|
2021-08-13 07:05:59 +08:00
|
|
|
class StyleBox;
|
|
|
|
class Theme;
|
|
|
|
|
2020-03-04 09:51:12 +08:00
|
|
|
class Window : public Viewport {
|
|
|
|
GDCLASS(Window, Viewport)
|
|
|
|
public:
|
|
|
|
enum Mode {
|
|
|
|
MODE_WINDOWED = DisplayServer::WINDOW_MODE_WINDOWED,
|
|
|
|
MODE_MINIMIZED = DisplayServer::WINDOW_MODE_MINIMIZED,
|
|
|
|
MODE_MAXIMIZED = DisplayServer::WINDOW_MODE_MAXIMIZED,
|
2020-03-31 17:56:58 +08:00
|
|
|
MODE_FULLSCREEN = DisplayServer::WINDOW_MODE_FULLSCREEN,
|
2022-01-28 17:19:53 +08:00
|
|
|
MODE_EXCLUSIVE_FULLSCREEN = DisplayServer::WINDOW_MODE_EXCLUSIVE_FULLSCREEN,
|
2020-03-04 09:51:12 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
enum Flags {
|
|
|
|
FLAG_RESIZE_DISABLED = DisplayServer::WINDOW_FLAG_RESIZE_DISABLED,
|
|
|
|
FLAG_BORDERLESS = DisplayServer::WINDOW_FLAG_BORDERLESS,
|
|
|
|
FLAG_ALWAYS_ON_TOP = DisplayServer::WINDOW_FLAG_ALWAYS_ON_TOP,
|
|
|
|
FLAG_TRANSPARENT = DisplayServer::WINDOW_FLAG_TRANSPARENT,
|
2020-03-21 04:51:53 +08:00
|
|
|
FLAG_NO_FOCUS = DisplayServer::WINDOW_FLAG_NO_FOCUS,
|
2022-02-24 17:21:23 +08:00
|
|
|
FLAG_POPUP = DisplayServer::WINDOW_FLAG_POPUP,
|
2022-08-23 18:40:48 +08:00
|
|
|
FLAG_EXTEND_TO_TITLE = DisplayServer::WINDOW_FLAG_EXTEND_TO_TITLE,
|
2020-03-04 09:51:12 +08:00
|
|
|
FLAG_MAX = DisplayServer::WINDOW_FLAG_MAX,
|
|
|
|
};
|
|
|
|
|
|
|
|
enum ContentScaleMode {
|
|
|
|
CONTENT_SCALE_MODE_DISABLED,
|
2020-07-03 04:15:11 +08:00
|
|
|
CONTENT_SCALE_MODE_CANVAS_ITEMS,
|
|
|
|
CONTENT_SCALE_MODE_VIEWPORT,
|
2020-03-04 09:51:12 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
enum ContentScaleAspect {
|
|
|
|
CONTENT_SCALE_ASPECT_IGNORE,
|
|
|
|
CONTENT_SCALE_ASPECT_KEEP,
|
|
|
|
CONTENT_SCALE_ASPECT_KEEP_WIDTH,
|
|
|
|
CONTENT_SCALE_ASPECT_KEEP_HEIGHT,
|
|
|
|
CONTENT_SCALE_ASPECT_EXPAND,
|
|
|
|
};
|
2020-03-31 17:56:58 +08:00
|
|
|
|
2020-09-03 19:22:16 +08:00
|
|
|
enum LayoutDirection {
|
|
|
|
LAYOUT_DIRECTION_INHERITED,
|
|
|
|
LAYOUT_DIRECTION_LOCALE,
|
|
|
|
LAYOUT_DIRECTION_LTR,
|
|
|
|
LAYOUT_DIRECTION_RTL
|
|
|
|
};
|
|
|
|
|
2020-03-04 09:51:12 +08:00
|
|
|
enum {
|
2020-03-31 17:56:58 +08:00
|
|
|
DEFAULT_WINDOW_SIZE = 100,
|
2020-03-04 09:51:12 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
private:
|
|
|
|
DisplayServer::WindowID window_id = DisplayServer::INVALID_WINDOW_ID;
|
|
|
|
|
|
|
|
String title;
|
|
|
|
mutable int current_screen = 0;
|
|
|
|
mutable Vector2i position;
|
|
|
|
mutable Size2i size = Size2i(DEFAULT_WINDOW_SIZE, DEFAULT_WINDOW_SIZE);
|
|
|
|
mutable Size2i min_size;
|
|
|
|
mutable Size2i max_size;
|
|
|
|
mutable Mode mode = MODE_WINDOWED;
|
2021-02-10 01:24:36 +08:00
|
|
|
mutable bool flags[FLAG_MAX] = {};
|
2020-03-04 09:51:12 +08:00
|
|
|
bool visible = true;
|
2020-03-07 01:00:16 +08:00
|
|
|
bool focused = false;
|
2020-03-04 09:51:12 +08:00
|
|
|
|
|
|
|
bool use_font_oversampling = false;
|
2020-03-05 03:03:30 +08:00
|
|
|
bool transient = false;
|
2020-03-07 01:00:16 +08:00
|
|
|
bool exclusive = false;
|
|
|
|
bool wrap_controls = false;
|
|
|
|
bool updating_child_controls = false;
|
2020-07-01 23:39:42 +08:00
|
|
|
bool clamp_to_embedder = false;
|
2020-03-07 01:00:16 +08:00
|
|
|
|
2020-09-03 19:22:16 +08:00
|
|
|
LayoutDirection layout_dir = LAYOUT_DIRECTION_INHERITED;
|
|
|
|
|
2021-05-28 01:31:33 +08:00
|
|
|
bool auto_translate = true;
|
|
|
|
|
2020-03-07 01:00:16 +08:00
|
|
|
void _update_child_controls();
|
2020-03-04 09:51:12 +08:00
|
|
|
|
|
|
|
Size2i content_scale_size;
|
2021-02-10 01:24:36 +08:00
|
|
|
ContentScaleMode content_scale_mode = CONTENT_SCALE_MODE_DISABLED;
|
|
|
|
ContentScaleAspect content_scale_aspect = CONTENT_SCALE_ASPECT_IGNORE;
|
2021-12-17 20:11:19 +08:00
|
|
|
real_t content_scale_factor = 1.0;
|
2020-03-04 09:51:12 +08:00
|
|
|
|
|
|
|
void _make_window();
|
|
|
|
void _clear_window();
|
|
|
|
void _update_from_window();
|
|
|
|
|
2020-03-15 00:06:39 +08:00
|
|
|
void _update_viewport_size();
|
|
|
|
void _update_window_size();
|
2020-03-04 09:51:12 +08:00
|
|
|
|
2020-03-05 00:36:09 +08:00
|
|
|
void _propagate_window_notification(Node *p_node, int p_notification);
|
|
|
|
|
|
|
|
void _update_window_callbacks();
|
|
|
|
|
2020-03-05 03:03:30 +08:00
|
|
|
void _clear_transient();
|
|
|
|
void _make_transient();
|
|
|
|
Window *transient_parent = nullptr;
|
2020-03-07 01:00:16 +08:00
|
|
|
Window *exclusive_child = nullptr;
|
2022-05-19 23:00:06 +08:00
|
|
|
HashSet<Window *> transient_children;
|
2020-03-05 03:03:30 +08:00
|
|
|
|
2020-03-07 01:00:16 +08:00
|
|
|
friend class Control;
|
|
|
|
Ref<Theme> theme;
|
|
|
|
Control *theme_owner = nullptr;
|
|
|
|
Window *theme_owner_window = nullptr;
|
2021-07-05 04:42:23 +08:00
|
|
|
StringName theme_type_variation;
|
2020-03-07 01:00:16 +08:00
|
|
|
|
2020-03-15 00:06:39 +08:00
|
|
|
Viewport *embedder = nullptr;
|
|
|
|
|
|
|
|
friend class Viewport; //friend back, can call the methods below
|
|
|
|
|
|
|
|
void _window_input(const Ref<InputEvent> &p_ev);
|
|
|
|
void _window_input_text(const String &p_text);
|
|
|
|
void _window_drop_files(const Vector<String> &p_files);
|
|
|
|
void _rect_changed_callback(const Rect2i &p_callback);
|
|
|
|
void _event_callback(DisplayServer::WindowEvent p_event);
|
2020-07-10 18:34:39 +08:00
|
|
|
virtual bool _can_consume_input_events() const override;
|
2020-03-15 00:06:39 +08:00
|
|
|
|
2022-08-30 19:32:34 +08:00
|
|
|
Ref<Shortcut> debugger_stop_shortcut;
|
|
|
|
|
2020-03-04 09:51:12 +08:00
|
|
|
protected:
|
2020-03-20 10:32:09 +08:00
|
|
|
Viewport *_get_embedder() const;
|
|
|
|
virtual Rect2i _popup_adjust_rect() const { return Rect2i(); }
|
|
|
|
|
2020-03-07 01:00:16 +08:00
|
|
|
virtual void _post_popup() {}
|
|
|
|
virtual Size2 _get_contents_minimum_size() const;
|
2020-03-04 09:51:12 +08:00
|
|
|
static void _bind_methods();
|
|
|
|
void _notification(int p_what);
|
2022-08-13 04:57:11 +08:00
|
|
|
void _validate_property(PropertyInfo &p_property) const;
|
2020-03-04 09:51:12 +08:00
|
|
|
|
2020-07-10 18:34:39 +08:00
|
|
|
virtual void add_child_notify(Node *p_child) override;
|
|
|
|
virtual void remove_child_notify(Node *p_child) override;
|
2020-03-07 01:00:16 +08:00
|
|
|
|
2020-03-04 09:51:12 +08:00
|
|
|
public:
|
2020-03-07 01:00:16 +08:00
|
|
|
enum {
|
|
|
|
NOTIFICATION_VISIBILITY_CHANGED = 30,
|
|
|
|
NOTIFICATION_POST_POPUP = 31,
|
2020-09-03 19:22:16 +08:00
|
|
|
NOTIFICATION_THEME_CHANGED = 32
|
2020-03-07 01:00:16 +08:00
|
|
|
};
|
|
|
|
|
2020-03-04 09:51:12 +08:00
|
|
|
void set_title(const String &p_title);
|
|
|
|
String get_title() const;
|
|
|
|
|
|
|
|
void set_current_screen(int p_screen);
|
|
|
|
int get_current_screen() const;
|
|
|
|
|
|
|
|
void set_position(const Point2i &p_position);
|
|
|
|
Point2i get_position() const;
|
|
|
|
|
|
|
|
void set_size(const Size2i &p_size);
|
|
|
|
Size2i get_size() const;
|
2021-11-20 16:04:57 +08:00
|
|
|
void reset_size();
|
2020-03-04 09:51:12 +08:00
|
|
|
|
|
|
|
Size2i get_real_size() const;
|
|
|
|
|
|
|
|
void set_max_size(const Size2i &p_max_size);
|
|
|
|
Size2i get_max_size() const;
|
|
|
|
|
|
|
|
void set_min_size(const Size2i &p_min_size);
|
|
|
|
Size2i get_min_size() const;
|
|
|
|
|
|
|
|
void set_mode(Mode p_mode);
|
|
|
|
Mode get_mode() const;
|
|
|
|
|
|
|
|
void set_flag(Flags p_flag, bool p_enabled);
|
|
|
|
bool get_flag(Flags p_flag) const;
|
|
|
|
|
|
|
|
bool is_maximize_allowed() const;
|
|
|
|
|
|
|
|
void request_attention();
|
|
|
|
void move_to_foreground();
|
|
|
|
|
|
|
|
void set_visible(bool p_visible);
|
|
|
|
bool is_visible() const;
|
|
|
|
|
2020-03-07 01:00:16 +08:00
|
|
|
void show();
|
|
|
|
void hide();
|
|
|
|
|
2020-03-05 03:03:30 +08:00
|
|
|
void set_transient(bool p_transient);
|
|
|
|
bool is_transient() const;
|
|
|
|
|
2020-03-07 01:00:16 +08:00
|
|
|
void set_exclusive(bool p_exclusive);
|
|
|
|
bool is_exclusive() const;
|
|
|
|
|
2020-07-01 23:39:42 +08:00
|
|
|
void set_clamp_to_embedder(bool p_enable);
|
|
|
|
bool is_clamped_to_embedder() const;
|
|
|
|
|
2020-03-04 09:51:12 +08:00
|
|
|
bool can_draw() const;
|
|
|
|
|
|
|
|
void set_ime_active(bool p_active);
|
|
|
|
void set_ime_position(const Point2i &p_pos);
|
|
|
|
|
|
|
|
bool is_embedded() const;
|
|
|
|
|
|
|
|
void set_content_scale_size(const Size2i &p_size);
|
|
|
|
Size2i get_content_scale_size() const;
|
|
|
|
|
2020-03-05 03:03:30 +08:00
|
|
|
void set_content_scale_mode(ContentScaleMode p_mode);
|
2020-03-04 09:51:12 +08:00
|
|
|
ContentScaleMode get_content_scale_mode() const;
|
|
|
|
|
2020-03-05 03:03:30 +08:00
|
|
|
void set_content_scale_aspect(ContentScaleAspect p_aspect);
|
2020-03-04 09:51:12 +08:00
|
|
|
ContentScaleAspect get_content_scale_aspect() const;
|
|
|
|
|
2021-12-17 20:11:19 +08:00
|
|
|
void set_content_scale_factor(real_t p_factor);
|
|
|
|
real_t get_content_scale_factor() const;
|
|
|
|
|
2020-03-04 09:51:12 +08:00
|
|
|
void set_use_font_oversampling(bool p_oversampling);
|
|
|
|
bool is_using_font_oversampling() const;
|
2020-03-07 01:00:16 +08:00
|
|
|
|
2022-08-18 17:16:29 +08:00
|
|
|
void warp_mouse(const Vector2 &p_position) override;
|
|
|
|
|
2020-03-07 01:00:16 +08:00
|
|
|
void set_wrap_controls(bool p_enable);
|
|
|
|
bool is_wrapping_controls() const;
|
|
|
|
void child_controls_changed();
|
|
|
|
|
|
|
|
Window *get_parent_visible_window() const;
|
|
|
|
Viewport *get_parent_viewport() const;
|
2020-03-25 22:16:19 +08:00
|
|
|
void popup(const Rect2i &p_rect = Rect2i());
|
|
|
|
void popup_on_parent(const Rect2i &p_parent_rect);
|
2020-03-07 01:00:16 +08:00
|
|
|
void popup_centered_ratio(float p_ratio = 0.8);
|
2020-03-25 22:16:19 +08:00
|
|
|
void popup_centered(const Size2i &p_minsize = Size2i());
|
|
|
|
void popup_centered_clamped(const Size2i &p_size = Size2i(), float p_fallback_ratio = 0.75);
|
2020-03-07 01:00:16 +08:00
|
|
|
|
|
|
|
void set_theme(const Ref<Theme> &p_theme);
|
|
|
|
Ref<Theme> get_theme() const;
|
2022-07-09 03:29:36 +08:00
|
|
|
void _theme_changed();
|
2020-03-07 01:00:16 +08:00
|
|
|
|
2021-07-05 04:42:23 +08:00
|
|
|
void set_theme_type_variation(const StringName &p_theme_type);
|
|
|
|
StringName get_theme_type_variation() const;
|
2021-03-31 01:16:33 +08:00
|
|
|
_FORCE_INLINE_ void _get_theme_type_dependencies(const StringName &p_theme_type, List<StringName> *p_list) const;
|
|
|
|
|
2020-03-12 20:37:40 +08:00
|
|
|
Size2 get_contents_minimum_size() const;
|
|
|
|
|
2020-03-07 01:00:16 +08:00
|
|
|
void grab_focus();
|
|
|
|
bool has_focus() const;
|
|
|
|
|
2020-09-03 19:22:16 +08:00
|
|
|
void set_layout_direction(LayoutDirection p_direction);
|
|
|
|
LayoutDirection get_layout_direction() const;
|
|
|
|
bool is_layout_rtl() const;
|
|
|
|
|
2021-05-28 01:31:33 +08:00
|
|
|
void set_auto_translate(bool p_enable);
|
|
|
|
bool is_auto_translating() const;
|
|
|
|
_FORCE_INLINE_ String atr(const String p_string) const { return is_auto_translating() ? tr(p_string) : p_string; };
|
|
|
|
|
2020-03-20 10:32:09 +08:00
|
|
|
Rect2i get_usable_parent_rect() const;
|
|
|
|
|
2021-03-31 01:16:33 +08:00
|
|
|
Ref<Texture2D> get_theme_icon(const StringName &p_name, const StringName &p_theme_type = StringName()) const;
|
|
|
|
Ref<StyleBox> get_theme_stylebox(const StringName &p_name, const StringName &p_theme_type = StringName()) const;
|
|
|
|
Ref<Font> get_theme_font(const StringName &p_name, const StringName &p_theme_type = StringName()) const;
|
|
|
|
int get_theme_font_size(const StringName &p_name, const StringName &p_theme_type = StringName()) const;
|
|
|
|
Color get_theme_color(const StringName &p_name, const StringName &p_theme_type = StringName()) const;
|
|
|
|
int get_theme_constant(const StringName &p_name, const StringName &p_theme_type = StringName()) const;
|
|
|
|
|
|
|
|
bool has_theme_icon(const StringName &p_name, const StringName &p_theme_type = StringName()) const;
|
|
|
|
bool has_theme_stylebox(const StringName &p_name, const StringName &p_theme_type = StringName()) const;
|
|
|
|
bool has_theme_font(const StringName &p_name, const StringName &p_theme_type = StringName()) const;
|
|
|
|
bool has_theme_font_size(const StringName &p_name, const StringName &p_theme_type = StringName()) const;
|
|
|
|
bool has_theme_color(const StringName &p_name, const StringName &p_theme_type = StringName()) const;
|
|
|
|
bool has_theme_constant(const StringName &p_name, const StringName &p_theme_type = StringName()) const;
|
2020-03-12 20:37:40 +08:00
|
|
|
|
2021-10-03 04:06:14 +08:00
|
|
|
float get_theme_default_base_scale() const;
|
|
|
|
Ref<Font> get_theme_default_font() const;
|
|
|
|
int get_theme_default_font_size() const;
|
|
|
|
|
2022-03-28 17:01:29 +08:00
|
|
|
virtual Transform2D get_screen_transform() const override;
|
|
|
|
|
2020-03-15 00:06:39 +08:00
|
|
|
Rect2i get_parent_rect() const;
|
2020-07-10 18:34:39 +08:00
|
|
|
virtual DisplayServer::WindowID get_window_id() const override;
|
2020-03-12 20:37:40 +08:00
|
|
|
|
2020-03-04 09:51:12 +08:00
|
|
|
Window();
|
|
|
|
~Window();
|
|
|
|
};
|
|
|
|
|
2020-03-31 17:56:58 +08:00
|
|
|
VARIANT_ENUM_CAST(Window::Mode);
|
|
|
|
VARIANT_ENUM_CAST(Window::Flags);
|
2020-03-04 09:51:12 +08:00
|
|
|
VARIANT_ENUM_CAST(Window::ContentScaleMode);
|
|
|
|
VARIANT_ENUM_CAST(Window::ContentScaleAspect);
|
2020-09-03 19:22:16 +08:00
|
|
|
VARIANT_ENUM_CAST(Window::LayoutDirection);
|
2020-03-04 09:51:12 +08:00
|
|
|
|
|
|
|
#endif // WINDOW_H
|