Merge pull request #17571 from kubecz3k/cam-disable
a way to ensure that camera is disabled
This commit is contained in:
commit
8cfca7726f
2 changed files with 7 additions and 4 deletions
|
@ -201,7 +201,7 @@ void Camera::make_current() {
|
||||||
//get_scene()->call_group(SceneMainLoop::GROUP_CALL_REALTIME,camera_group,"_camera_make_current",this);
|
//get_scene()->call_group(SceneMainLoop::GROUP_CALL_REALTIME,camera_group,"_camera_make_current",this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Camera::clear_current() {
|
void Camera::clear_current(bool p_enable_next) {
|
||||||
|
|
||||||
current = false;
|
current = false;
|
||||||
if (!is_inside_tree())
|
if (!is_inside_tree())
|
||||||
|
@ -209,7 +209,10 @@ void Camera::clear_current() {
|
||||||
|
|
||||||
if (get_viewport()->get_camera() == this) {
|
if (get_viewport()->get_camera() == this) {
|
||||||
get_viewport()->_camera_set(NULL);
|
get_viewport()->_camera_set(NULL);
|
||||||
get_viewport()->_camera_make_next_current(this);
|
|
||||||
|
if (p_enable_next) {
|
||||||
|
get_viewport()->_camera_make_next_current(this);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -439,7 +442,7 @@ void Camera::_bind_methods() {
|
||||||
ClassDB::bind_method(D_METHOD("set_perspective", "fov", "z_near", "z_far"), &Camera::set_perspective);
|
ClassDB::bind_method(D_METHOD("set_perspective", "fov", "z_near", "z_far"), &Camera::set_perspective);
|
||||||
ClassDB::bind_method(D_METHOD("set_orthogonal", "size", "z_near", "z_far"), &Camera::set_orthogonal);
|
ClassDB::bind_method(D_METHOD("set_orthogonal", "size", "z_near", "z_far"), &Camera::set_orthogonal);
|
||||||
ClassDB::bind_method(D_METHOD("make_current"), &Camera::make_current);
|
ClassDB::bind_method(D_METHOD("make_current"), &Camera::make_current);
|
||||||
ClassDB::bind_method(D_METHOD("clear_current"), &Camera::clear_current);
|
ClassDB::bind_method(D_METHOD("clear_current", "enable_next"), &Camera::clear_current, DEFVAL(true));
|
||||||
ClassDB::bind_method(D_METHOD("set_current"), &Camera::set_current);
|
ClassDB::bind_method(D_METHOD("set_current"), &Camera::set_current);
|
||||||
ClassDB::bind_method(D_METHOD("is_current"), &Camera::is_current);
|
ClassDB::bind_method(D_METHOD("is_current"), &Camera::is_current);
|
||||||
ClassDB::bind_method(D_METHOD("get_camera_transform"), &Camera::get_camera_transform);
|
ClassDB::bind_method(D_METHOD("get_camera_transform"), &Camera::get_camera_transform);
|
||||||
|
|
|
@ -113,7 +113,7 @@ public:
|
||||||
void set_projection(Camera::Projection p_mode);
|
void set_projection(Camera::Projection p_mode);
|
||||||
|
|
||||||
void make_current();
|
void make_current();
|
||||||
void clear_current();
|
void clear_current(bool p_enable_next = true);
|
||||||
void set_current(bool p_current);
|
void set_current(bool p_current);
|
||||||
bool is_current() const;
|
bool is_current() const;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue