From 8841a5f05670719d2c0a1e8bf0596f03500e94f6 Mon Sep 17 00:00:00 2001 From: PZerua Date: Tue, 5 Jul 2022 19:41:52 +0200 Subject: [PATCH] Fix light intensity and attenuation import from GLTF (cherry picked from commit aa7ab96e7163578f0318546b0b39a4d962e88511) --- modules/gltf/gltf_document.cpp | 13 ++++--------- 1 file changed, 4 insertions(+), 9 deletions(-) diff --git a/modules/gltf/gltf_document.cpp b/modules/gltf/gltf_document.cpp index cddcfe284..edcda55b1 100644 --- a/modules/gltf/gltf_document.cpp +++ b/modules/gltf/gltf_document.cpp @@ -5174,19 +5174,16 @@ Spatial *GLTFDocument::_generate_light(Ref state, Node *scene_parent, } const float range = CLAMP(l->range, 0, 4096); - // Doubling the range will double the effective brightness, so we need double attenuation (half brightness). - // We want to have double intensity give double brightness, so we need half the attenuation. - const float attenuation = range / intensity; if (l->type == "point") { OmniLight *light = memnew(OmniLight); - light->set_param(OmniLight::PARAM_ATTENUATION, attenuation); + light->set_param(OmniLight::PARAM_ENERGY, intensity); light->set_param(OmniLight::PARAM_RANGE, range); light->set_color(l->color); return light; } if (l->type == "spot") { SpotLight *light = memnew(SpotLight); - light->set_param(SpotLight::PARAM_ATTENUATION, attenuation); + light->set_param(SpotLight::PARAM_ENERGY, intensity); light->set_param(SpotLight::PARAM_RANGE, range); light->set_param(SpotLight::PARAM_SPOT_ANGLE, Math::rad2deg(l->outer_cone_angle)); light->set_color(l->color); @@ -5255,14 +5252,12 @@ GLTFLightIndex GLTFDocument::_convert_light(Ref state, Light *p_light l->type = "point"; OmniLight *light = cast_to(p_light); l->range = light->get_param(OmniLight::PARAM_RANGE); - float attenuation = p_light->get_param(OmniLight::PARAM_ATTENUATION); - l->intensity = l->range / attenuation; + l->intensity = light->get_param(OmniLight::PARAM_ENERGY); } else if (cast_to(p_light)) { l->type = "spot"; SpotLight *light = cast_to(p_light); l->range = light->get_param(SpotLight::PARAM_RANGE); - float attenuation = light->get_param(SpotLight::PARAM_ATTENUATION); - l->intensity = l->range / attenuation; + l->intensity = light->get_param(SpotLight::PARAM_ENERGY); l->outer_cone_angle = Math::deg2rad(light->get_param(SpotLight::PARAM_SPOT_ANGLE)); // This equation is the inverse of the import equation (which has a desmos link).