Skip to main content

bevy_light/
volumetric.rs

1use bevy_asset::Handle;
2use bevy_camera::visibility::Visibility;
3use bevy_color::Color;
4use bevy_ecs::prelude::*;
5use bevy_image::Image;
6use bevy_math::Vec3;
7use bevy_reflect::prelude::*;
8use bevy_transform::components::Transform;
9
10/// Add this component to a [`DirectionalLight`](crate::DirectionalLight) with a shadow map
11/// (`shadow_maps_enabled: true`) to make volumetric fog interact with it.
12///
13/// This allows the light to generate light shafts/god rays.
14#[derive(#[automatically_derived]
impl ::core::clone::Clone for VolumetricLight {
    #[inline]
    fn clone(&self) -> VolumetricLight { *self }
}Clone, #[automatically_derived]
impl ::core::marker::Copy for VolumetricLight { }Copy, impl bevy_ecs::component::Component for VolumetricLight where
    Self: ::core::marker::Send + ::core::marker::Sync + 'static {
    const STORAGE_TYPE: bevy_ecs::component::StorageType =
        bevy_ecs::component::StorageType::Table;
    type Mutability = bevy_ecs::component::Mutable;
    fn register_required_components(_requiree:
            bevy_ecs::component::ComponentId,
        required_components:
            &mut bevy_ecs::component::RequiredComponentsRegistrator) {}
    fn clone_behavior() -> bevy_ecs::component::ComponentCloneBehavior {
        use bevy_ecs::component::{
            DefaultCloneBehaviorBase, DefaultCloneBehaviorViaClone,
        };
        (&&&bevy_ecs::component::DefaultCloneBehaviorSpecialization::<Self>::default()).default_clone_behavior()
    }
    fn relationship_accessor()
        ->
            ::core::option::Option<bevy_ecs::relationship::ComponentRelationshipAccessor<Self>> {
        ::core::option::Option::None
    }
}Component, #[automatically_derived]
impl ::core::default::Default for VolumetricLight {
    #[inline]
    fn default() -> VolumetricLight { VolumetricLight {} }
}Default, #[automatically_derived]
impl ::core::fmt::Debug for VolumetricLight {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        ::core::fmt::Formatter::write_str(f, "VolumetricLight")
    }
}Debug, const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for VolumetricLight where  {
            fn get_type_registration() -> bevy_reflect::TypeRegistration {
                let mut registration =
                    bevy_reflect::TypeRegistration::of::<Self>();
                registration.insert::<bevy_reflect::ReflectFromPtr>(bevy_reflect::FromType::<Self>::from_type());
                registration.insert::<bevy_reflect::ReflectFromReflect>(bevy_reflect::FromType::<Self>::from_type());
                registration.register_type_data::<ReflectComponent, Self>();
                registration.register_type_data::<ReflectDefault, Self>();
                registration
            }
            #[inline(never)]
            fn register_type_dependencies(registry:
                    &mut bevy_reflect::TypeRegistry) {}
        }
        impl bevy_reflect::Typed for VolumetricLight where  {
            #[inline]
            fn type_info() -> &'static bevy_reflect::TypeInfo {
                static CELL: bevy_reflect::utility::NonGenericTypeInfoCell =
                    bevy_reflect::utility::NonGenericTypeInfoCell::new();
                CELL.get_or_set(||
                        {
                            bevy_reflect::TypeInfo::Struct(bevy_reflect::structs::StructInfo::new::<Self>(&[]))
                        })
            }
        }
        #[allow(deprecated, reason =
        "derives on a deprecated type shouldn't be considered a usage")]
        impl bevy_reflect::TypePath for VolumetricLight where  {
            fn type_path() -> &'static str {
                "bevy_light::volumetric::VolumetricLight"
            }
            fn short_type_path() -> &'static str { "VolumetricLight" }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("VolumetricLight")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_light::volumetric".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_light::volumetric")
            }
        }
        impl bevy_reflect::Reflect for VolumetricLight where  {
            #[inline]
            fn into_any(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                ->
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn ::core::any::Any> {
                self
            }
            #[inline]
            fn as_any(&self) -> &dyn ::core::any::Any { self }
            #[inline]
            fn as_any_mut(&mut self) -> &mut dyn ::core::any::Any { self }
            #[inline]
            fn into_reflect(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                ->
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::Reflect> {
                self
            }
            #[inline]
            fn as_reflect(&self) -> &dyn bevy_reflect::Reflect { self }
            #[inline]
            fn as_reflect_mut(&mut self) -> &mut dyn bevy_reflect::Reflect {
                self
            }
            #[inline]
            fn set(&mut self,
                value:
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::Reflect>)
                ->
                    ::core::result::Result<(),
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::Reflect>> {
                *self = <dyn bevy_reflect::Reflect>::take(value)?;
                ::core::result::Result::Ok(())
            }
        }
        #[allow(non_upper_case_globals)]
        const _: () =
            {
                static __INVENTORY: ::inventory::Node =
                    ::inventory::Node {
                        value: &{
                                bevy_reflect::__macro_exports::auto_register::AutomaticReflectRegistrations(<VolumetricLight
                                        as
                                        bevy_reflect::__macro_exports::auto_register::RegisterForReflection>::__register)
                            },
                        next: ::inventory::__private::UnsafeCell::new(::inventory::__private::Option::None),
                    };
                #[link_section = ".text.startup"]
                unsafe extern "C" fn __ctor() {
                    unsafe {
                        ::inventory::ErasedNode::submit(__INVENTORY.value,
                            &__INVENTORY)
                    }
                }
                #[used]
                #[link_section = ".init_array"]
                static __CTOR: unsafe extern "C" fn() = __ctor;
            };
        impl bevy_reflect::structs::Struct for VolumetricLight where  {
            fn field(&self, name: &str)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match name { _ => ::core::option::Option::None, }
            }
            fn field_mut(&mut self, name: &str)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match name { _ => ::core::option::Option::None, }
            }
            fn field_at(&self, index: usize)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match index { _ => ::core::option::Option::None, }
            }
            fn field_at_mut(&mut self, index: usize)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match index { _ => ::core::option::Option::None, }
            }
            fn name_at(&self, index: usize) -> ::core::option::Option<&str> {
                match index { _ => ::core::option::Option::None, }
            }
            fn index_of_name(&self, name: &str)
                -> ::core::option::Option<usize> {
                match name { _ => ::core::option::Option::None, }
            }
            fn field_len(&self) -> usize { 0usize }
            fn iter_fields(&self) -> bevy_reflect::structs::FieldIter {
                bevy_reflect::structs::FieldIter::new(self)
            }
            fn to_dynamic_struct(&self)
                -> bevy_reflect::structs::DynamicStruct {
                let mut dynamic: bevy_reflect::structs::DynamicStruct =
                    ::core::default::Default::default();
                dynamic.set_represented_type(bevy_reflect::PartialReflect::get_represented_type_info(self));
                dynamic
            }
        }
        impl bevy_reflect::PartialReflect for VolumetricLight where  {
            #[inline]
            fn get_represented_type_info(&self)
                -> ::core::option::Option<&'static bevy_reflect::TypeInfo> {
                ::core::option::Option::Some(<Self as
                            bevy_reflect::Typed>::type_info())
            }
            #[inline]
            fn try_apply(&mut self, value: &dyn bevy_reflect::PartialReflect)
                -> ::core::result::Result<(), bevy_reflect::ApplyError> {
                if let bevy_reflect::ReflectRef::Struct(struct_value) =
                        bevy_reflect::PartialReflect::reflect_ref(value) {
                    for (name, value) in
                        bevy_reflect::structs::Struct::iter_fields(struct_value) {
                        if let ::core::option::Option::Some(v) =
                                bevy_reflect::structs::Struct::field_mut(self, name) {
                            bevy_reflect::PartialReflect::try_apply(v, value)?;
                        }
                    }
                } else {
                    return ::core::result::Result::Err(bevy_reflect::ApplyError::MismatchedKinds {
                                from_kind: bevy_reflect::PartialReflect::reflect_kind(value),
                                to_kind: bevy_reflect::ReflectKind::Struct,
                            });
                }
                ::core::result::Result::Ok(())
            }
            #[inline]
            fn reflect_kind(&self) -> bevy_reflect::ReflectKind {
                bevy_reflect::ReflectKind::Struct
            }
            #[inline]
            fn reflect_ref(&self) -> bevy_reflect::ReflectRef {
                bevy_reflect::ReflectRef::Struct(self)
            }
            #[inline]
            fn reflect_mut(&mut self) -> bevy_reflect::ReflectMut {
                bevy_reflect::ReflectMut::Struct(self)
            }
            #[inline]
            fn reflect_owned(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                -> bevy_reflect::ReflectOwned {
                bevy_reflect::ReflectOwned::Struct(self)
            }
            #[inline]
            fn try_into_reflect(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                ->
                    ::core::result::Result<bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::Reflect>,
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::PartialReflect>> {
                ::core::result::Result::Ok(self)
            }
            #[inline]
            fn try_as_reflect(&self)
                -> ::core::option::Option<&dyn bevy_reflect::Reflect> {
                ::core::option::Option::Some(self)
            }
            #[inline]
            fn try_as_reflect_mut(&mut self)
                -> ::core::option::Option<&mut dyn bevy_reflect::Reflect> {
                ::core::option::Option::Some(self)
            }
            #[inline]
            fn into_partial_reflect(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                ->
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::PartialReflect> {
                self
            }
            #[inline]
            fn as_partial_reflect(&self)
                -> &dyn bevy_reflect::PartialReflect {
                self
            }
            #[inline]
            fn as_partial_reflect_mut(&mut self)
                -> &mut dyn bevy_reflect::PartialReflect {
                self
            }
            fn reflect_partial_eq(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<bool> {
                (bevy_reflect::structs::struct_partial_eq)(self, value)
            }
            fn reflect_partial_cmp(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<::core::cmp::Ordering> {
                (bevy_reflect::structs::struct_partial_cmp)(self, value)
            }
            fn debug(&self, f: &mut ::core::fmt::Formatter<'_>)
                -> ::core::fmt::Result {
                ::core::fmt::Debug::fmt(self, f)
            }
            #[inline]
            fn reflect_clone(&self)
                ->
                    ::core::result::Result<bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::Reflect>,
                    bevy_reflect::ReflectCloneError> {
                ::core::result::Result::Ok(bevy_reflect::__macro_exports::alloc_utils::Box::new(::core::clone::Clone::clone(self)))
            }
        }
        impl bevy_reflect::FromReflect for VolumetricLight where  {
            fn from_reflect(reflect: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<Self> {
                if let bevy_reflect::ReflectRef::Struct(__ref_struct) =
                        bevy_reflect::PartialReflect::reflect_ref(reflect) {
                    let mut __this =
                        <Self as ::core::default::Default>::default();
                    ::core::option::Option::Some(__this)
                } else { ::core::option::Option::None }
            }
        }
    };Reflect)]
15#[reflect(Component, Default, Debug, Clone)]
16pub struct VolumetricLight;
17
18/// When placed on a [`bevy_camera::Camera3d`], enables
19/// volumetric fog and volumetric lighting, also known as light shafts or god
20/// rays.
21///
22/// Requires using WebGPU on Wasm builds.
23#[derive(#[automatically_derived]
impl ::core::clone::Clone for VolumetricFog {
    #[inline]
    fn clone(&self) -> VolumetricFog {
        let _: ::core::clone::AssertParamIsClone<Color>;
        let _: ::core::clone::AssertParamIsClone<f32>;
        let _: ::core::clone::AssertParamIsClone<u32>;
        *self
    }
}Clone, #[automatically_derived]
impl ::core::marker::Copy for VolumetricFog { }Copy, impl bevy_ecs::component::Component for VolumetricFog where
    Self: ::core::marker::Send + ::core::marker::Sync + 'static {
    const STORAGE_TYPE: bevy_ecs::component::StorageType =
        bevy_ecs::component::StorageType::Table;
    type Mutability = bevy_ecs::component::Mutable;
    fn register_required_components(_requiree:
            bevy_ecs::component::ComponentId,
        required_components:
            &mut bevy_ecs::component::RequiredComponentsRegistrator) {}
    fn clone_behavior() -> bevy_ecs::component::ComponentCloneBehavior {
        use bevy_ecs::component::{
            DefaultCloneBehaviorBase, DefaultCloneBehaviorViaClone,
        };
        (&&&bevy_ecs::component::DefaultCloneBehaviorSpecialization::<Self>::default()).default_clone_behavior()
    }
    fn relationship_accessor()
        ->
            ::core::option::Option<bevy_ecs::relationship::ComponentRelationshipAccessor<Self>> {
        ::core::option::Option::None
    }
}Component, #[automatically_derived]
impl ::core::fmt::Debug for VolumetricFog {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        ::core::fmt::Formatter::debug_struct_field4_finish(f, "VolumetricFog",
            "ambient_color", &self.ambient_color, "ambient_intensity",
            &self.ambient_intensity, "jitter", &self.jitter, "step_count",
            &&self.step_count)
    }
}Debug, const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for VolumetricFog where  {
            fn get_type_registration() -> bevy_reflect::TypeRegistration {
                let mut registration =
                    bevy_reflect::TypeRegistration::of::<Self>();
                registration.insert::<bevy_reflect::ReflectFromPtr>(bevy_reflect::FromType::<Self>::from_type());
                registration.insert::<bevy_reflect::ReflectFromReflect>(bevy_reflect::FromType::<Self>::from_type());
                registration.register_type_data::<ReflectComponent, Self>();
                registration.register_type_data::<ReflectDefault, Self>();
                registration
            }
            #[inline(never)]
            fn register_type_dependencies(registry:
                    &mut bevy_reflect::TypeRegistry) {
                <Color as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <f32 as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <u32 as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
            }
        }
        impl bevy_reflect::Typed for VolumetricFog where  {
            #[inline]
            fn type_info() -> &'static bevy_reflect::TypeInfo {
                static CELL: bevy_reflect::utility::NonGenericTypeInfoCell =
                    bevy_reflect::utility::NonGenericTypeInfoCell::new();
                CELL.get_or_set(||
                        {
                            bevy_reflect::TypeInfo::Struct(bevy_reflect::structs::StructInfo::new::<Self>(&[bevy_reflect::NamedField::new::<Color>("ambient_color"),
                                                bevy_reflect::NamedField::new::<f32>("ambient_intensity"),
                                                bevy_reflect::NamedField::new::<f32>("jitter"),
                                                bevy_reflect::NamedField::new::<u32>("step_count")]))
                        })
            }
        }
        #[allow(deprecated, reason =
        "derives on a deprecated type shouldn't be considered a usage")]
        impl bevy_reflect::TypePath for VolumetricFog where  {
            fn type_path() -> &'static str {
                "bevy_light::volumetric::VolumetricFog"
            }
            fn short_type_path() -> &'static str { "VolumetricFog" }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("VolumetricFog")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_light::volumetric".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_light::volumetric")
            }
        }
        impl bevy_reflect::Reflect for VolumetricFog where  {
            #[inline]
            fn into_any(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                ->
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn ::core::any::Any> {
                self
            }
            #[inline]
            fn as_any(&self) -> &dyn ::core::any::Any { self }
            #[inline]
            fn as_any_mut(&mut self) -> &mut dyn ::core::any::Any { self }
            #[inline]
            fn into_reflect(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                ->
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::Reflect> {
                self
            }
            #[inline]
            fn as_reflect(&self) -> &dyn bevy_reflect::Reflect { self }
            #[inline]
            fn as_reflect_mut(&mut self) -> &mut dyn bevy_reflect::Reflect {
                self
            }
            #[inline]
            fn set(&mut self,
                value:
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::Reflect>)
                ->
                    ::core::result::Result<(),
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::Reflect>> {
                *self = <dyn bevy_reflect::Reflect>::take(value)?;
                ::core::result::Result::Ok(())
            }
        }
        #[allow(non_upper_case_globals)]
        const _: () =
            {
                static __INVENTORY: ::inventory::Node =
                    ::inventory::Node {
                        value: &{
                                bevy_reflect::__macro_exports::auto_register::AutomaticReflectRegistrations(<VolumetricFog
                                        as
                                        bevy_reflect::__macro_exports::auto_register::RegisterForReflection>::__register)
                            },
                        next: ::inventory::__private::UnsafeCell::new(::inventory::__private::Option::None),
                    };
                #[link_section = ".text.startup"]
                unsafe extern "C" fn __ctor() {
                    unsafe {
                        ::inventory::ErasedNode::submit(__INVENTORY.value,
                            &__INVENTORY)
                    }
                }
                #[used]
                #[link_section = ".init_array"]
                static __CTOR: unsafe extern "C" fn() = __ctor;
            };
        impl bevy_reflect::structs::Struct for VolumetricFog where  {
            fn field(&self, name: &str)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match name {
                    "ambient_color" =>
                        ::core::option::Option::Some(&self.ambient_color),
                    "ambient_intensity" =>
                        ::core::option::Option::Some(&self.ambient_intensity),
                    "jitter" => ::core::option::Option::Some(&self.jitter),
                    "step_count" =>
                        ::core::option::Option::Some(&self.step_count),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_mut(&mut self, name: &str)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match name {
                    "ambient_color" =>
                        ::core::option::Option::Some(&mut self.ambient_color),
                    "ambient_intensity" =>
                        ::core::option::Option::Some(&mut self.ambient_intensity),
                    "jitter" => ::core::option::Option::Some(&mut self.jitter),
                    "step_count" =>
                        ::core::option::Option::Some(&mut self.step_count),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_at(&self, index: usize)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match index {
                    0usize => ::core::option::Option::Some(&self.ambient_color),
                    1usize =>
                        ::core::option::Option::Some(&self.ambient_intensity),
                    2usize => ::core::option::Option::Some(&self.jitter),
                    3usize => ::core::option::Option::Some(&self.step_count),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_at_mut(&mut self, index: usize)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match index {
                    0usize =>
                        ::core::option::Option::Some(&mut self.ambient_color),
                    1usize =>
                        ::core::option::Option::Some(&mut self.ambient_intensity),
                    2usize => ::core::option::Option::Some(&mut self.jitter),
                    3usize =>
                        ::core::option::Option::Some(&mut self.step_count),
                    _ => ::core::option::Option::None,
                }
            }
            fn name_at(&self, index: usize) -> ::core::option::Option<&str> {
                match index {
                    0usize => ::core::option::Option::Some("ambient_color"),
                    1usize => ::core::option::Option::Some("ambient_intensity"),
                    2usize => ::core::option::Option::Some("jitter"),
                    3usize => ::core::option::Option::Some("step_count"),
                    _ => ::core::option::Option::None,
                }
            }
            fn index_of_name(&self, name: &str)
                -> ::core::option::Option<usize> {
                match name {
                    "ambient_color" => ::core::option::Option::Some(0usize),
                    "ambient_intensity" => ::core::option::Option::Some(1usize),
                    "jitter" => ::core::option::Option::Some(2usize),
                    "step_count" => ::core::option::Option::Some(3usize),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_len(&self) -> usize { 4usize }
            fn iter_fields(&self) -> bevy_reflect::structs::FieldIter {
                bevy_reflect::structs::FieldIter::new(self)
            }
            fn to_dynamic_struct(&self)
                -> bevy_reflect::structs::DynamicStruct {
                let mut dynamic: bevy_reflect::structs::DynamicStruct =
                    ::core::default::Default::default();
                dynamic.set_represented_type(bevy_reflect::PartialReflect::get_represented_type_info(self));
                dynamic.insert_boxed("ambient_color",
                    bevy_reflect::PartialReflect::to_dynamic(&self.ambient_color));
                dynamic.insert_boxed("ambient_intensity",
                    bevy_reflect::PartialReflect::to_dynamic(&self.ambient_intensity));
                dynamic.insert_boxed("jitter",
                    bevy_reflect::PartialReflect::to_dynamic(&self.jitter));
                dynamic.insert_boxed("step_count",
                    bevy_reflect::PartialReflect::to_dynamic(&self.step_count));
                dynamic
            }
        }
        impl bevy_reflect::PartialReflect for VolumetricFog where  {
            #[inline]
            fn get_represented_type_info(&self)
                -> ::core::option::Option<&'static bevy_reflect::TypeInfo> {
                ::core::option::Option::Some(<Self as
                            bevy_reflect::Typed>::type_info())
            }
            #[inline]
            fn try_apply(&mut self, value: &dyn bevy_reflect::PartialReflect)
                -> ::core::result::Result<(), bevy_reflect::ApplyError> {
                if let bevy_reflect::ReflectRef::Struct(struct_value) =
                        bevy_reflect::PartialReflect::reflect_ref(value) {
                    for (name, value) in
                        bevy_reflect::structs::Struct::iter_fields(struct_value) {
                        if let ::core::option::Option::Some(v) =
                                bevy_reflect::structs::Struct::field_mut(self, name) {
                            bevy_reflect::PartialReflect::try_apply(v, value)?;
                        }
                    }
                } else {
                    return ::core::result::Result::Err(bevy_reflect::ApplyError::MismatchedKinds {
                                from_kind: bevy_reflect::PartialReflect::reflect_kind(value),
                                to_kind: bevy_reflect::ReflectKind::Struct,
                            });
                }
                ::core::result::Result::Ok(())
            }
            #[inline]
            fn reflect_kind(&self) -> bevy_reflect::ReflectKind {
                bevy_reflect::ReflectKind::Struct
            }
            #[inline]
            fn reflect_ref(&self) -> bevy_reflect::ReflectRef {
                bevy_reflect::ReflectRef::Struct(self)
            }
            #[inline]
            fn reflect_mut(&mut self) -> bevy_reflect::ReflectMut {
                bevy_reflect::ReflectMut::Struct(self)
            }
            #[inline]
            fn reflect_owned(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                -> bevy_reflect::ReflectOwned {
                bevy_reflect::ReflectOwned::Struct(self)
            }
            #[inline]
            fn try_into_reflect(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                ->
                    ::core::result::Result<bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::Reflect>,
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::PartialReflect>> {
                ::core::result::Result::Ok(self)
            }
            #[inline]
            fn try_as_reflect(&self)
                -> ::core::option::Option<&dyn bevy_reflect::Reflect> {
                ::core::option::Option::Some(self)
            }
            #[inline]
            fn try_as_reflect_mut(&mut self)
                -> ::core::option::Option<&mut dyn bevy_reflect::Reflect> {
                ::core::option::Option::Some(self)
            }
            #[inline]
            fn into_partial_reflect(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                ->
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::PartialReflect> {
                self
            }
            #[inline]
            fn as_partial_reflect(&self)
                -> &dyn bevy_reflect::PartialReflect {
                self
            }
            #[inline]
            fn as_partial_reflect_mut(&mut self)
                -> &mut dyn bevy_reflect::PartialReflect {
                self
            }
            fn reflect_partial_eq(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<bool> {
                (bevy_reflect::structs::struct_partial_eq)(self, value)
            }
            fn reflect_partial_cmp(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<::core::cmp::Ordering> {
                (bevy_reflect::structs::struct_partial_cmp)(self, value)
            }
            fn debug(&self, f: &mut ::core::fmt::Formatter<'_>)
                -> ::core::fmt::Result {
                ::core::fmt::Debug::fmt(self, f)
            }
            #[inline]
            fn reflect_clone(&self)
                ->
                    ::core::result::Result<bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::Reflect>,
                    bevy_reflect::ReflectCloneError> {
                ::core::result::Result::Ok(bevy_reflect::__macro_exports::alloc_utils::Box::new(::core::clone::Clone::clone(self)))
            }
        }
        impl bevy_reflect::FromReflect for VolumetricFog where  {
            fn from_reflect(reflect: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<Self> {
                if let bevy_reflect::ReflectRef::Struct(__ref_struct) =
                        bevy_reflect::PartialReflect::reflect_ref(reflect) {
                    let mut __this =
                        <Self as ::core::default::Default>::default();
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <Color as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "ambient_color")?))() {
                        __this.ambient_color = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <f32 as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "ambient_intensity")?))() {
                        __this.ambient_intensity = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <f32 as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "jitter")?))() {
                        __this.jitter = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <u32 as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "step_count")?))() {
                        __this.step_count = __field;
                    }
                    ::core::option::Option::Some(__this)
                } else { ::core::option::Option::None }
            }
        }
    };Reflect)]
24#[reflect(Component, Default, Debug, Clone)]
25pub struct VolumetricFog {
26    /// Color of the ambient light.
27    ///
28    /// This is separate from Bevy's [`AmbientLight`](crate::AmbientLight) because an
29    /// [`EnvironmentMapLight`](crate::EnvironmentMapLight) is
30    /// still considered an ambient light for the purposes of volumetric fog. If you're using a
31    /// [`EnvironmentMapLight`](crate::EnvironmentMapLight), for best results,
32    /// this should be a good approximation of the average color of the environment map.
33    ///
34    /// Defaults to white.
35    pub ambient_color: Color,
36
37    /// The brightness of the ambient light.
38    ///
39    /// If there's no [`EnvironmentMapLight`](crate::EnvironmentMapLight),
40    /// set this to 0.
41    ///
42    /// Defaults to 0.1.
43    pub ambient_intensity: f32,
44
45    /// The maximum distance to offset the ray origin randomly by, in meters.
46    ///
47    /// This is intended for use with temporal antialiasing. It helps fog look
48    /// less blocky by varying the start position of the ray, using interleaved
49    /// gradient noise.
50    pub jitter: f32,
51
52    /// The number of raymarching steps to perform.
53    ///
54    /// Higher values produce higher-quality results with less banding, but
55    /// reduce performance.
56    ///
57    /// The default value is 64.
58    pub step_count: u32,
59}
60
61impl Default for VolumetricFog {
62    fn default() -> Self {
63        Self {
64            step_count: 64,
65            // Matches `AmbientLight` defaults.
66            ambient_color: Color::WHITE,
67            ambient_intensity: 0.1,
68            jitter: 0.0,
69        }
70    }
71}
72
73/// A unit cube of fog at the origin. Can be positioned and scaled with a [`Transform`].
74/// Only visible by cameras with a [`VolumetricFog`] component when lit by a directional light with [`VolumetricLight`].
75#[derive(#[automatically_derived]
impl ::core::clone::Clone for FogVolume {
    #[inline]
    fn clone(&self) -> FogVolume {
        FogVolume {
            fog_color: ::core::clone::Clone::clone(&self.fog_color),
            density_factor: ::core::clone::Clone::clone(&self.density_factor),
            density_texture: ::core::clone::Clone::clone(&self.density_texture),
            density_texture_offset: ::core::clone::Clone::clone(&self.density_texture_offset),
            absorption: ::core::clone::Clone::clone(&self.absorption),
            scattering: ::core::clone::Clone::clone(&self.scattering),
            scattering_asymmetry: ::core::clone::Clone::clone(&self.scattering_asymmetry),
            light_tint: ::core::clone::Clone::clone(&self.light_tint),
            light_intensity: ::core::clone::Clone::clone(&self.light_intensity),
        }
    }
}Clone, #[doc =
"**Required Components**: [`Transform`], [`Visibility`]. \n\n A component's Required Components are inserted whenever it is inserted. Note that this will also insert the required components _of_ the required components, recursively, in depth-first order."]
impl bevy_ecs::component::Component for FogVolume where
    Self: ::core::marker::Send + ::core::marker::Sync + 'static {
    const STORAGE_TYPE: bevy_ecs::component::StorageType =
        bevy_ecs::component::StorageType::Table;
    type Mutability = bevy_ecs::component::Mutable;
    fn register_required_components(_requiree:
            bevy_ecs::component::ComponentId,
        required_components:
            &mut bevy_ecs::component::RequiredComponentsRegistrator) {
        required_components.register_required::<Transform>(<Transform as
                ::core::default::Default>::default);
        required_components.register_required::<Visibility>(<Visibility as
                ::core::default::Default>::default);
    }
    fn clone_behavior() -> bevy_ecs::component::ComponentCloneBehavior {
        use bevy_ecs::component::{
            DefaultCloneBehaviorBase, DefaultCloneBehaviorViaClone,
        };
        (&&&bevy_ecs::component::DefaultCloneBehaviorSpecialization::<Self>::default()).default_clone_behavior()
    }
    fn relationship_accessor()
        ->
            ::core::option::Option<bevy_ecs::relationship::ComponentRelationshipAccessor<Self>> {
        ::core::option::Option::None
    }
}Component, #[automatically_derived]
impl ::core::fmt::Debug for FogVolume {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        let names: &'static _ =
            &["fog_color", "density_factor", "density_texture",
                        "density_texture_offset", "absorption", "scattering",
                        "scattering_asymmetry", "light_tint", "light_intensity"];
        let values: &[&dyn ::core::fmt::Debug] =
            &[&self.fog_color, &self.density_factor, &self.density_texture,
                        &self.density_texture_offset, &self.absorption,
                        &self.scattering, &self.scattering_asymmetry,
                        &self.light_tint, &&self.light_intensity];
        ::core::fmt::Formatter::debug_struct_fields_finish(f, "FogVolume",
            names, values)
    }
}Debug, const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for FogVolume where  {
            fn get_type_registration() -> bevy_reflect::TypeRegistration {
                let mut registration =
                    bevy_reflect::TypeRegistration::of::<Self>();
                registration.insert::<bevy_reflect::ReflectFromPtr>(bevy_reflect::FromType::<Self>::from_type());
                registration.insert::<bevy_reflect::ReflectFromReflect>(bevy_reflect::FromType::<Self>::from_type());
                registration.register_type_data::<ReflectComponent, Self>();
                registration.register_type_data::<ReflectDefault, Self>();
                registration
            }
            #[inline(never)]
            fn register_type_dependencies(registry:
                    &mut bevy_reflect::TypeRegistry) {
                <Color as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <f32 as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <Option<Handle<Image>> as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <Vec3 as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
            }
        }
        impl bevy_reflect::Typed for FogVolume where  {
            #[inline]
            fn type_info() -> &'static bevy_reflect::TypeInfo {
                static CELL: bevy_reflect::utility::NonGenericTypeInfoCell =
                    bevy_reflect::utility::NonGenericTypeInfoCell::new();
                CELL.get_or_set(||
                        {
                            bevy_reflect::TypeInfo::Struct(bevy_reflect::structs::StructInfo::new::<Self>(&[bevy_reflect::NamedField::new::<Color>("fog_color"),
                                                bevy_reflect::NamedField::new::<f32>("density_factor"),
                                                bevy_reflect::NamedField::new::<Option<Handle<Image>>>("density_texture"),
                                                bevy_reflect::NamedField::new::<Vec3>("density_texture_offset"),
                                                bevy_reflect::NamedField::new::<f32>("absorption"),
                                                bevy_reflect::NamedField::new::<f32>("scattering"),
                                                bevy_reflect::NamedField::new::<f32>("scattering_asymmetry"),
                                                bevy_reflect::NamedField::new::<Color>("light_tint"),
                                                bevy_reflect::NamedField::new::<f32>("light_intensity")]))
                        })
            }
        }
        #[allow(deprecated, reason =
        "derives on a deprecated type shouldn't be considered a usage")]
        impl bevy_reflect::TypePath for FogVolume where  {
            fn type_path() -> &'static str {
                "bevy_light::volumetric::FogVolume"
            }
            fn short_type_path() -> &'static str { "FogVolume" }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("FogVolume")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_light::volumetric".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_light::volumetric")
            }
        }
        impl bevy_reflect::Reflect for FogVolume where  {
            #[inline]
            fn into_any(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                ->
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn ::core::any::Any> {
                self
            }
            #[inline]
            fn as_any(&self) -> &dyn ::core::any::Any { self }
            #[inline]
            fn as_any_mut(&mut self) -> &mut dyn ::core::any::Any { self }
            #[inline]
            fn into_reflect(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                ->
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::Reflect> {
                self
            }
            #[inline]
            fn as_reflect(&self) -> &dyn bevy_reflect::Reflect { self }
            #[inline]
            fn as_reflect_mut(&mut self) -> &mut dyn bevy_reflect::Reflect {
                self
            }
            #[inline]
            fn set(&mut self,
                value:
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::Reflect>)
                ->
                    ::core::result::Result<(),
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::Reflect>> {
                *self = <dyn bevy_reflect::Reflect>::take(value)?;
                ::core::result::Result::Ok(())
            }
        }
        #[allow(non_upper_case_globals)]
        const _: () =
            {
                static __INVENTORY: ::inventory::Node =
                    ::inventory::Node {
                        value: &{
                                bevy_reflect::__macro_exports::auto_register::AutomaticReflectRegistrations(<FogVolume
                                        as
                                        bevy_reflect::__macro_exports::auto_register::RegisterForReflection>::__register)
                            },
                        next: ::inventory::__private::UnsafeCell::new(::inventory::__private::Option::None),
                    };
                #[link_section = ".text.startup"]
                unsafe extern "C" fn __ctor() {
                    unsafe {
                        ::inventory::ErasedNode::submit(__INVENTORY.value,
                            &__INVENTORY)
                    }
                }
                #[used]
                #[link_section = ".init_array"]
                static __CTOR: unsafe extern "C" fn() = __ctor;
            };
        impl bevy_reflect::structs::Struct for FogVolume where  {
            fn field(&self, name: &str)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match name {
                    "fog_color" =>
                        ::core::option::Option::Some(&self.fog_color),
                    "density_factor" =>
                        ::core::option::Option::Some(&self.density_factor),
                    "density_texture" =>
                        ::core::option::Option::Some(&self.density_texture),
                    "density_texture_offset" =>
                        ::core::option::Option::Some(&self.density_texture_offset),
                    "absorption" =>
                        ::core::option::Option::Some(&self.absorption),
                    "scattering" =>
                        ::core::option::Option::Some(&self.scattering),
                    "scattering_asymmetry" =>
                        ::core::option::Option::Some(&self.scattering_asymmetry),
                    "light_tint" =>
                        ::core::option::Option::Some(&self.light_tint),
                    "light_intensity" =>
                        ::core::option::Option::Some(&self.light_intensity),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_mut(&mut self, name: &str)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match name {
                    "fog_color" =>
                        ::core::option::Option::Some(&mut self.fog_color),
                    "density_factor" =>
                        ::core::option::Option::Some(&mut self.density_factor),
                    "density_texture" =>
                        ::core::option::Option::Some(&mut self.density_texture),
                    "density_texture_offset" =>
                        ::core::option::Option::Some(&mut self.density_texture_offset),
                    "absorption" =>
                        ::core::option::Option::Some(&mut self.absorption),
                    "scattering" =>
                        ::core::option::Option::Some(&mut self.scattering),
                    "scattering_asymmetry" =>
                        ::core::option::Option::Some(&mut self.scattering_asymmetry),
                    "light_tint" =>
                        ::core::option::Option::Some(&mut self.light_tint),
                    "light_intensity" =>
                        ::core::option::Option::Some(&mut self.light_intensity),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_at(&self, index: usize)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match index {
                    0usize => ::core::option::Option::Some(&self.fog_color),
                    1usize =>
                        ::core::option::Option::Some(&self.density_factor),
                    2usize =>
                        ::core::option::Option::Some(&self.density_texture),
                    3usize =>
                        ::core::option::Option::Some(&self.density_texture_offset),
                    4usize => ::core::option::Option::Some(&self.absorption),
                    5usize => ::core::option::Option::Some(&self.scattering),
                    6usize =>
                        ::core::option::Option::Some(&self.scattering_asymmetry),
                    7usize => ::core::option::Option::Some(&self.light_tint),
                    8usize =>
                        ::core::option::Option::Some(&self.light_intensity),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_at_mut(&mut self, index: usize)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match index {
                    0usize => ::core::option::Option::Some(&mut self.fog_color),
                    1usize =>
                        ::core::option::Option::Some(&mut self.density_factor),
                    2usize =>
                        ::core::option::Option::Some(&mut self.density_texture),
                    3usize =>
                        ::core::option::Option::Some(&mut self.density_texture_offset),
                    4usize =>
                        ::core::option::Option::Some(&mut self.absorption),
                    5usize =>
                        ::core::option::Option::Some(&mut self.scattering),
                    6usize =>
                        ::core::option::Option::Some(&mut self.scattering_asymmetry),
                    7usize =>
                        ::core::option::Option::Some(&mut self.light_tint),
                    8usize =>
                        ::core::option::Option::Some(&mut self.light_intensity),
                    _ => ::core::option::Option::None,
                }
            }
            fn name_at(&self, index: usize) -> ::core::option::Option<&str> {
                match index {
                    0usize => ::core::option::Option::Some("fog_color"),
                    1usize => ::core::option::Option::Some("density_factor"),
                    2usize => ::core::option::Option::Some("density_texture"),
                    3usize =>
                        ::core::option::Option::Some("density_texture_offset"),
                    4usize => ::core::option::Option::Some("absorption"),
                    5usize => ::core::option::Option::Some("scattering"),
                    6usize =>
                        ::core::option::Option::Some("scattering_asymmetry"),
                    7usize => ::core::option::Option::Some("light_tint"),
                    8usize => ::core::option::Option::Some("light_intensity"),
                    _ => ::core::option::Option::None,
                }
            }
            fn index_of_name(&self, name: &str)
                -> ::core::option::Option<usize> {
                match name {
                    "fog_color" => ::core::option::Option::Some(0usize),
                    "density_factor" => ::core::option::Option::Some(1usize),
                    "density_texture" => ::core::option::Option::Some(2usize),
                    "density_texture_offset" =>
                        ::core::option::Option::Some(3usize),
                    "absorption" => ::core::option::Option::Some(4usize),
                    "scattering" => ::core::option::Option::Some(5usize),
                    "scattering_asymmetry" =>
                        ::core::option::Option::Some(6usize),
                    "light_tint" => ::core::option::Option::Some(7usize),
                    "light_intensity" => ::core::option::Option::Some(8usize),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_len(&self) -> usize { 9usize }
            fn iter_fields(&self) -> bevy_reflect::structs::FieldIter {
                bevy_reflect::structs::FieldIter::new(self)
            }
            fn to_dynamic_struct(&self)
                -> bevy_reflect::structs::DynamicStruct {
                let mut dynamic: bevy_reflect::structs::DynamicStruct =
                    ::core::default::Default::default();
                dynamic.set_represented_type(bevy_reflect::PartialReflect::get_represented_type_info(self));
                dynamic.insert_boxed("fog_color",
                    bevy_reflect::PartialReflect::to_dynamic(&self.fog_color));
                dynamic.insert_boxed("density_factor",
                    bevy_reflect::PartialReflect::to_dynamic(&self.density_factor));
                dynamic.insert_boxed("density_texture",
                    bevy_reflect::PartialReflect::to_dynamic(&self.density_texture));
                dynamic.insert_boxed("density_texture_offset",
                    bevy_reflect::PartialReflect::to_dynamic(&self.density_texture_offset));
                dynamic.insert_boxed("absorption",
                    bevy_reflect::PartialReflect::to_dynamic(&self.absorption));
                dynamic.insert_boxed("scattering",
                    bevy_reflect::PartialReflect::to_dynamic(&self.scattering));
                dynamic.insert_boxed("scattering_asymmetry",
                    bevy_reflect::PartialReflect::to_dynamic(&self.scattering_asymmetry));
                dynamic.insert_boxed("light_tint",
                    bevy_reflect::PartialReflect::to_dynamic(&self.light_tint));
                dynamic.insert_boxed("light_intensity",
                    bevy_reflect::PartialReflect::to_dynamic(&self.light_intensity));
                dynamic
            }
        }
        impl bevy_reflect::PartialReflect for FogVolume where  {
            #[inline]
            fn get_represented_type_info(&self)
                -> ::core::option::Option<&'static bevy_reflect::TypeInfo> {
                ::core::option::Option::Some(<Self as
                            bevy_reflect::Typed>::type_info())
            }
            #[inline]
            fn try_apply(&mut self, value: &dyn bevy_reflect::PartialReflect)
                -> ::core::result::Result<(), bevy_reflect::ApplyError> {
                if let bevy_reflect::ReflectRef::Struct(struct_value) =
                        bevy_reflect::PartialReflect::reflect_ref(value) {
                    for (name, value) in
                        bevy_reflect::structs::Struct::iter_fields(struct_value) {
                        if let ::core::option::Option::Some(v) =
                                bevy_reflect::structs::Struct::field_mut(self, name) {
                            bevy_reflect::PartialReflect::try_apply(v, value)?;
                        }
                    }
                } else {
                    return ::core::result::Result::Err(bevy_reflect::ApplyError::MismatchedKinds {
                                from_kind: bevy_reflect::PartialReflect::reflect_kind(value),
                                to_kind: bevy_reflect::ReflectKind::Struct,
                            });
                }
                ::core::result::Result::Ok(())
            }
            #[inline]
            fn reflect_kind(&self) -> bevy_reflect::ReflectKind {
                bevy_reflect::ReflectKind::Struct
            }
            #[inline]
            fn reflect_ref(&self) -> bevy_reflect::ReflectRef {
                bevy_reflect::ReflectRef::Struct(self)
            }
            #[inline]
            fn reflect_mut(&mut self) -> bevy_reflect::ReflectMut {
                bevy_reflect::ReflectMut::Struct(self)
            }
            #[inline]
            fn reflect_owned(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                -> bevy_reflect::ReflectOwned {
                bevy_reflect::ReflectOwned::Struct(self)
            }
            #[inline]
            fn try_into_reflect(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                ->
                    ::core::result::Result<bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::Reflect>,
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::PartialReflect>> {
                ::core::result::Result::Ok(self)
            }
            #[inline]
            fn try_as_reflect(&self)
                -> ::core::option::Option<&dyn bevy_reflect::Reflect> {
                ::core::option::Option::Some(self)
            }
            #[inline]
            fn try_as_reflect_mut(&mut self)
                -> ::core::option::Option<&mut dyn bevy_reflect::Reflect> {
                ::core::option::Option::Some(self)
            }
            #[inline]
            fn into_partial_reflect(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                ->
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::PartialReflect> {
                self
            }
            #[inline]
            fn as_partial_reflect(&self)
                -> &dyn bevy_reflect::PartialReflect {
                self
            }
            #[inline]
            fn as_partial_reflect_mut(&mut self)
                -> &mut dyn bevy_reflect::PartialReflect {
                self
            }
            fn reflect_partial_eq(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<bool> {
                (bevy_reflect::structs::struct_partial_eq)(self, value)
            }
            fn reflect_partial_cmp(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<::core::cmp::Ordering> {
                (bevy_reflect::structs::struct_partial_cmp)(self, value)
            }
            fn debug(&self, f: &mut ::core::fmt::Formatter<'_>)
                -> ::core::fmt::Result {
                ::core::fmt::Debug::fmt(self, f)
            }
            #[inline]
            fn reflect_clone(&self)
                ->
                    ::core::result::Result<bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::Reflect>,
                    bevy_reflect::ReflectCloneError> {
                ::core::result::Result::Ok(bevy_reflect::__macro_exports::alloc_utils::Box::new(::core::clone::Clone::clone(self)))
            }
        }
        impl bevy_reflect::FromReflect for FogVolume where  {
            fn from_reflect(reflect: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<Self> {
                if let bevy_reflect::ReflectRef::Struct(__ref_struct) =
                        bevy_reflect::PartialReflect::reflect_ref(reflect) {
                    let mut __this =
                        <Self as ::core::default::Default>::default();
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <Color as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "fog_color")?))() {
                        __this.fog_color = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <f32 as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "density_factor")?))() {
                        __this.density_factor = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <Option<Handle<Image>> as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "density_texture")?))() {
                        __this.density_texture = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <Vec3 as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "density_texture_offset")?))() {
                        __this.density_texture_offset = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <f32 as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "absorption")?))() {
                        __this.absorption = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <f32 as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "scattering")?))() {
                        __this.scattering = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <f32 as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "scattering_asymmetry")?))() {
                        __this.scattering_asymmetry = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <Color as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "light_tint")?))() {
                        __this.light_tint = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <f32 as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "light_intensity")?))() {
                        __this.light_intensity = __field;
                    }
                    ::core::option::Option::Some(__this)
                } else { ::core::option::Option::None }
            }
        }
    };Reflect)]
76#[reflect(Component, Default, Debug, Clone)]
77#[require(Transform, Visibility)]
78pub struct FogVolume {
79    /// The color of the fog.
80    ///
81    /// Note that the fog must be lit by a [`VolumetricLight`] or ambient light
82    /// in order for this color to appear.
83    ///
84    /// Defaults to white.
85    pub fog_color: Color,
86
87    /// The density of fog, which measures how dark the fog is.
88    ///
89    /// The default value is 0.1.
90    pub density_factor: f32,
91
92    /// Optional 3D voxel density texture for the fog.
93    pub density_texture: Option<Handle<Image>>,
94
95    /// Configurable offset of the density texture in UVW coordinates.
96    ///
97    /// This can be used to scroll a repeating density texture in a direction over time
98    /// to create effects like fog moving in the wind. Make sure to configure the texture
99    /// to use `ImageAddressMode::Repeat` if this is your intention.
100    ///
101    /// Has no effect when no density texture is present.
102    ///
103    /// The default value is (0, 0, 0).
104    pub density_texture_offset: Vec3,
105
106    /// The absorption coefficient, which measures what fraction of light is
107    /// absorbed by the fog at each step.
108    ///
109    /// Increasing this value makes the fog darker.
110    ///
111    /// The default value is 0.3.
112    pub absorption: f32,
113
114    /// The scattering coefficient, which measures the fraction of light that's
115    /// scattered toward, and away from, the viewer.
116    ///
117    /// The default value is 0.3.
118    pub scattering: f32,
119
120    /// Measures the fraction of light that's scattered *toward* the camera, as
121    /// opposed to *away* from the camera.
122    ///
123    /// Increasing this value makes light shafts become more prominent when the
124    /// camera is facing toward their source and less prominent when the camera
125    /// is facing away. Essentially, a high value here means the light shafts
126    /// will fade into view as the camera focuses on them and fade away when the
127    /// camera is pointing away.
128    ///
129    /// The default value is 0.8.
130    pub scattering_asymmetry: f32,
131
132    /// Applies a nonphysical color to the light.
133    ///
134    /// This can be useful for artistic purposes but is nonphysical.
135    ///
136    /// The default value is white.
137    pub light_tint: Color,
138
139    /// Scales the light by a fixed fraction.
140    ///
141    /// This can be useful for artistic purposes but is nonphysical.
142    ///
143    /// The default value is 1.0, which results in no adjustment.
144    pub light_intensity: f32,
145}
146
147impl Default for FogVolume {
148    fn default() -> Self {
149        Self {
150            absorption: 0.3,
151            scattering: 0.3,
152            density_factor: 0.1,
153            density_texture: None,
154            density_texture_offset: Vec3::ZERO,
155            scattering_asymmetry: 0.5,
156            fog_color: Color::WHITE,
157            light_tint: Color::WHITE,
158            light_intensity: 1.0,
159        }
160    }
161}