2014-02-10 09:10:30 +08:00
|
|
|
/*************************************************************************/
|
2020-03-27 05:49:16 +08:00
|
|
|
/* light_3d.h */
|
2014-02-10 09:10:30 +08:00
|
|
|
/*************************************************************************/
|
|
|
|
/* This file is part of: */
|
|
|
|
/* GODOT ENGINE */
|
2017-08-27 20:16:55 +08:00
|
|
|
/* https://godotengine.org */
|
2014-02-10 09:10:30 +08:00
|
|
|
/*************************************************************************/
|
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). */
|
2014-02-10 09:10:30 +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. */
|
|
|
|
/*************************************************************************/
|
2018-01-05 07:50:27 +08:00
|
|
|
|
2020-07-01 20:18:13 +08:00
|
|
|
#ifndef LIGHT_3D_H
|
|
|
|
#define LIGHT_3D_H
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2020-03-27 05:49:16 +08:00
|
|
|
#include "scene/3d/visual_instance_3d.h"
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2020-03-27 05:49:16 +08:00
|
|
|
class Light3D : public VisualInstance3D {
|
|
|
|
GDCLASS(Light3D, VisualInstance3D);
|
2014-02-10 09:10:30 +08:00
|
|
|
|
|
|
|
public:
|
2016-10-27 22:50:26 +08:00
|
|
|
enum Param {
|
2020-03-28 02:21:27 +08:00
|
|
|
PARAM_ENERGY = RS::LIGHT_PARAM_ENERGY,
|
|
|
|
PARAM_INDIRECT_ENERGY = RS::LIGHT_PARAM_INDIRECT_ENERGY,
|
2021-07-09 16:28:33 +08:00
|
|
|
PARAM_VOLUMETRIC_FOG_ENERGY = RS::LIGHT_PARAM_VOLUMETRIC_FOG_ENERGY,
|
2020-03-28 02:21:27 +08:00
|
|
|
PARAM_SPECULAR = RS::LIGHT_PARAM_SPECULAR,
|
|
|
|
PARAM_RANGE = RS::LIGHT_PARAM_RANGE,
|
2020-04-10 02:11:15 +08:00
|
|
|
PARAM_SIZE = RS::LIGHT_PARAM_SIZE,
|
2020-03-28 02:21:27 +08:00
|
|
|
PARAM_ATTENUATION = RS::LIGHT_PARAM_ATTENUATION,
|
|
|
|
PARAM_SPOT_ANGLE = RS::LIGHT_PARAM_SPOT_ANGLE,
|
|
|
|
PARAM_SPOT_ATTENUATION = RS::LIGHT_PARAM_SPOT_ATTENUATION,
|
|
|
|
PARAM_SHADOW_MAX_DISTANCE = RS::LIGHT_PARAM_SHADOW_MAX_DISTANCE,
|
|
|
|
PARAM_SHADOW_SPLIT_1_OFFSET = RS::LIGHT_PARAM_SHADOW_SPLIT_1_OFFSET,
|
|
|
|
PARAM_SHADOW_SPLIT_2_OFFSET = RS::LIGHT_PARAM_SHADOW_SPLIT_2_OFFSET,
|
|
|
|
PARAM_SHADOW_SPLIT_3_OFFSET = RS::LIGHT_PARAM_SHADOW_SPLIT_3_OFFSET,
|
|
|
|
PARAM_SHADOW_FADE_START = RS::LIGHT_PARAM_SHADOW_FADE_START,
|
|
|
|
PARAM_SHADOW_NORMAL_BIAS = RS::LIGHT_PARAM_SHADOW_NORMAL_BIAS,
|
|
|
|
PARAM_SHADOW_BIAS = RS::LIGHT_PARAM_SHADOW_BIAS,
|
2020-04-08 09:51:52 +08:00
|
|
|
PARAM_SHADOW_PANCAKE_SIZE = RS::LIGHT_PARAM_SHADOW_PANCAKE_SIZE,
|
2022-06-10 18:47:06 +08:00
|
|
|
PARAM_SHADOW_OPACITY = RS::LIGHT_PARAM_SHADOW_OPACITY,
|
2020-04-10 17:30:36 +08:00
|
|
|
PARAM_SHADOW_BLUR = RS::LIGHT_PARAM_SHADOW_BLUR,
|
2020-04-08 09:51:52 +08:00
|
|
|
PARAM_TRANSMITTANCE_BIAS = RS::LIGHT_PARAM_TRANSMITTANCE_BIAS,
|
2020-03-28 02:21:27 +08:00
|
|
|
PARAM_MAX = RS::LIGHT_PARAM_MAX
|
2014-06-11 21:41:03 +08:00
|
|
|
};
|
|
|
|
|
2017-12-14 19:59:46 +08:00
|
|
|
enum BakeMode {
|
|
|
|
BAKE_DISABLED,
|
2021-11-27 00:47:37 +08:00
|
|
|
BAKE_STATIC,
|
2020-06-25 21:33:28 +08:00
|
|
|
BAKE_DYNAMIC,
|
2017-12-14 19:59:46 +08:00
|
|
|
};
|
|
|
|
|
2014-02-10 09:10:30 +08:00
|
|
|
private:
|
2016-10-27 22:50:26 +08:00
|
|
|
Color color;
|
2021-01-30 08:55:54 +08:00
|
|
|
real_t param[PARAM_MAX] = {};
|
2021-02-08 05:29:31 +08:00
|
|
|
bool shadow = false;
|
|
|
|
bool negative = false;
|
|
|
|
bool reverse_cull = false;
|
|
|
|
uint32_t cull_mask = 0;
|
2022-02-25 05:55:14 +08:00
|
|
|
bool distance_fade_enabled = false;
|
|
|
|
real_t distance_fade_begin = 40.0;
|
|
|
|
real_t distance_fade_shadow = 50.0;
|
|
|
|
real_t distance_fade_length = 10.0;
|
2021-02-08 05:29:31 +08:00
|
|
|
RS::LightType type = RenderingServer::LIGHT_DIRECTIONAL;
|
|
|
|
bool editor_only = false;
|
2014-10-12 13:13:22 +08:00
|
|
|
void _update_visibility();
|
2021-02-08 05:29:31 +08:00
|
|
|
BakeMode bake_mode = BAKE_DYNAMIC;
|
2020-04-15 04:05:45 +08:00
|
|
|
Ref<Texture2D> projector;
|
2016-12-20 11:21:07 +08:00
|
|
|
|
2017-03-05 23:44:50 +08:00
|
|
|
// bind helpers
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2022-06-23 14:19:18 +08:00
|
|
|
virtual void owner_changed_notify() override;
|
|
|
|
|
2016-03-09 07:00:52 +08:00
|
|
|
protected:
|
2014-02-10 09:10:30 +08:00
|
|
|
RID light;
|
|
|
|
|
|
|
|
static void _bind_methods();
|
2014-10-12 13:13:22 +08:00
|
|
|
void _notification(int p_what);
|
2022-08-13 04:57:11 +08:00
|
|
|
void _validate_property(PropertyInfo &p_property) const;
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2020-03-28 02:21:27 +08:00
|
|
|
Light3D(RenderingServer::LightType p_type);
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2017-03-05 23:44:50 +08:00
|
|
|
public:
|
2020-03-28 02:21:27 +08:00
|
|
|
RS::LightType get_light_type() const { return type; }
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2014-10-12 13:13:22 +08:00
|
|
|
void set_editor_only(bool p_editor_only);
|
|
|
|
bool is_editor_only() const;
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2021-01-30 08:55:54 +08:00
|
|
|
void set_param(Param p_param, real_t p_value);
|
|
|
|
real_t get_param(Param p_param) const;
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2016-10-27 22:50:26 +08:00
|
|
|
void set_shadow(bool p_enable);
|
|
|
|
bool has_shadow() const;
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2016-10-27 22:50:26 +08:00
|
|
|
void set_negative(bool p_enable);
|
|
|
|
bool is_negative() const;
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2022-02-25 05:55:14 +08:00
|
|
|
void set_enable_distance_fade(bool p_enable);
|
|
|
|
bool is_distance_fade_enabled() const;
|
|
|
|
|
|
|
|
void set_distance_fade_begin(real_t p_distance);
|
|
|
|
real_t get_distance_fade_begin() const;
|
|
|
|
|
|
|
|
void set_distance_fade_shadow(real_t p_distance);
|
|
|
|
real_t get_distance_fade_shadow() const;
|
|
|
|
|
|
|
|
void set_distance_fade_length(real_t p_length);
|
|
|
|
real_t get_distance_fade_length() const;
|
|
|
|
|
2016-10-27 22:50:26 +08:00
|
|
|
void set_cull_mask(uint32_t p_cull_mask);
|
|
|
|
uint32_t get_cull_mask() const;
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2017-03-05 23:44:50 +08:00
|
|
|
void set_color(const Color &p_color);
|
2016-10-27 22:50:26 +08:00
|
|
|
Color get_color() const;
|
2014-06-11 21:41:03 +08:00
|
|
|
|
2017-08-20 07:06:40 +08:00
|
|
|
void set_shadow_reverse_cull_face(bool p_enable);
|
|
|
|
bool get_shadow_reverse_cull_face() const;
|
|
|
|
|
2017-12-14 19:59:46 +08:00
|
|
|
void set_bake_mode(BakeMode p_mode);
|
|
|
|
BakeMode get_bake_mode() const;
|
|
|
|
|
2020-04-15 15:09:48 +08:00
|
|
|
void set_projector(const Ref<Texture2D> &p_texture);
|
2020-04-15 04:05:45 +08:00
|
|
|
Ref<Texture2D> get_projector() const;
|
|
|
|
|
2020-07-10 18:34:39 +08:00
|
|
|
virtual AABB get_aabb() const override;
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2020-03-27 05:49:16 +08:00
|
|
|
Light3D();
|
|
|
|
~Light3D();
|
2014-02-10 09:10:30 +08:00
|
|
|
};
|
|
|
|
|
2020-03-27 05:49:16 +08:00
|
|
|
VARIANT_ENUM_CAST(Light3D::Param);
|
|
|
|
VARIANT_ENUM_CAST(Light3D::BakeMode);
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2020-03-27 05:49:16 +08:00
|
|
|
class DirectionalLight3D : public Light3D {
|
|
|
|
GDCLASS(DirectionalLight3D, Light3D);
|
2014-02-10 09:10:30 +08:00
|
|
|
|
|
|
|
public:
|
|
|
|
enum ShadowMode {
|
|
|
|
SHADOW_ORTHOGONAL,
|
2014-05-05 09:50:23 +08:00
|
|
|
SHADOW_PARALLEL_2_SPLITS,
|
2020-07-01 20:18:13 +08:00
|
|
|
SHADOW_PARALLEL_4_SPLITS,
|
2014-02-10 09:10:30 +08:00
|
|
|
};
|
|
|
|
|
2021-10-20 06:40:46 +08:00
|
|
|
enum SkyMode {
|
|
|
|
SKY_MODE_LIGHT_AND_SKY,
|
|
|
|
SKY_MODE_LIGHT_ONLY,
|
|
|
|
SKY_MODE_SKY_ONLY,
|
|
|
|
};
|
|
|
|
|
2014-02-10 09:10:30 +08:00
|
|
|
private:
|
2016-11-10 10:55:06 +08:00
|
|
|
bool blend_splits;
|
2014-02-10 09:10:30 +08:00
|
|
|
ShadowMode shadow_mode;
|
2021-10-20 06:40:46 +08:00
|
|
|
SkyMode sky_mode = SKY_MODE_LIGHT_AND_SKY;
|
2016-10-04 03:33:42 +08:00
|
|
|
|
2014-02-10 09:10:30 +08:00
|
|
|
protected:
|
|
|
|
static void _bind_methods();
|
2022-08-13 04:57:11 +08:00
|
|
|
void _validate_property(PropertyInfo &p_property) const;
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2017-03-05 23:44:50 +08:00
|
|
|
public:
|
2014-02-10 09:10:30 +08:00
|
|
|
void set_shadow_mode(ShadowMode p_mode);
|
|
|
|
ShadowMode get_shadow_mode() const;
|
|
|
|
|
2016-11-10 10:55:06 +08:00
|
|
|
void set_blend_splits(bool p_enable);
|
|
|
|
bool is_blend_splits_enabled() const;
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2021-10-20 06:40:46 +08:00
|
|
|
void set_sky_mode(SkyMode p_mode);
|
|
|
|
SkyMode get_sky_mode() const;
|
2020-10-22 14:22:53 +08:00
|
|
|
|
2020-03-27 05:49:16 +08:00
|
|
|
DirectionalLight3D();
|
2014-02-10 09:10:30 +08:00
|
|
|
};
|
|
|
|
|
2020-03-27 05:49:16 +08:00
|
|
|
VARIANT_ENUM_CAST(DirectionalLight3D::ShadowMode)
|
2021-10-20 06:40:46 +08:00
|
|
|
VARIANT_ENUM_CAST(DirectionalLight3D::SkyMode)
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2020-03-27 05:49:16 +08:00
|
|
|
class OmniLight3D : public Light3D {
|
|
|
|
GDCLASS(OmniLight3D, Light3D);
|
2017-03-05 23:44:50 +08:00
|
|
|
|
2016-11-10 10:55:06 +08:00
|
|
|
public:
|
|
|
|
// omni light
|
|
|
|
enum ShadowMode {
|
|
|
|
SHADOW_DUAL_PARABOLOID,
|
|
|
|
SHADOW_CUBE,
|
|
|
|
};
|
|
|
|
|
|
|
|
private:
|
|
|
|
ShadowMode shadow_mode;
|
2017-03-05 23:44:50 +08:00
|
|
|
|
2014-02-10 09:10:30 +08:00
|
|
|
protected:
|
|
|
|
static void _bind_methods();
|
|
|
|
|
|
|
|
public:
|
2016-11-10 10:55:06 +08:00
|
|
|
void set_shadow_mode(ShadowMode p_mode);
|
|
|
|
ShadowMode get_shadow_mode() const;
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2020-10-29 18:01:28 +08:00
|
|
|
TypedArray<String> get_configuration_warnings() const override;
|
2020-04-15 04:05:45 +08:00
|
|
|
|
2020-03-27 05:49:16 +08:00
|
|
|
OmniLight3D();
|
2014-02-10 09:10:30 +08:00
|
|
|
};
|
|
|
|
|
2020-03-27 05:49:16 +08:00
|
|
|
VARIANT_ENUM_CAST(OmniLight3D::ShadowMode)
|
2016-11-10 10:55:06 +08:00
|
|
|
|
2020-03-27 05:49:16 +08:00
|
|
|
class SpotLight3D : public Light3D {
|
|
|
|
GDCLASS(SpotLight3D, Light3D);
|
2017-03-05 23:44:50 +08:00
|
|
|
|
2014-02-10 09:10:30 +08:00
|
|
|
protected:
|
|
|
|
static void _bind_methods();
|
|
|
|
|
2017-03-05 23:44:50 +08:00
|
|
|
public:
|
2020-10-29 18:01:28 +08:00
|
|
|
TypedArray<String> get_configuration_warnings() const override;
|
2019-07-07 22:22:09 +08:00
|
|
|
|
2020-03-27 05:49:16 +08:00
|
|
|
SpotLight3D() :
|
2020-03-28 02:21:27 +08:00
|
|
|
Light3D(RenderingServer::LIGHT_SPOT) {}
|
2014-02-10 09:10:30 +08:00
|
|
|
};
|
|
|
|
|
2020-07-01 20:18:13 +08:00
|
|
|
#endif // LIGHT_3D_H
|