2023-01-10 14:26:54 +00:00
/**************************************************************************/
/* world_environment.cpp */
/**************************************************************************/
/* This file is part of: */
/* GODOT ENGINE */
/* https://godotengine.org */
/**************************************************************************/
/* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */
/* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur. */
/* */
/* 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. */
/**************************************************************************/
2018-01-04 23:50:27 +00:00
2019-02-12 16:18:13 +00:00
# include "world_environment.h"
2017-06-24 11:58:27 +00:00
# include "scene/main/viewport.h"
2014-02-10 01:10:30 +00:00
void WorldEnvironment : : _notification ( int p_what ) {
2017-06-24 11:58:27 +00:00
if ( p_what = = Spatial : : NOTIFICATION_ENTER_WORLD | | p_what = = Spatial : : NOTIFICATION_ENTER_TREE ) {
2014-09-22 03:50:48 +00:00
if ( environment . is_valid ( ) ) {
2017-06-24 11:58:27 +00:00
if ( get_viewport ( ) - > find_world ( ) - > get_environment ( ) . is_valid ( ) ) {
2014-09-22 03:50:48 +00:00
WARN_PRINT ( " World already has an environment (Another WorldEnvironment?), overriding. " ) ;
}
2017-06-24 11:58:27 +00:00
get_viewport ( ) - > find_world ( ) - > set_environment ( environment ) ;
add_to_group ( " _world_environment_ " + itos ( get_viewport ( ) - > find_world ( ) - > get_scenario ( ) . get_id ( ) ) ) ;
2014-09-22 03:50:48 +00:00
}
2017-06-24 11:58:27 +00:00
} else if ( p_what = = Spatial : : NOTIFICATION_EXIT_WORLD | | p_what = = Spatial : : NOTIFICATION_EXIT_TREE ) {
if ( environment . is_valid ( ) & & get_viewport ( ) - > find_world ( ) - > get_environment ( ) = = environment ) {
get_viewport ( ) - > find_world ( ) - > set_environment ( Ref < Environment > ( ) ) ;
remove_from_group ( " _world_environment_ " + itos ( get_viewport ( ) - > find_world ( ) - > get_scenario ( ) . get_id ( ) ) ) ;
2016-05-17 21:27:15 +00:00
}
2014-02-10 01:10:30 +00:00
}
}
2017-03-05 15:44:50 +00:00
void WorldEnvironment : : set_environment ( const Ref < Environment > & p_environment ) {
2017-06-24 11:58:27 +00:00
if ( is_inside_tree ( ) & & environment . is_valid ( ) & & get_viewport ( ) - > find_world ( ) - > get_environment ( ) = = environment ) {
get_viewport ( ) - > find_world ( ) - > set_environment ( Ref < Environment > ( ) ) ;
remove_from_group ( " _world_environment_ " + itos ( get_viewport ( ) - > find_world ( ) - > get_scenario ( ) . get_id ( ) ) ) ;
2014-09-22 03:50:48 +00:00
//clean up
}
2017-03-05 15:44:50 +00:00
environment = p_environment ;
2017-06-24 11:58:27 +00:00
if ( is_inside_tree ( ) & & environment . is_valid ( ) ) {
if ( get_viewport ( ) - > find_world ( ) - > get_environment ( ) . is_valid ( ) ) {
2014-09-22 03:50:48 +00:00
WARN_PRINT ( " World already has an environment (Another WorldEnvironment?), overriding. " ) ;
}
2017-06-24 11:58:27 +00:00
get_viewport ( ) - > find_world ( ) - > set_environment ( environment ) ;
add_to_group ( " _world_environment_ " + itos ( get_viewport ( ) - > find_world ( ) - > get_scenario ( ) . get_id ( ) ) ) ;
2014-02-10 01:10:30 +00:00
}
2016-05-17 21:27:15 +00:00
update_configuration_warning ( ) ;
2014-02-10 01:10:30 +00:00
}
Ref < Environment > WorldEnvironment : : get_environment ( ) const {
return environment ;
}
2016-05-17 21:27:15 +00:00
String WorldEnvironment : : get_configuration_warning ( ) const {
2020-03-22 08:31:09 +00:00
String warning = Node : : get_configuration_warning ( ) ;
2018-03-16 10:15:15 +00:00
if ( ! environment . is_valid ( ) ) {
2020-03-22 08:31:09 +00:00
if ( warning ! = String ( ) ) {
warning + = " \n \n " ;
}
warning + = TTR ( " WorldEnvironment requires its \" Environment \" property to contain an Environment to have a visible effect. " ) ;
return warning ;
2018-03-16 10:15:15 +00:00
}
2021-05-05 10:44:11 +00:00
if ( /*!is_visible_in_tree() ||*/ ! is_inside_tree ( ) ) {
2016-05-17 21:27:15 +00:00
return String ( ) ;
2021-05-05 10:44:11 +00:00
}
2016-05-17 21:27:15 +00:00
2017-03-05 15:44:50 +00:00
List < Node * > nodes ;
2017-06-24 11:58:27 +00:00
get_tree ( ) - > get_nodes_in_group ( " _world_environment_ " + itos ( get_viewport ( ) - > find_world ( ) - > get_scenario ( ) . get_id ( ) ) , & nodes ) ;
2016-05-17 21:27:15 +00:00
2017-03-05 15:44:50 +00:00
if ( nodes . size ( ) > 1 ) {
2020-03-22 08:31:09 +00:00
if ( warning ! = String ( ) ) {
warning + = " \n \n " ;
}
warning + = TTR ( " Only one WorldEnvironment is allowed per scene (or set of instanced scenes). " ) ;
2016-05-17 21:27:15 +00:00
}
2018-05-17 21:02:16 +00:00
// Commenting this warning for now, I think it makes no sense. If anyone can figure out what its supposed to do, feedback welcome. Else it should be deprecated.
//if (environment.is_valid() && get_viewport() && !get_viewport()->get_camera() && environment->get_background() != Environment::BG_CANVAS) {
// return TTR("This WorldEnvironment is ignored. Either add a Camera (for 3D scenes) or set this environment's Background Mode to Canvas (for 2D scenes).");
//}
2018-03-16 10:15:15 +00:00
2020-03-22 08:31:09 +00:00
return warning ;
2016-05-17 21:27:15 +00:00
}
2014-02-10 01:10:30 +00:00
void WorldEnvironment : : _bind_methods ( ) {
2017-08-09 11:19:41 +00:00
ClassDB : : bind_method ( D_METHOD ( " set_environment " , " env " ) , & WorldEnvironment : : set_environment ) ;
ClassDB : : bind_method ( D_METHOD ( " get_environment " ) , & WorldEnvironment : : get_environment ) ;
2017-03-05 15:44:50 +00:00
ADD_PROPERTY ( PropertyInfo ( Variant : : OBJECT , " environment " , PROPERTY_HINT_RESOURCE_TYPE , " Environment " ) , " set_environment " , " get_environment " ) ;
2014-02-10 01:10:30 +00:00
}
WorldEnvironment : : WorldEnvironment ( ) {
}