summaryrefslogtreecommitdiffstats
path: root/scene/main/window.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'scene/main/window.cpp')
-rw-r--r--scene/main/window.cpp22
1 files changed, 22 insertions, 0 deletions
diff --git a/scene/main/window.cpp b/scene/main/window.cpp
index 9c2509404c..6632dd9033 100644
--- a/scene/main/window.cpp
+++ b/scene/main/window.cpp
@@ -1209,8 +1209,26 @@ void Window::_update_window_callbacks() {
DisplayServer::get_singleton()->window_set_drop_files_callback(callable_mp(this, &Window::_window_drop_files), window_id);
}
+void Window::set_force_native(bool p_force_native) {
+ if (force_native == p_force_native) {
+ return;
+ }
+ force_native = p_force_native;
+ if (is_visible()) {
+ WARN_PRINT("Can't change \"force_native\" while a window is displayed. Consider hiding window before changing this value.");
+ }
+}
+
+bool Window::get_force_native() const {
+ return force_native;
+}
+
Viewport *Window::get_embedder() const {
ERR_READ_THREAD_GUARD_V(nullptr);
+ if (force_native && DisplayServer::get_singleton()->has_feature(DisplayServer::FEATURE_SUBWINDOWS)) {
+ return nullptr;
+ }
+
Viewport *vp = get_parent_viewport();
while (vp) {
@@ -2802,6 +2820,9 @@ void Window::_bind_methods() {
ClassDB::bind_method(D_METHOD("get_contents_minimum_size"), &Window::get_contents_minimum_size);
+ ClassDB::bind_method(D_METHOD("set_force_native", "force_native"), &Window::set_force_native);
+ ClassDB::bind_method(D_METHOD("get_force_native"), &Window::get_force_native);
+
ClassDB::bind_method(D_METHOD("set_content_scale_size", "size"), &Window::set_content_scale_size);
ClassDB::bind_method(D_METHOD("get_content_scale_size"), &Window::get_content_scale_size);
@@ -2926,6 +2947,7 @@ void Window::_bind_methods() {
ADD_PROPERTYI(PropertyInfo(Variant::BOOL, "popup_window"), "set_flag", "get_flag", FLAG_POPUP);
ADD_PROPERTYI(PropertyInfo(Variant::BOOL, "extend_to_title"), "set_flag", "get_flag", FLAG_EXTEND_TO_TITLE);
ADD_PROPERTYI(PropertyInfo(Variant::BOOL, "mouse_passthrough"), "set_flag", "get_flag", FLAG_MOUSE_PASSTHROUGH);
+ ADD_PROPERTY(PropertyInfo(Variant::BOOL, "force_native"), "set_force_native", "get_force_native");
ADD_GROUP("Limits", "");
ADD_PROPERTY(PropertyInfo(Variant::VECTOR2I, "min_size", PROPERTY_HINT_NONE, "suffix:px"), "set_min_size", "get_min_size");