Skip to main content

bevy_camera/
camera.rs

1use crate::primitives::Frustum;
2
3use super::{
4    visibility::{Visibility, VisibleEntities},
5    ClearColorConfig, MsaaWriteback,
6};
7use bevy_asset::Handle;
8use bevy_derive::Deref;
9use bevy_ecs::{
10    component::Component, entity::Entity, reflect::ReflectComponent, template::FromTemplate,
11};
12use bevy_image::Image;
13use bevy_math::{ops, Dir3, FloatOrd, Mat4, Ray3d, Rect, URect, UVec2, Vec2, Vec3, Vec3A};
14use bevy_reflect::prelude::*;
15use bevy_transform::components::{GlobalTransform, Transform};
16use bevy_window::{NormalizedWindowRef, WindowRef};
17use core::ops::Range;
18use derive_more::derive::From;
19use thiserror::Error;
20use wgpu_types::{BlendState, TextureUsages};
21
22/// Render viewport configuration for the [`Camera`] component.
23///
24/// The viewport defines the area on the render target to which the camera renders its image.
25/// You can overlay multiple cameras in a single window using viewports to create effects like
26/// split screen, minimaps, and character viewers.
27///
28/// <div class="warning">
29///
30/// Note that the physical position is in actual screen coordinates and not virtual pixels for window targets.  
31/// You should use the scaling factor reported by the window, which on some OS's defaults to a value other than 1.
32/// Please see the example code (which assumes a single camera and window)
33///
34/// ```no_run
35/// # use bevy_camera::{Camera, Projection, Viewport};
36/// # use bevy_transform::prelude::Transform;
37/// # use bevy_ecs::prelude::*;
38/// # use bevy_math::UVec2;
39/// # use bevy_window::Window;
40/// # use bevy_utils::default;
41///
42/// fn update_viewport(
43///    mut camera_query: Query<(&mut Camera, &mut Transform, &mut Projection)>,
44///    windows: Query<&Window>
45/// ) {
46///     let Ok((mut camera, _, _)) = camera_query.single_mut() else { return; };
47///
48///     let window = windows.single().expect("Window not found");
49///     let scale = window.resolution.scale_factor();
50///
51///     camera.viewport = Some(Viewport {
52///         physical_position: (UVec2::new(10, 10).as_vec2() * scale).as_uvec2(),
53///         physical_size: (UVec2::new(100, 100).as_vec2() * scale).as_uvec2(),
54///         ..default()
55///     });
56/// }
57/// ```
58///
59/// </div>
60#[derive(const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for Viewport 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::<ReflectDefault, Self>();
                registration
            }
            #[inline(never)]
            fn register_type_dependencies(registry:
                    &mut bevy_reflect::TypeRegistry) {
                <UVec2 as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <Range<f32> as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
            }
        }
        impl bevy_reflect::Typed for Viewport 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::<UVec2>("physical_position"),
                                                bevy_reflect::NamedField::new::<UVec2>("physical_size"),
                                                bevy_reflect::NamedField::new::<Range<f32>>("depth")]))
                        })
            }
        }
        #[allow(deprecated, reason =
        "derives on a deprecated type shouldn't be considered a usage")]
        impl bevy_reflect::TypePath for Viewport where  {
            fn type_path() -> &'static str { "bevy_camera::camera::Viewport" }
            fn short_type_path() -> &'static str { "Viewport" }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("Viewport")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera")
            }
        }
        impl bevy_reflect::Reflect for Viewport 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(<Viewport
                                        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 Viewport where  {
            fn field(&self, name: &str)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match name {
                    "physical_position" =>
                        ::core::option::Option::Some(&self.physical_position),
                    "physical_size" =>
                        ::core::option::Option::Some(&self.physical_size),
                    "depth" => ::core::option::Option::Some(&self.depth),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_mut(&mut self, name: &str)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match name {
                    "physical_position" =>
                        ::core::option::Option::Some(&mut self.physical_position),
                    "physical_size" =>
                        ::core::option::Option::Some(&mut self.physical_size),
                    "depth" => ::core::option::Option::Some(&mut self.depth),
                    _ => ::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.physical_position),
                    1usize => ::core::option::Option::Some(&self.physical_size),
                    2usize => ::core::option::Option::Some(&self.depth),
                    _ => ::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.physical_position),
                    1usize =>
                        ::core::option::Option::Some(&mut self.physical_size),
                    2usize => ::core::option::Option::Some(&mut self.depth),
                    _ => ::core::option::Option::None,
                }
            }
            fn name_at(&self, index: usize) -> ::core::option::Option<&str> {
                match index {
                    0usize => ::core::option::Option::Some("physical_position"),
                    1usize => ::core::option::Option::Some("physical_size"),
                    2usize => ::core::option::Option::Some("depth"),
                    _ => ::core::option::Option::None,
                }
            }
            fn index_of_name(&self, name: &str)
                -> ::core::option::Option<usize> {
                match name {
                    "physical_position" => ::core::option::Option::Some(0usize),
                    "physical_size" => ::core::option::Option::Some(1usize),
                    "depth" => ::core::option::Option::Some(2usize),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_len(&self) -> usize { 3usize }
            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("physical_position",
                    bevy_reflect::PartialReflect::to_dynamic(&self.physical_position));
                dynamic.insert_boxed("physical_size",
                    bevy_reflect::PartialReflect::to_dynamic(&self.physical_size));
                dynamic.insert_boxed("depth",
                    bevy_reflect::PartialReflect::to_dynamic(&self.depth));
                dynamic
            }
        }
        impl bevy_reflect::PartialReflect for Viewport 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)
            }
            #[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 Viewport 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) =
                            (||
                                        <UVec2 as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "physical_position")?))() {
                        __this.physical_position = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <UVec2 as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "physical_size")?))() {
                        __this.physical_size = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <Range<f32> as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "depth")?))() {
                        __this.depth = __field;
                    }
                    ::core::option::Option::Some(__this)
                } else { ::core::option::Option::None }
            }
        }
    };Reflect, #[automatically_derived]
impl ::core::fmt::Debug for Viewport {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        ::core::fmt::Formatter::debug_struct_field3_finish(f, "Viewport",
            "physical_position", &self.physical_position, "physical_size",
            &self.physical_size, "depth", &&self.depth)
    }
}Debug, #[automatically_derived]
impl ::core::clone::Clone for Viewport {
    #[inline]
    fn clone(&self) -> Viewport {
        Viewport {
            physical_position: ::core::clone::Clone::clone(&self.physical_position),
            physical_size: ::core::clone::Clone::clone(&self.physical_size),
            depth: ::core::clone::Clone::clone(&self.depth),
        }
    }
}Clone)]
61#[reflect(Default, Clone)]
62pub struct Viewport {
63    /// The physical position to render this viewport to within the [`RenderTarget`] of this [`Camera`].
64    /// (0,0) corresponds to the top-left corner
65    pub physical_position: UVec2,
66    /// The physical size of the viewport rectangle to render to within the [`RenderTarget`] of this [`Camera`].
67    /// The origin of the rectangle is in the top-left corner.
68    pub physical_size: UVec2,
69    /// The minimum and maximum depth to render (on a scale from 0.0 to 1.0).
70    pub depth: Range<f32>,
71}
72
73impl Default for Viewport {
74    fn default() -> Self {
75        Self {
76            physical_position: Default::default(),
77            physical_size: UVec2::new(1, 1),
78            depth: 0.0..1.0,
79        }
80    }
81}
82
83impl Viewport {
84    /// Cut the viewport rectangle so that it lies inside a rectangle of the
85    /// given size.
86    ///
87    /// If either of the viewport's position coordinates lies outside the given
88    /// dimensions, it will be moved just inside first. If either of the given
89    /// dimensions is zero, the position and size of the viewport rectangle will
90    /// both be set to zero in that dimension.
91    pub fn clamp_to_size(&mut self, size: UVec2) {
92        // If the origin of the viewport rect is outside, then adjust so that
93        // it's just barely inside. Then, cut off the part that is outside.
94        if self.physical_size.x + self.physical_position.x > size.x {
95            if self.physical_position.x < size.x {
96                self.physical_size.x = size.x - self.physical_position.x;
97            } else if size.x > 0 {
98                self.physical_position.x = size.x - 1;
99                self.physical_size.x = 1;
100            } else {
101                self.physical_position.x = 0;
102                self.physical_size.x = 0;
103            }
104        }
105        if self.physical_size.y + self.physical_position.y > size.y {
106            if self.physical_position.y < size.y {
107                self.physical_size.y = size.y - self.physical_position.y;
108            } else if size.y > 0 {
109                self.physical_position.y = size.y - 1;
110                self.physical_size.y = 1;
111            } else {
112                self.physical_position.y = 0;
113                self.physical_size.y = 0;
114            }
115        }
116    }
117
118    pub fn from_viewport_and_override(
119        viewport: Option<&Self>,
120        main_pass_resolution_override: Option<&MainPassResolutionOverride>,
121    ) -> Option<Self> {
122        if let Some(override_size) = main_pass_resolution_override {
123            let mut vp = viewport.map_or_else(Self::default, Self::clone);
124            vp.physical_size = **override_size;
125            Some(vp)
126        } else {
127            viewport.cloned()
128        }
129    }
130}
131
132/// Override the resolution a 3d camera's main pass is rendered at.
133///
134/// Does not affect post processing.
135///
136/// ## Usage
137///
138/// * Insert this component on a 3d camera entity in the render world.
139/// * The resolution override must be smaller than the camera's viewport size.
140/// * The resolution override is specified in physical pixels.
141/// * In shaders, use `View::main_pass_viewport` instead of `View::viewport`.
142#[derive(impl bevy_ecs::component::Component for MainPassResolutionOverride 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, const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for MainPassResolutionOverride
            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
            }
            #[inline(never)]
            fn register_type_dependencies(registry:
                    &mut bevy_reflect::TypeRegistry) {
                <UVec2 as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
            }
        }
        impl bevy_reflect::Typed for MainPassResolutionOverride 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::TupleStruct(bevy_reflect::tuple_struct::TupleStructInfo::new::<Self>(&[bevy_reflect::UnnamedField::new::<UVec2>(0usize)]))
                        })
            }
        }
        #[allow(deprecated, reason =
        "derives on a deprecated type shouldn't be considered a usage")]
        impl bevy_reflect::TypePath for MainPassResolutionOverride where  {
            fn type_path() -> &'static str {
                "bevy_camera::camera::MainPassResolutionOverride"
            }
            fn short_type_path() -> &'static str {
                "MainPassResolutionOverride"
            }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("MainPassResolutionOverride")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera")
            }
        }
        impl bevy_reflect::Reflect for MainPassResolutionOverride 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(<MainPassResolutionOverride
                                        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::tuple_struct::TupleStruct for
            MainPassResolutionOverride where  {
            fn field(&self, index: usize)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match index {
                    0usize => ::core::option::Option::Some(&self.0),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_mut(&mut self, index: usize)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match index {
                    0usize => ::core::option::Option::Some(&mut self.0),
                    _ => ::core::option::Option::None,
                }
            }
            #[inline]
            fn field_len(&self) -> usize { 1usize }
            #[inline]
            fn iter_fields(&self)
                -> bevy_reflect::tuple_struct::TupleStructFieldIter {
                bevy_reflect::tuple_struct::TupleStructFieldIter::new(self)
            }
            fn to_dynamic_tuple_struct(&self)
                -> bevy_reflect::tuple_struct::DynamicTupleStruct {
                let mut dynamic:
                        bevy_reflect::tuple_struct::DynamicTupleStruct =
                    ::core::default::Default::default();
                dynamic.set_represented_type(bevy_reflect::PartialReflect::get_represented_type_info(self));
                dynamic.insert_boxed(bevy_reflect::PartialReflect::to_dynamic(&self.0));
                dynamic
            }
        }
        impl bevy_reflect::PartialReflect for MainPassResolutionOverride 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::TupleStruct(struct_value) =
                        bevy_reflect::PartialReflect::reflect_ref(value) {
                    for (i, value) in
                        ::core::iter::Iterator::enumerate(bevy_reflect::tuple_struct::TupleStruct::iter_fields(struct_value))
                        {
                        if let ::core::option::Option::Some(v) =
                                bevy_reflect::tuple_struct::TupleStruct::field_mut(self, i)
                            {
                            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::TupleStruct,
                            });
                }
                ::core::result::Result::Ok(())
            }
            #[inline]
            fn reflect_kind(&self) -> bevy_reflect::ReflectKind {
                bevy_reflect::ReflectKind::TupleStruct
            }
            #[inline]
            fn reflect_ref(&self) -> bevy_reflect::ReflectRef {
                bevy_reflect::ReflectRef::TupleStruct(self)
            }
            #[inline]
            fn reflect_mut(&mut self) -> bevy_reflect::ReflectMut {
                bevy_reflect::ReflectMut::TupleStruct(self)
            }
            #[inline]
            fn reflect_owned(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                -> bevy_reflect::ReflectOwned {
                bevy_reflect::ReflectOwned::TupleStruct(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::tuple_struct::tuple_struct_partial_eq)(self,
                    value)
            }
            fn reflect_partial_cmp(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<::core::cmp::Ordering> {
                (bevy_reflect::tuple_struct::tuple_struct_partial_cmp)(self,
                    value)
            }
            #[inline]
            #[allow(unreachable_code, reason =
            "Ignored fields without a `clone` attribute will early-return with an error")]
            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(Self {
                            0: <UVec2 as
                                        bevy_reflect::PartialReflect>::reflect_clone_and_take(&self.0)?,
                        }))
            }
        }
        impl bevy_reflect::FromReflect for MainPassResolutionOverride where  {
            fn from_reflect(reflect: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<Self> {
                if let bevy_reflect::ReflectRef::TupleStruct(__ref_struct) =
                        bevy_reflect::PartialReflect::reflect_ref(reflect) {
                    let __this =
                        Self {
                            0: <UVec2 as
                                        bevy_reflect::FromReflect>::from_reflect(bevy_reflect::tuple_struct::TupleStruct::field(__ref_struct,
                                            0)?)?,
                        };
                    ::core::option::Option::Some(__this)
                } else { ::core::option::Option::None }
            }
        }
    };Reflect, impl ::core::ops::Deref for MainPassResolutionOverride {
    type Target = UVec2;
    fn deref(&self) -> &Self::Target { &self.0 }
}Deref, #[automatically_derived]
impl ::core::fmt::Debug for MainPassResolutionOverride {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        ::core::fmt::Formatter::debug_tuple_field1_finish(f,
            "MainPassResolutionOverride", &&self.0)
    }
}Debug)]
143#[reflect(Component)]
144pub struct MainPassResolutionOverride(pub UVec2);
145
146/// Settings to define a camera sub view.
147///
148/// When [`Camera::sub_camera_view`] is `Some`, only the sub-section of the
149/// image defined by `size` and `offset` (relative to the `full_size` of the
150/// whole image) is projected to the cameras viewport.
151///
152/// Take the example of the following multi-monitor setup:
153/// ```css
154/// ┌───┬───┐
155/// │ A │ B │
156/// ├───┼───┤
157/// │ C │ D │
158/// └───┴───┘
159/// ```
160/// If each monitor is 1920x1080, the whole image will have a resolution of
161/// 3840x2160. For each monitor we can use a single camera with a viewport of
162/// the same size as the monitor it corresponds to. To ensure that the image is
163/// cohesive, we can use a different sub view on each camera:
164/// - Camera A: `full_size` = 3840x2160, `size` = 1920x1080, `offset` = 0,0
165/// - Camera B: `full_size` = 3840x2160, `size` = 1920x1080, `offset` = 1920,0
166/// - Camera C: `full_size` = 3840x2160, `size` = 1920x1080, `offset` = 0,1080
167/// - Camera D: `full_size` = 3840x2160, `size` = 1920x1080, `offset` =
168///   1920,1080
169///
170/// However since only the ratio between the values is important, they could all
171/// be divided by 120 and still produce the same image. Camera D would for
172/// example have the following values:
173/// `full_size` = 32x18, `size` = 16x9, `offset` = 16,9
174#[derive(#[automatically_derived]
impl ::core::fmt::Debug for SubCameraView {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        ::core::fmt::Formatter::debug_struct_field3_finish(f, "SubCameraView",
            "full_size", &self.full_size, "offset", &self.offset, "size",
            &&self.size)
    }
}Debug, #[automatically_derived]
impl ::core::clone::Clone for SubCameraView {
    #[inline]
    fn clone(&self) -> SubCameraView {
        let _: ::core::clone::AssertParamIsClone<UVec2>;
        let _: ::core::clone::AssertParamIsClone<Vec2>;
        *self
    }
}Clone, #[automatically_derived]
impl ::core::marker::Copy for SubCameraView { }Copy, const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for SubCameraView 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::<ReflectDefault, Self>();
                registration
            }
            #[inline(never)]
            fn register_type_dependencies(registry:
                    &mut bevy_reflect::TypeRegistry) {
                <UVec2 as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <Vec2 as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
            }
        }
        impl bevy_reflect::Typed for SubCameraView 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::<UVec2>("full_size"),
                                                bevy_reflect::NamedField::new::<Vec2>("offset"),
                                                bevy_reflect::NamedField::new::<UVec2>("size")]))
                        })
            }
        }
        #[allow(deprecated, reason =
        "derives on a deprecated type shouldn't be considered a usage")]
        impl bevy_reflect::TypePath for SubCameraView where  {
            fn type_path() -> &'static str {
                "bevy_camera::camera::SubCameraView"
            }
            fn short_type_path() -> &'static str { "SubCameraView" }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("SubCameraView")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera")
            }
        }
        impl bevy_reflect::Reflect for SubCameraView 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(<SubCameraView
                                        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 SubCameraView where  {
            fn field(&self, name: &str)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match name {
                    "full_size" =>
                        ::core::option::Option::Some(&self.full_size),
                    "offset" => ::core::option::Option::Some(&self.offset),
                    "size" => ::core::option::Option::Some(&self.size),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_mut(&mut self, name: &str)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match name {
                    "full_size" =>
                        ::core::option::Option::Some(&mut self.full_size),
                    "offset" => ::core::option::Option::Some(&mut self.offset),
                    "size" => ::core::option::Option::Some(&mut self.size),
                    _ => ::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.full_size),
                    1usize => ::core::option::Option::Some(&self.offset),
                    2usize => ::core::option::Option::Some(&self.size),
                    _ => ::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.full_size),
                    1usize => ::core::option::Option::Some(&mut self.offset),
                    2usize => ::core::option::Option::Some(&mut self.size),
                    _ => ::core::option::Option::None,
                }
            }
            fn name_at(&self, index: usize) -> ::core::option::Option<&str> {
                match index {
                    0usize => ::core::option::Option::Some("full_size"),
                    1usize => ::core::option::Option::Some("offset"),
                    2usize => ::core::option::Option::Some("size"),
                    _ => ::core::option::Option::None,
                }
            }
            fn index_of_name(&self, name: &str)
                -> ::core::option::Option<usize> {
                match name {
                    "full_size" => ::core::option::Option::Some(0usize),
                    "offset" => ::core::option::Option::Some(1usize),
                    "size" => ::core::option::Option::Some(2usize),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_len(&self) -> usize { 3usize }
            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("full_size",
                    bevy_reflect::PartialReflect::to_dynamic(&self.full_size));
                dynamic.insert_boxed("offset",
                    bevy_reflect::PartialReflect::to_dynamic(&self.offset));
                dynamic.insert_boxed("size",
                    bevy_reflect::PartialReflect::to_dynamic(&self.size));
                dynamic
            }
        }
        impl bevy_reflect::PartialReflect for SubCameraView 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> {
                let value =
                    <dyn bevy_reflect::PartialReflect>::try_downcast_ref::<Self>(value);
                if let ::core::option::Option::Some(value) = value {
                    ::core::option::Option::Some(::core::cmp::PartialEq::eq(self,
                            value))
                } else { ::core::option::Option::Some(false) }
            }
            fn reflect_partial_cmp(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<::core::cmp::Ordering> {
                (bevy_reflect::structs::struct_partial_cmp)(self, value)
            }
            #[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 SubCameraView 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) =
                            (||
                                        <UVec2 as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "full_size")?))() {
                        __this.full_size = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <Vec2 as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "offset")?))() {
                        __this.offset = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <UVec2 as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "size")?))() {
                        __this.size = __field;
                    }
                    ::core::option::Option::Some(__this)
                } else { ::core::option::Option::None }
            }
        }
    };Reflect, #[automatically_derived]
impl ::core::cmp::PartialEq for SubCameraView {
    #[inline]
    fn eq(&self, other: &SubCameraView) -> bool {
        self.full_size == other.full_size && self.offset == other.offset &&
            self.size == other.size
    }
}PartialEq)]
175#[reflect(Clone, PartialEq, Default)]
176pub struct SubCameraView {
177    /// Size of the entire camera view
178    pub full_size: UVec2,
179    /// Offset of the sub camera
180    pub offset: Vec2,
181    /// Size of the sub camera
182    pub size: UVec2,
183}
184
185impl Default for SubCameraView {
186    fn default() -> Self {
187        Self {
188            full_size: UVec2::new(1, 1),
189            offset: Vec2::new(0., 0.),
190            size: UVec2::new(1, 1),
191        }
192    }
193}
194
195/// Information about the current [`RenderTarget`].
196#[derive(#[automatically_derived]
impl ::core::fmt::Debug for RenderTargetInfo {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        ::core::fmt::Formatter::debug_struct_field2_finish(f,
            "RenderTargetInfo", "physical_size", &self.physical_size,
            "scale_factor", &&self.scale_factor)
    }
}Debug, const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for RenderTargetInfo 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
            }
            #[inline(never)]
            fn register_type_dependencies(registry:
                    &mut bevy_reflect::TypeRegistry) {
                <UVec2 as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <f32 as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
            }
        }
        impl bevy_reflect::Typed for RenderTargetInfo 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::<UVec2>("physical_size"),
                                                bevy_reflect::NamedField::new::<f32>("scale_factor")]))
                        })
            }
        }
        #[allow(deprecated, reason =
        "derives on a deprecated type shouldn't be considered a usage")]
        impl bevy_reflect::TypePath for RenderTargetInfo where  {
            fn type_path() -> &'static str {
                "bevy_camera::camera::RenderTargetInfo"
            }
            fn short_type_path() -> &'static str { "RenderTargetInfo" }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("RenderTargetInfo")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera")
            }
        }
        impl bevy_reflect::Reflect for RenderTargetInfo 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(<RenderTargetInfo
                                        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 RenderTargetInfo where  {
            fn field(&self, name: &str)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match name {
                    "physical_size" =>
                        ::core::option::Option::Some(&self.physical_size),
                    "scale_factor" =>
                        ::core::option::Option::Some(&self.scale_factor),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_mut(&mut self, name: &str)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match name {
                    "physical_size" =>
                        ::core::option::Option::Some(&mut self.physical_size),
                    "scale_factor" =>
                        ::core::option::Option::Some(&mut self.scale_factor),
                    _ => ::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.physical_size),
                    1usize => ::core::option::Option::Some(&self.scale_factor),
                    _ => ::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.physical_size),
                    1usize =>
                        ::core::option::Option::Some(&mut self.scale_factor),
                    _ => ::core::option::Option::None,
                }
            }
            fn name_at(&self, index: usize) -> ::core::option::Option<&str> {
                match index {
                    0usize => ::core::option::Option::Some("physical_size"),
                    1usize => ::core::option::Option::Some("scale_factor"),
                    _ => ::core::option::Option::None,
                }
            }
            fn index_of_name(&self, name: &str)
                -> ::core::option::Option<usize> {
                match name {
                    "physical_size" => ::core::option::Option::Some(0usize),
                    "scale_factor" => ::core::option::Option::Some(1usize),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_len(&self) -> usize { 2usize }
            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("physical_size",
                    bevy_reflect::PartialReflect::to_dynamic(&self.physical_size));
                dynamic.insert_boxed("scale_factor",
                    bevy_reflect::PartialReflect::to_dynamic(&self.scale_factor));
                dynamic
            }
        }
        impl bevy_reflect::PartialReflect for RenderTargetInfo 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)
            }
            #[inline]
            #[allow(unreachable_code, reason =
            "Ignored fields without a `clone` attribute will early-return with an error")]
            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(Self {
                            physical_size: <UVec2 as
                                        bevy_reflect::PartialReflect>::reflect_clone_and_take(&self.physical_size)?,
                            scale_factor: <f32 as
                                        bevy_reflect::PartialReflect>::reflect_clone_and_take(&self.scale_factor)?,
                        }))
            }
        }
        impl bevy_reflect::FromReflect for RenderTargetInfo 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 __this =
                        Self {
                            physical_size: <UVec2 as
                                        bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                            "physical_size")?)?,
                            scale_factor: <f32 as
                                        bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                            "scale_factor")?)?,
                        };
                    ::core::option::Option::Some(__this)
                } else { ::core::option::Option::None }
            }
        }
    };Reflect, #[automatically_derived]
impl ::core::clone::Clone for RenderTargetInfo {
    #[inline]
    fn clone(&self) -> RenderTargetInfo {
        RenderTargetInfo {
            physical_size: ::core::clone::Clone::clone(&self.physical_size),
            scale_factor: ::core::clone::Clone::clone(&self.scale_factor),
        }
    }
}Clone)]
197pub struct RenderTargetInfo {
198    /// The physical size of this render target (in physical pixels, ignoring scale factor).
199    pub physical_size: UVec2,
200    /// The scale factor of this render target.
201    ///
202    /// When rendering to a window, typically it is a value greater or equal than 1.0,
203    /// representing the ratio between the size of the window in physical pixels and the logical size of the window.
204    pub scale_factor: f32,
205}
206
207impl Default for RenderTargetInfo {
208    fn default() -> Self {
209        Self {
210            physical_size: Default::default(),
211            scale_factor: 1.,
212        }
213    }
214}
215
216/// Holds internally computed [`Camera`] values.
217#[derive(#[automatically_derived]
impl ::core::default::Default for ComputedCameraValues {
    #[inline]
    fn default() -> ComputedCameraValues {
        ComputedCameraValues {
            clip_from_view: ::core::default::Default::default(),
            target_info: ::core::default::Default::default(),
            old_viewport_size: ::core::default::Default::default(),
            old_sub_camera_view: ::core::default::Default::default(),
        }
    }
}Default, #[automatically_derived]
impl ::core::fmt::Debug for ComputedCameraValues {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        ::core::fmt::Formatter::debug_struct_field4_finish(f,
            "ComputedCameraValues", "clip_from_view", &self.clip_from_view,
            "target_info", &self.target_info, "old_viewport_size",
            &self.old_viewport_size, "old_sub_camera_view",
            &&self.old_sub_camera_view)
    }
}Debug, const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for ComputedCameraValues 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
            }
            #[inline(never)]
            fn register_type_dependencies(registry:
                    &mut bevy_reflect::TypeRegistry) {
                <Mat4 as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <Option<RenderTargetInfo> as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <Option<UVec2> as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <Option<SubCameraView> as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
            }
        }
        impl bevy_reflect::Typed for ComputedCameraValues 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::<Mat4>("clip_from_view"),
                                                bevy_reflect::NamedField::new::<Option<RenderTargetInfo>>("target_info"),
                                                bevy_reflect::NamedField::new::<Option<UVec2>>("old_viewport_size"),
                                                bevy_reflect::NamedField::new::<Option<SubCameraView>>("old_sub_camera_view")]))
                        })
            }
        }
        #[allow(deprecated, reason =
        "derives on a deprecated type shouldn't be considered a usage")]
        impl bevy_reflect::TypePath for ComputedCameraValues where  {
            fn type_path() -> &'static str {
                "bevy_camera::camera::ComputedCameraValues"
            }
            fn short_type_path() -> &'static str { "ComputedCameraValues" }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("ComputedCameraValues")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera")
            }
        }
        impl bevy_reflect::Reflect for ComputedCameraValues 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(<ComputedCameraValues
                                        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 ComputedCameraValues where  {
            fn field(&self, name: &str)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match name {
                    "clip_from_view" =>
                        ::core::option::Option::Some(&self.clip_from_view),
                    "target_info" =>
                        ::core::option::Option::Some(&self.target_info),
                    "old_viewport_size" =>
                        ::core::option::Option::Some(&self.old_viewport_size),
                    "old_sub_camera_view" =>
                        ::core::option::Option::Some(&self.old_sub_camera_view),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_mut(&mut self, name: &str)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match name {
                    "clip_from_view" =>
                        ::core::option::Option::Some(&mut self.clip_from_view),
                    "target_info" =>
                        ::core::option::Option::Some(&mut self.target_info),
                    "old_viewport_size" =>
                        ::core::option::Option::Some(&mut self.old_viewport_size),
                    "old_sub_camera_view" =>
                        ::core::option::Option::Some(&mut self.old_sub_camera_view),
                    _ => ::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.clip_from_view),
                    1usize => ::core::option::Option::Some(&self.target_info),
                    2usize =>
                        ::core::option::Option::Some(&self.old_viewport_size),
                    3usize =>
                        ::core::option::Option::Some(&self.old_sub_camera_view),
                    _ => ::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.clip_from_view),
                    1usize =>
                        ::core::option::Option::Some(&mut self.target_info),
                    2usize =>
                        ::core::option::Option::Some(&mut self.old_viewport_size),
                    3usize =>
                        ::core::option::Option::Some(&mut self.old_sub_camera_view),
                    _ => ::core::option::Option::None,
                }
            }
            fn name_at(&self, index: usize) -> ::core::option::Option<&str> {
                match index {
                    0usize => ::core::option::Option::Some("clip_from_view"),
                    1usize => ::core::option::Option::Some("target_info"),
                    2usize => ::core::option::Option::Some("old_viewport_size"),
                    3usize =>
                        ::core::option::Option::Some("old_sub_camera_view"),
                    _ => ::core::option::Option::None,
                }
            }
            fn index_of_name(&self, name: &str)
                -> ::core::option::Option<usize> {
                match name {
                    "clip_from_view" => ::core::option::Option::Some(0usize),
                    "target_info" => ::core::option::Option::Some(1usize),
                    "old_viewport_size" => ::core::option::Option::Some(2usize),
                    "old_sub_camera_view" =>
                        ::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("clip_from_view",
                    bevy_reflect::PartialReflect::to_dynamic(&self.clip_from_view));
                dynamic.insert_boxed("target_info",
                    bevy_reflect::PartialReflect::to_dynamic(&self.target_info));
                dynamic.insert_boxed("old_viewport_size",
                    bevy_reflect::PartialReflect::to_dynamic(&self.old_viewport_size));
                dynamic.insert_boxed("old_sub_camera_view",
                    bevy_reflect::PartialReflect::to_dynamic(&self.old_sub_camera_view));
                dynamic
            }
        }
        impl bevy_reflect::PartialReflect for ComputedCameraValues 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)
            }
            #[inline]
            #[allow(unreachable_code, reason =
            "Ignored fields without a `clone` attribute will early-return with an error")]
            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(Self {
                            clip_from_view: <Mat4 as
                                        bevy_reflect::PartialReflect>::reflect_clone_and_take(&self.clip_from_view)?,
                            target_info: <Option<RenderTargetInfo> as
                                        bevy_reflect::PartialReflect>::reflect_clone_and_take(&self.target_info)?,
                            old_viewport_size: <Option<UVec2> as
                                        bevy_reflect::PartialReflect>::reflect_clone_and_take(&self.old_viewport_size)?,
                            old_sub_camera_view: <Option<SubCameraView> as
                                        bevy_reflect::PartialReflect>::reflect_clone_and_take(&self.old_sub_camera_view)?,
                        }))
            }
        }
        impl bevy_reflect::FromReflect for ComputedCameraValues 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 __this =
                        Self {
                            clip_from_view: <Mat4 as
                                        bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                            "clip_from_view")?)?,
                            target_info: <Option<RenderTargetInfo> as
                                        bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                            "target_info")?)?,
                            old_viewport_size: <Option<UVec2> as
                                        bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                            "old_viewport_size")?)?,
                            old_sub_camera_view: <Option<SubCameraView> as
                                        bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                            "old_sub_camera_view")?)?,
                        };
                    ::core::option::Option::Some(__this)
                } else { ::core::option::Option::None }
            }
        }
    };Reflect, #[automatically_derived]
impl ::core::clone::Clone for ComputedCameraValues {
    #[inline]
    fn clone(&self) -> ComputedCameraValues {
        ComputedCameraValues {
            clip_from_view: ::core::clone::Clone::clone(&self.clip_from_view),
            target_info: ::core::clone::Clone::clone(&self.target_info),
            old_viewport_size: ::core::clone::Clone::clone(&self.old_viewport_size),
            old_sub_camera_view: ::core::clone::Clone::clone(&self.old_sub_camera_view),
        }
    }
}Clone)]
218pub struct ComputedCameraValues {
219    pub clip_from_view: Mat4,
220    pub target_info: Option<RenderTargetInfo>,
221    // size of the `Viewport`
222    pub old_viewport_size: Option<UVec2>,
223    pub old_sub_camera_view: Option<SubCameraView>,
224}
225
226/// How much energy a [`Camera3d`](crate::Camera3d) absorbs from incoming light.
227///
228/// <https://en.wikipedia.org/wiki/Exposure_(photography)>
229#[derive(impl bevy_ecs::component::Component for Exposure 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::clone::Clone for Exposure {
    #[inline]
    fn clone(&self) -> Exposure {
        let _: ::core::clone::AssertParamIsClone<f32>;
        *self
    }
}Clone, #[automatically_derived]
impl ::core::marker::Copy for Exposure { }Copy, const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for Exposure 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
            }
        }
        #[allow(deprecated, reason =
        "derives on a deprecated type shouldn't be considered a usage")]
        impl bevy_reflect::TypePath for Exposure where  {
            fn type_path() -> &'static str { "bevy_camera::camera::Exposure" }
            fn short_type_path() -> &'static str { "Exposure" }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("Exposure")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera")
            }
        }
        impl bevy_reflect::Typed for Exposure where  {
            #[inline]
            fn type_info() -> &'static bevy_reflect::TypeInfo {
                static CELL: bevy_reflect::utility::NonGenericTypeInfoCell =
                    bevy_reflect::utility::NonGenericTypeInfoCell::new();
                CELL.get_or_set(||
                        {
                            let info = bevy_reflect::OpaqueInfo::new::<Self>();
                            bevy_reflect::TypeInfo::Opaque(info)
                        })
            }
        }
        impl bevy_reflect::Reflect for Exposure 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(<Exposure
                                        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::PartialReflect for Exposure 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 to_dynamic(&self)
                ->
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::PartialReflect> {
                bevy_reflect::__macro_exports::alloc_utils::Box::new(::core::clone::Clone::clone(self))
            }
            #[inline]
            fn try_apply(&mut self, value: &dyn bevy_reflect::PartialReflect)
                -> ::core::result::Result<(), bevy_reflect::ApplyError> {
                if let ::core::option::Option::Some(value) =
                        <dyn bevy_reflect::PartialReflect>::try_downcast_ref::<Self>(value)
                    {
                    *self = ::core::clone::Clone::clone(value);
                    return ::core::result::Result::Ok(());
                }
                ::core::result::Result::Err(bevy_reflect::ApplyError::MismatchedTypes {
                        from_type: ::core::convert::Into::into(bevy_reflect::DynamicTypePath::reflect_type_path(value)),
                        to_type: ::core::convert::Into::into(<Self as
                                    bevy_reflect::TypePath>::type_path()),
                    })
            }
            #[inline]
            fn reflect_kind(&self) -> bevy_reflect::ReflectKind {
                bevy_reflect::ReflectKind::Opaque
            }
            #[inline]
            fn reflect_ref(&self) -> bevy_reflect::ReflectRef {
                bevy_reflect::ReflectRef::Opaque(self)
            }
            #[inline]
            fn reflect_mut(&mut self) -> bevy_reflect::ReflectMut {
                bevy_reflect::ReflectMut::Opaque(self)
            }
            #[inline]
            fn reflect_owned(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                -> bevy_reflect::ReflectOwned {
                bevy_reflect::ReflectOwned::Opaque(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
            }
            #[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 Exposure where  {
            fn from_reflect(reflect: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<Self> {
                ::core::option::Option::Some(::core::clone::Clone::clone(<dyn bevy_reflect::PartialReflect>::try_downcast_ref::<Exposure>(reflect)?))
            }
        }
    };Reflect)]
230#[reflect(opaque)]
231#[reflect(Component, Default, Clone)]
232pub struct Exposure {
233    /// <https://en.wikipedia.org/wiki/Exposure_value#Tabulated_exposure_values>
234    pub ev100: f32,
235}
236
237impl Exposure {
238    pub const SUNLIGHT: Self = Self {
239        ev100: Self::EV100_SUNLIGHT,
240    };
241    pub const OVERCAST: Self = Self {
242        ev100: Self::EV100_OVERCAST,
243    };
244    pub const INDOOR: Self = Self {
245        ev100: Self::EV100_INDOOR,
246    };
247    /// This value was calibrated to match Blender's implicit/default exposure as closely as possible.
248    /// It also happens to be a reasonable default.
249    ///
250    /// See <https://github.com/bevyengine/bevy/issues/11577> for details.
251    pub const BLENDER: Self = Self {
252        ev100: Self::EV100_BLENDER,
253    };
254
255    pub const EV100_SUNLIGHT: f32 = 15.0;
256    pub const EV100_OVERCAST: f32 = 12.0;
257    pub const EV100_INDOOR: f32 = 7.0;
258
259    /// This value was calibrated to match Blender's implicit/default exposure as closely as possible.
260    /// It also happens to be a reasonable default.
261    ///
262    /// See <https://github.com/bevyengine/bevy/issues/11577> for details.
263    pub const EV100_BLENDER: f32 = 9.7;
264
265    pub fn from_physical_camera(physical_camera_parameters: PhysicalCameraParameters) -> Self {
266        Self {
267            ev100: physical_camera_parameters.ev100(),
268        }
269    }
270
271    /// Converts EV100 values to exposure values.
272    /// <https://google.github.io/filament/Filament.md.html#imagingpipeline/physicallybasedcamera/exposure>
273    #[inline]
274    pub fn exposure(&self) -> f32 {
275        ops::exp2(-self.ev100) / 1.2
276    }
277}
278
279impl Default for Exposure {
280    fn default() -> Self {
281        Self::BLENDER
282    }
283}
284
285/// Parameters based on physical camera characteristics for calculating EV100
286/// values for use with [`Exposure`]. This is also used for depth of field.
287#[derive(#[automatically_derived]
impl ::core::clone::Clone for PhysicalCameraParameters {
    #[inline]
    fn clone(&self) -> PhysicalCameraParameters {
        let _: ::core::clone::AssertParamIsClone<f32>;
        *self
    }
}Clone, #[automatically_derived]
impl ::core::marker::Copy for PhysicalCameraParameters { }Copy)]
288pub struct PhysicalCameraParameters {
289    /// <https://en.wikipedia.org/wiki/F-number>
290    pub aperture_f_stops: f32,
291    /// <https://en.wikipedia.org/wiki/Shutter_speed>
292    pub shutter_speed_s: f32,
293    /// <https://en.wikipedia.org/wiki/Film_speed>
294    pub sensitivity_iso: f32,
295    /// The height of the [image sensor format] in meters.
296    ///
297    /// Focal length is derived from the FOV and this value. The default is
298    /// 18.66mm, matching the [Super 35] format, which is popular in cinema.
299    ///
300    /// [image sensor format]: https://en.wikipedia.org/wiki/Image_sensor_format
301    ///
302    /// [Super 35]: https://en.wikipedia.org/wiki/Super_35
303    pub sensor_height: f32,
304}
305
306impl PhysicalCameraParameters {
307    /// Calculate the [EV100](https://en.wikipedia.org/wiki/Exposure_value).
308    pub fn ev100(&self) -> f32 {
309        ops::log2(
310            self.aperture_f_stops * self.aperture_f_stops * 100.0
311                / (self.shutter_speed_s * self.sensitivity_iso),
312        )
313    }
314}
315
316impl Default for PhysicalCameraParameters {
317    fn default() -> Self {
318        Self {
319            aperture_f_stops: 1.0,
320            shutter_speed_s: 1.0 / 125.0,
321            sensitivity_iso: 100.0,
322            sensor_height: 0.01866,
323        }
324    }
325}
326
327/// Error returned when a conversion between world-space and viewport-space coordinates fails.
328///
329/// See [`world_to_viewport`][Camera::world_to_viewport] and [`viewport_to_world`][Camera::viewport_to_world].
330#[derive(#[automatically_derived]
impl ::core::fmt::Debug for ViewportConversionError {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        ::core::fmt::Formatter::write_str(f,
            match self {
                ViewportConversionError::NoViewportSize => "NoViewportSize",
                ViewportConversionError::PastNearPlane => "PastNearPlane",
                ViewportConversionError::PastFarPlane => "PastFarPlane",
                ViewportConversionError::InvalidData => "InvalidData",
            })
    }
}Debug, #[automatically_derived]
impl ::core::cmp::Eq for ViewportConversionError {
    #[inline]
    #[doc(hidden)]
    #[coverage(off)]
    fn assert_fields_are_eq(&self) {}
}Eq, #[automatically_derived]
impl ::core::cmp::PartialEq for ViewportConversionError {
    #[inline]
    fn eq(&self, other: &ViewportConversionError) -> bool {
        let __self_discr = ::core::intrinsics::discriminant_value(self);
        let __arg1_discr = ::core::intrinsics::discriminant_value(other);
        __self_discr == __arg1_discr
    }
}PartialEq, #[automatically_derived]
impl ::core::marker::Copy for ViewportConversionError { }Copy, #[automatically_derived]
impl ::core::clone::Clone for ViewportConversionError {
    #[inline]
    fn clone(&self) -> ViewportConversionError { *self }
}Clone, #[allow(unused_qualifications)]
#[automatically_derived]
impl ::core::fmt::Display for ViewportConversionError {
    fn fmt(&self, __formatter: &mut ::core::fmt::Formatter)
        -> ::core::fmt::Result {

        #[allow(unused_variables, deprecated, clippy ::
        used_underscore_binding)]
        match self {
            ViewportConversionError::NoViewportSize {} =>
                __formatter.write_str("pre-computed size of viewport not available"),
            ViewportConversionError::PastNearPlane {} =>
                __formatter.write_str("computed coordinate beyond `Camera`'s near plane"),
            ViewportConversionError::PastFarPlane {} =>
                __formatter.write_str("computed coordinate beyond `Camera`'s far plane"),
            ViewportConversionError::InvalidData {} =>
                __formatter.write_str("found NaN while computing NDC"),
        }
    }
}Error)]
331pub enum ViewportConversionError {
332    /// The pre-computed size of the viewport was not available.
333    ///
334    /// This may be because the `Camera` was just created and `camera_system` has not been executed
335    /// yet, or because the [`RenderTarget`] is misconfigured in one of the following ways:
336    ///   - it references the [`PrimaryWindow`](RenderTarget::Window) when there is none,
337    ///   - it references a [`Window`](RenderTarget::Window) entity that doesn't exist or doesn't actually have a `Window` component,
338    ///   - it references an [`Image`](RenderTarget::Image) that doesn't exist (invalid handle),
339    ///   - it references a [`TextureView`](RenderTarget::TextureView) that doesn't exist (invalid handle).
340    #[error("pre-computed size of viewport not available")]
341    NoViewportSize,
342    /// The computed coordinate was beyond the `Camera`'s near plane.
343    ///
344    /// Only applicable when converting from world-space to viewport-space.
345    #[error("computed coordinate beyond `Camera`'s near plane")]
346    PastNearPlane,
347    /// The computed coordinate was beyond the `Camera`'s far plane.
348    ///
349    /// Only applicable when converting from world-space to viewport-space.
350    #[error("computed coordinate beyond `Camera`'s far plane")]
351    PastFarPlane,
352    /// The Normalized Device Coordinates could not be computed because the `camera_transform`, the
353    /// `world_position`, or the projection matrix defined by [`Projection`](super::projection::Projection)
354    /// contained `NAN` (see [`world_to_ndc`][Camera::world_to_ndc] and [`ndc_to_world`][Camera::ndc_to_world]).
355    #[error("found NaN while computing NDC")]
356    InvalidData,
357}
358
359/// The defining [`Component`] for camera entities,
360/// storing information about how and what to render through this camera.
361///
362/// The [`Camera`] component is added to an entity to define the properties of the viewpoint from
363/// which rendering occurs. It defines the position of the view to render, the projection method
364/// to transform the 3D objects into a 2D image, as well as the render target into which that image
365/// is produced.
366///
367/// Note that a [`Camera`] needs a `CameraRenderGraph` to render anything.
368/// This is typically provided by adding a [`Camera2d`] or [`Camera3d`] component,
369/// but custom render graphs can also be defined. Inserting a [`Camera`] with no render
370/// graph will emit an error at runtime.
371///
372/// [`Camera2d`]: crate::Camera2d
373/// [`Camera3d`]: crate::Camera3d
374#[derive(#[doc =
"**Required Components**: [`Frustum`], [`CameraMainTextureUsages`], [`VisibleEntities`], [`Transform`], [`Visibility`], [`RenderTarget`]. \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 Camera 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::<Frustum>(<Frustum as
                ::core::default::Default>::default);
        required_components.register_required::<CameraMainTextureUsages>(<CameraMainTextureUsages
                as ::core::default::Default>::default);
        required_components.register_required::<VisibleEntities>(<VisibleEntities
                as ::core::default::Default>::default);
        required_components.register_required::<Transform>(<Transform as
                ::core::default::Default>::default);
        required_components.register_required::<Visibility>(<Visibility as
                ::core::default::Default>::default);
        required_components.register_required::<RenderTarget>(<RenderTarget 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 Camera {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        let names: &'static _ =
            &["viewport", "order", "is_active", "computed", "output_mode",
                        "msaa_writeback", "clear_color", "invert_culling",
                        "sub_camera_view"];
        let values: &[&dyn ::core::fmt::Debug] =
            &[&self.viewport, &self.order, &self.is_active, &self.computed,
                        &self.output_mode, &self.msaa_writeback, &self.clear_color,
                        &self.invert_culling, &&self.sub_camera_view];
        ::core::fmt::Formatter::debug_struct_fields_finish(f, "Camera", names,
            values)
    }
}Debug, const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for Camera 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) {
                <Option<Viewport> as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <isize as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <bool as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <ComputedCameraValues as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <CameraOutputMode as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <MsaaWriteback as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <ClearColorConfig as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <Option<SubCameraView> as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
            }
        }
        impl bevy_reflect::Typed for Camera 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::<Option<Viewport>>("viewport"),
                                                bevy_reflect::NamedField::new::<isize>("order"),
                                                bevy_reflect::NamedField::new::<bool>("is_active"),
                                                bevy_reflect::NamedField::new::<ComputedCameraValues>("computed"),
                                                bevy_reflect::NamedField::new::<CameraOutputMode>("output_mode"),
                                                bevy_reflect::NamedField::new::<MsaaWriteback>("msaa_writeback"),
                                                bevy_reflect::NamedField::new::<ClearColorConfig>("clear_color"),
                                                bevy_reflect::NamedField::new::<bool>("invert_culling"),
                                                bevy_reflect::NamedField::new::<Option<SubCameraView>>("sub_camera_view")]))
                        })
            }
        }
        #[allow(deprecated, reason =
        "derives on a deprecated type shouldn't be considered a usage")]
        impl bevy_reflect::TypePath for Camera where  {
            fn type_path() -> &'static str { "bevy_camera::camera::Camera" }
            fn short_type_path() -> &'static str { "Camera" }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("Camera")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera")
            }
        }
        impl bevy_reflect::Reflect for Camera 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(<Camera
                                        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 Camera where  {
            fn field(&self, name: &str)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match name {
                    "viewport" => ::core::option::Option::Some(&self.viewport),
                    "order" => ::core::option::Option::Some(&self.order),
                    "is_active" =>
                        ::core::option::Option::Some(&self.is_active),
                    "computed" => ::core::option::Option::Some(&self.computed),
                    "output_mode" =>
                        ::core::option::Option::Some(&self.output_mode),
                    "msaa_writeback" =>
                        ::core::option::Option::Some(&self.msaa_writeback),
                    "clear_color" =>
                        ::core::option::Option::Some(&self.clear_color),
                    "invert_culling" =>
                        ::core::option::Option::Some(&self.invert_culling),
                    "sub_camera_view" =>
                        ::core::option::Option::Some(&self.sub_camera_view),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_mut(&mut self, name: &str)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match name {
                    "viewport" =>
                        ::core::option::Option::Some(&mut self.viewport),
                    "order" => ::core::option::Option::Some(&mut self.order),
                    "is_active" =>
                        ::core::option::Option::Some(&mut self.is_active),
                    "computed" =>
                        ::core::option::Option::Some(&mut self.computed),
                    "output_mode" =>
                        ::core::option::Option::Some(&mut self.output_mode),
                    "msaa_writeback" =>
                        ::core::option::Option::Some(&mut self.msaa_writeback),
                    "clear_color" =>
                        ::core::option::Option::Some(&mut self.clear_color),
                    "invert_culling" =>
                        ::core::option::Option::Some(&mut self.invert_culling),
                    "sub_camera_view" =>
                        ::core::option::Option::Some(&mut self.sub_camera_view),
                    _ => ::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.viewport),
                    1usize => ::core::option::Option::Some(&self.order),
                    2usize => ::core::option::Option::Some(&self.is_active),
                    3usize => ::core::option::Option::Some(&self.computed),
                    4usize => ::core::option::Option::Some(&self.output_mode),
                    5usize =>
                        ::core::option::Option::Some(&self.msaa_writeback),
                    6usize => ::core::option::Option::Some(&self.clear_color),
                    7usize =>
                        ::core::option::Option::Some(&self.invert_culling),
                    8usize =>
                        ::core::option::Option::Some(&self.sub_camera_view),
                    _ => ::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.viewport),
                    1usize => ::core::option::Option::Some(&mut self.order),
                    2usize => ::core::option::Option::Some(&mut self.is_active),
                    3usize => ::core::option::Option::Some(&mut self.computed),
                    4usize =>
                        ::core::option::Option::Some(&mut self.output_mode),
                    5usize =>
                        ::core::option::Option::Some(&mut self.msaa_writeback),
                    6usize =>
                        ::core::option::Option::Some(&mut self.clear_color),
                    7usize =>
                        ::core::option::Option::Some(&mut self.invert_culling),
                    8usize =>
                        ::core::option::Option::Some(&mut self.sub_camera_view),
                    _ => ::core::option::Option::None,
                }
            }
            fn name_at(&self, index: usize) -> ::core::option::Option<&str> {
                match index {
                    0usize => ::core::option::Option::Some("viewport"),
                    1usize => ::core::option::Option::Some("order"),
                    2usize => ::core::option::Option::Some("is_active"),
                    3usize => ::core::option::Option::Some("computed"),
                    4usize => ::core::option::Option::Some("output_mode"),
                    5usize => ::core::option::Option::Some("msaa_writeback"),
                    6usize => ::core::option::Option::Some("clear_color"),
                    7usize => ::core::option::Option::Some("invert_culling"),
                    8usize => ::core::option::Option::Some("sub_camera_view"),
                    _ => ::core::option::Option::None,
                }
            }
            fn index_of_name(&self, name: &str)
                -> ::core::option::Option<usize> {
                match name {
                    "viewport" => ::core::option::Option::Some(0usize),
                    "order" => ::core::option::Option::Some(1usize),
                    "is_active" => ::core::option::Option::Some(2usize),
                    "computed" => ::core::option::Option::Some(3usize),
                    "output_mode" => ::core::option::Option::Some(4usize),
                    "msaa_writeback" => ::core::option::Option::Some(5usize),
                    "clear_color" => ::core::option::Option::Some(6usize),
                    "invert_culling" => ::core::option::Option::Some(7usize),
                    "sub_camera_view" => ::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("viewport",
                    bevy_reflect::PartialReflect::to_dynamic(&self.viewport));
                dynamic.insert_boxed("order",
                    bevy_reflect::PartialReflect::to_dynamic(&self.order));
                dynamic.insert_boxed("is_active",
                    bevy_reflect::PartialReflect::to_dynamic(&self.is_active));
                dynamic.insert_boxed("computed",
                    bevy_reflect::PartialReflect::to_dynamic(&self.computed));
                dynamic.insert_boxed("output_mode",
                    bevy_reflect::PartialReflect::to_dynamic(&self.output_mode));
                dynamic.insert_boxed("msaa_writeback",
                    bevy_reflect::PartialReflect::to_dynamic(&self.msaa_writeback));
                dynamic.insert_boxed("clear_color",
                    bevy_reflect::PartialReflect::to_dynamic(&self.clear_color));
                dynamic.insert_boxed("invert_culling",
                    bevy_reflect::PartialReflect::to_dynamic(&self.invert_culling));
                dynamic.insert_boxed("sub_camera_view",
                    bevy_reflect::PartialReflect::to_dynamic(&self.sub_camera_view));
                dynamic
            }
        }
        impl bevy_reflect::PartialReflect for Camera 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 Camera 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) =
                            (||
                                        <Option<Viewport> as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "viewport")?))() {
                        __this.viewport = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <isize as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "order")?))() {
                        __this.order = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <bool as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "is_active")?))() {
                        __this.is_active = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <ComputedCameraValues as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "computed")?))() {
                        __this.computed = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <CameraOutputMode as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "output_mode")?))() {
                        __this.output_mode = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <MsaaWriteback as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "msaa_writeback")?))() {
                        __this.msaa_writeback = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <ClearColorConfig as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "clear_color")?))() {
                        __this.clear_color = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <bool as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "invert_culling")?))() {
                        __this.invert_culling = __field;
                    }
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <Option<SubCameraView> as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                                    "sub_camera_view")?))() {
                        __this.sub_camera_view = __field;
                    }
                    ::core::option::Option::Some(__this)
                } else { ::core::option::Option::None }
            }
        }
    };Reflect, #[automatically_derived]
impl ::core::clone::Clone for Camera {
    #[inline]
    fn clone(&self) -> Camera {
        Camera {
            viewport: ::core::clone::Clone::clone(&self.viewport),
            order: ::core::clone::Clone::clone(&self.order),
            is_active: ::core::clone::Clone::clone(&self.is_active),
            computed: ::core::clone::Clone::clone(&self.computed),
            output_mode: ::core::clone::Clone::clone(&self.output_mode),
            msaa_writeback: ::core::clone::Clone::clone(&self.msaa_writeback),
            clear_color: ::core::clone::Clone::clone(&self.clear_color),
            invert_culling: ::core::clone::Clone::clone(&self.invert_culling),
            sub_camera_view: ::core::clone::Clone::clone(&self.sub_camera_view),
        }
    }
}Clone)]
375#[reflect(Component, Default, Debug, Clone)]
376#[require(
377    Frustum,
378    CameraMainTextureUsages,
379    VisibleEntities,
380    Transform,
381    Visibility,
382    RenderTarget
383)]
384pub struct Camera {
385    /// If set, this camera will render to the given [`Viewport`] rectangle within the configured [`RenderTarget`].
386    pub viewport: Option<Viewport>,
387    /// Cameras with a higher order are rendered later, and thus on top of lower order cameras.
388    pub order: isize,
389    /// If this is set to `true`, this camera will be rendered to its specified [`RenderTarget`]. If `false`, this
390    /// camera will not be rendered.
391    pub is_active: bool,
392    /// Computed values for this camera, such as the projection matrix and the render target size.
393    pub computed: ComputedCameraValues,
394    // todo: reflect this when #6042 lands
395    /// The [`CameraOutputMode`] for this camera.
396    pub output_mode: CameraOutputMode,
397    /// Controls when MSAA writeback occurs for this camera.
398    /// See [`MsaaWriteback`] for available options.
399    pub msaa_writeback: MsaaWriteback,
400    /// The clear color operation to perform on the render target.
401    pub clear_color: ClearColorConfig,
402    /// Whether to switch culling mode so that materials that request backface
403    /// culling cull front faces, and vice versa.
404    ///
405    /// This is typically used for cameras that mirror the world that they
406    /// render across a plane, because doing that flips the winding of each
407    /// polygon.
408    ///
409    /// This setting doesn't affect materials that disable backface culling.
410    pub invert_culling: bool,
411    /// If set, this camera will be a sub camera of a large view, defined by a [`SubCameraView`].
412    pub sub_camera_view: Option<SubCameraView>,
413}
414
415impl Default for Camera {
416    fn default() -> Self {
417        Self {
418            is_active: true,
419            order: 0,
420            viewport: None,
421            computed: Default::default(),
422            output_mode: Default::default(),
423            msaa_writeback: MsaaWriteback::default(),
424            clear_color: Default::default(),
425            invert_culling: false,
426            sub_camera_view: None,
427        }
428    }
429}
430
431impl Camera {
432    /// Converts a physical size in this `Camera` to a logical size.
433    #[inline]
434    pub fn to_logical(&self, physical_size: UVec2) -> Option<Vec2> {
435        let scale = self.computed.target_info.as_ref()?.scale_factor;
436        Some(physical_size.as_vec2() / scale)
437    }
438
439    /// The rendered physical bounds [`URect`] of the camera. If the `viewport` field is
440    /// set to [`Some`], this will be the rect of that custom viewport. Otherwise it will default to
441    /// the full physical rect of the current [`RenderTarget`].
442    #[inline]
443    pub fn physical_viewport_rect(&self) -> Option<URect> {
444        let min = self
445            .viewport
446            .as_ref()
447            .map(|v| v.physical_position)
448            .unwrap_or(UVec2::ZERO);
449        let max = min + self.physical_viewport_size()?;
450        Some(URect { min, max })
451    }
452
453    /// The rendered logical bounds [`Rect`] of the camera. If the `viewport` field is set to
454    /// [`Some`], this will be the rect of that custom viewport. Otherwise it will default to the
455    /// full logical rect of the current [`RenderTarget`].
456    #[inline]
457    pub fn logical_viewport_rect(&self) -> Option<Rect> {
458        let URect { min, max } = self.physical_viewport_rect()?;
459        Some(Rect {
460            min: self.to_logical(min)?,
461            max: self.to_logical(max)?,
462        })
463    }
464
465    /// The logical size of this camera's viewport. If the `viewport` field is set to [`Some`], this
466    /// will be the size of that custom viewport. Otherwise it will default to the full logical size
467    /// of the current [`RenderTarget`].
468    ///  For logic that requires the full logical size of the
469    /// [`RenderTarget`], prefer [`Camera::logical_target_size`].
470    ///
471    /// Returns `None` if either:
472    /// - the function is called just after the `Camera` is created, before `camera_system` is executed,
473    /// - the [`RenderTarget`] isn't correctly set:
474    ///   - it references the [`PrimaryWindow`](RenderTarget::Window) when there is none,
475    ///   - it references a [`Window`](RenderTarget::Window) entity that doesn't exist or doesn't actually have a `Window` component,
476    ///   - it references an [`Image`](RenderTarget::Image) that doesn't exist (invalid handle),
477    ///   - it references a [`TextureView`](RenderTarget::TextureView) that doesn't exist (invalid handle).
478    #[inline]
479    pub fn logical_viewport_size(&self) -> Option<Vec2> {
480        self.viewport
481            .as_ref()
482            .and_then(|v| self.to_logical(v.physical_size))
483            .or_else(|| self.logical_target_size())
484    }
485
486    /// The physical size of this camera's viewport (in physical pixels).
487    /// If the `viewport` field is set to [`Some`], this
488    /// will be the size of that custom viewport. Otherwise it will default to the full physical size of
489    /// the current [`RenderTarget`].
490    /// For logic that requires the full physical size of the [`RenderTarget`], prefer [`Camera::physical_target_size`].
491    #[inline]
492    pub fn physical_viewport_size(&self) -> Option<UVec2> {
493        self.viewport
494            .as_ref()
495            .map(|v| v.physical_size)
496            .or_else(|| self.physical_target_size())
497    }
498
499    /// The full logical size of this camera's [`RenderTarget`], ignoring custom `viewport` configuration.
500    /// Note that if the `viewport` field is [`Some`], this will not represent the size of the rendered area.
501    /// For logic that requires the size of the actually rendered area, prefer [`Camera::logical_viewport_size`].
502    #[inline]
503    pub fn logical_target_size(&self) -> Option<Vec2> {
504        self.computed
505            .target_info
506            .as_ref()
507            .and_then(|t| self.to_logical(t.physical_size))
508    }
509
510    /// The full physical size of this camera's [`RenderTarget`] (in physical pixels),
511    /// ignoring custom `viewport` configuration.
512    /// Note that if the `viewport` field is [`Some`], this will not represent the size of the rendered area.
513    /// For logic that requires the size of the actually rendered area, prefer [`Camera::physical_viewport_size`].
514    #[inline]
515    pub fn physical_target_size(&self) -> Option<UVec2> {
516        self.computed.target_info.as_ref().map(|t| t.physical_size)
517    }
518
519    #[inline]
520    pub fn target_scaling_factor(&self) -> Option<f32> {
521        self.computed
522            .target_info
523            .as_ref()
524            .map(|t: &RenderTargetInfo| t.scale_factor)
525    }
526
527    /// The projection matrix computed using this camera's [`Projection`](super::projection::Projection).
528    #[inline]
529    pub fn clip_from_view(&self) -> Mat4 {
530        self.computed.clip_from_view
531    }
532
533    /// Core conversion logic to compute viewport coordinates
534    ///
535    /// This function is shared by `world_to_viewport` and `world_to_viewport_with_depth`
536    /// to avoid code duplication.
537    ///
538    /// Returns a tuple `(viewport_position, depth)`.
539    fn world_to_viewport_core(
540        &self,
541        camera_transform: &GlobalTransform,
542        world_position: Vec3,
543    ) -> Result<(Vec2, f32), ViewportConversionError> {
544        let target_rect = self
545            .logical_viewport_rect()
546            .ok_or(ViewportConversionError::NoViewportSize)?;
547        let mut ndc_space_coords = self
548            .world_to_ndc(camera_transform, world_position)
549            .ok_or(ViewportConversionError::InvalidData)?;
550        // NDC z-values outside of 0 < z < 1 are outside the (implicit) camera frustum and are thus not in viewport-space
551        if ndc_space_coords.z < 0.0 {
552            return Err(ViewportConversionError::PastFarPlane);
553        }
554        if ndc_space_coords.z > 1.0 {
555            return Err(ViewportConversionError::PastNearPlane);
556        }
557
558        let depth = ndc_space_coords.z;
559
560        // Flip the Y co-ordinate origin from the bottom to the top.
561        ndc_space_coords.y = -ndc_space_coords.y;
562
563        // Once in NDC space, we can discard the z element and map x/y to the viewport rect
564        let viewport_position =
565            (ndc_space_coords.truncate() + Vec2::ONE) / 2.0 * target_rect.size() + target_rect.min;
566        Ok((viewport_position, depth))
567    }
568
569    /// Given a position in world space, use the camera to compute the viewport-space coordinates.
570    ///
571    /// To get the coordinates in Normalized Device Coordinates, you should use
572    /// [`world_to_ndc`](Self::world_to_ndc).
573    ///
574    /// # Panics
575    ///
576    /// Will panic if `glam_assert` is enabled and the `camera_transform` contains `NAN`
577    /// (see [`world_to_ndc`][Self::world_to_ndc]).
578    #[doc(alias = "world_to_screen")]
579    pub fn world_to_viewport(
580        &self,
581        camera_transform: &GlobalTransform,
582        world_position: Vec3,
583    ) -> Result<Vec2, ViewportConversionError> {
584        Ok(self
585            .world_to_viewport_core(camera_transform, world_position)?
586            .0)
587    }
588
589    /// Given a position in world space, use the camera to compute the viewport-space coordinates and depth.
590    ///
591    /// To get the coordinates in Normalized Device Coordinates, you should use
592    /// [`world_to_ndc`](Self::world_to_ndc).
593    ///
594    /// # Panics
595    ///
596    /// Will panic if `glam_assert` is enabled and the `camera_transform` contains `NAN`
597    /// (see [`world_to_ndc`][Self::world_to_ndc]).
598    #[doc(alias = "world_to_screen_with_depth")]
599    pub fn world_to_viewport_with_depth(
600        &self,
601        camera_transform: &GlobalTransform,
602        world_position: Vec3,
603    ) -> Result<Vec3, ViewportConversionError> {
604        let result = self.world_to_viewport_core(camera_transform, world_position)?;
605        // Stretching ndc depth to value via near plane and negating result to be in positive room again.
606        let depth = -self.depth_ndc_to_view_z(result.1);
607        Ok(result.0.extend(depth))
608    }
609
610    /// Returns a ray originating from the camera, that passes through everything beyond `viewport_position`.
611    ///
612    /// The resulting ray starts on the near plane of the camera.
613    ///
614    /// If the camera's projection is orthographic the direction of the ray is always equal to `camera_transform.forward()`.
615    ///
616    /// To get the world space coordinates with Normalized Device Coordinates, you should use
617    /// [`ndc_to_world`](Self::ndc_to_world).
618    ///
619    /// # Example
620    /// ```no_run
621    /// # use bevy_window::Window;
622    /// # use bevy_ecs::prelude::{Single, IntoScheduleConfigs};
623    /// # use bevy_transform::prelude::{GlobalTransform, TransformSystems};
624    /// # use bevy_camera::Camera;
625    /// # use bevy_app::{App, PostUpdate};
626    /// #
627    /// fn system(camera_query: Single<(&Camera, &GlobalTransform)>, window: Single<&Window>) {
628    ///     let (camera, camera_transform) = *camera_query;
629    ///
630    ///     if let Some(cursor_position) = window.cursor_position()
631    ///         // Calculate a ray pointing from the camera into the world based on the cursor's position.
632    ///         && let Ok(ray) = camera.viewport_to_world(camera_transform, cursor_position)
633    ///     {
634    ///         println!("{ray:?}");
635    ///     }
636    /// }
637    ///
638    /// # let mut app = App::new();
639    /// // Run the system after transform propagation so the camera's global transform is up-to-date.
640    /// app.add_systems(PostUpdate, system.after(TransformSystems::Propagate));
641    /// ```
642    ///
643    /// # Panics
644    ///
645    /// Will panic if the camera's projection matrix is invalid (has a determinant of 0) and
646    /// `glam_assert` is enabled (see [`ndc_to_world`](Self::ndc_to_world).
647    pub fn viewport_to_world(
648        &self,
649        camera_transform: &GlobalTransform,
650        viewport_position: Vec2,
651    ) -> Result<Ray3d, ViewportConversionError> {
652        let ndc_xy = self.viewport_to_ndc(viewport_position)?;
653
654        let ndc_point_near = ndc_xy.extend(1.0).into();
655        // Using EPSILON because an ndc with Z = 0 returns NaNs.
656        let ndc_point_far = ndc_xy.extend(f32::EPSILON).into();
657        let view_from_clip = self.computed.clip_from_view.inverse();
658        let world_from_view = camera_transform.affine();
659        // We multiply the point by `view_from_clip` and then `world_from_view` in sequence to avoid the precision loss
660        // (and performance penalty) incurred by pre-composing an affine transform with a projective transform.
661        // Additionally, we avoid adding and subtracting translation to the direction component to maintain precision.
662        let view_point_near = view_from_clip.project_point3a(ndc_point_near);
663        let view_point_far = view_from_clip.project_point3a(ndc_point_far);
664        let view_dir = view_point_far - view_point_near;
665        let origin = world_from_view.transform_point3a(view_point_near).into();
666        let direction = world_from_view.transform_vector3a(view_dir).into();
667
668        // The fallible direction constructor ensures that direction isn't NaN.
669        Dir3::new(direction)
670            .map_err(|_| ViewportConversionError::InvalidData)
671            .map(|direction| Ray3d { origin, direction })
672    }
673
674    /// Returns a 2D world position computed from a position on this [`Camera`]'s viewport.
675    ///
676    /// Useful for 2D cameras and other cameras with an orthographic projection pointing along the Z axis.
677    ///
678    /// To get the world space coordinates with Normalized Device Coordinates, you should use
679    /// [`ndc_to_world`](Self::ndc_to_world).
680    ///
681    /// # Example
682    /// ```no_run
683    /// # use bevy_window::Window;
684    /// # use bevy_ecs::prelude::*;
685    /// # use bevy_transform::prelude::{GlobalTransform, TransformSystems};
686    /// # use bevy_camera::Camera;
687    /// # use bevy_app::{App, PostUpdate};
688    /// #
689    /// fn system(camera_query: Single<(&Camera, &GlobalTransform)>, window: Single<&Window>) {
690    ///     let (camera, camera_transform) = *camera_query;
691    ///
692    ///     if let Some(cursor_position) = window.cursor_position()
693    ///         // Calculate a world position based on the cursor's position.
694    ///         && let Ok(world_pos) = camera.viewport_to_world_2d(camera_transform, cursor_position)
695    ///     {
696    ///         println!("World position: {world_pos:.2}");
697    ///     }
698    /// }
699    ///
700    /// # let mut app = App::new();
701    /// // Run the system after transform propagation so the camera's global transform is up-to-date.
702    /// app.add_systems(PostUpdate, system.after(TransformSystems::Propagate));
703    /// ```
704    ///
705    /// # Panics
706    ///
707    /// Will panic if the camera's projection matrix is invalid (has a determinant of 0) and
708    /// `glam_assert` is enabled (see [`ndc_to_world`](Self::ndc_to_world).
709    pub fn viewport_to_world_2d(
710        &self,
711        camera_transform: &GlobalTransform,
712        viewport_position: Vec2,
713    ) -> Result<Vec2, ViewportConversionError> {
714        let ndc = self.viewport_to_ndc(viewport_position)?;
715
716        let world_near_plane = self
717            .ndc_to_world(camera_transform, ndc.extend(1.))
718            .ok_or(ViewportConversionError::InvalidData)?;
719
720        Ok(world_near_plane.truncate())
721    }
722
723    /// Given a point in world space, use the camera's viewport to compute the Normalized Device Coordinates of the point.
724    ///
725    /// When the point is within the viewport the values returned will be between -1.0 (bottom left) and 1.0 (top right)
726    /// on the X and Y axes, and between 0.0 (far) and 1.0 (near) on the Z axis.
727    /// To get the coordinates in the render target's viewport dimensions, you should use
728    /// [`world_to_viewport`](Self::world_to_viewport).
729    ///
730    /// Returns `None` if the `camera_transform`, the `world_position`, or the projection matrix defined by
731    /// [`Projection`](super::projection::Projection) contain `NAN`.
732    ///
733    /// # Panics
734    ///
735    /// Will panic if the `camera_transform` contains `NAN` and the `glam_assert` feature is enabled.
736    pub fn world_to_ndc<V: Into<Vec3A> + From<Vec3A>>(
737        &self,
738        camera_transform: &GlobalTransform,
739        world_point: V,
740    ) -> Option<V> {
741        let view_from_world = camera_transform.affine().inverse();
742        let view_point = view_from_world.transform_point3a(world_point.into());
743        let ndc_point = self.computed.clip_from_view.project_point3a(view_point);
744
745        (!ndc_point.is_nan()).then_some(ndc_point.into())
746    }
747
748    /// Given a position in Normalized Device Coordinates,
749    /// use the camera's viewport to compute the world space position.
750    ///
751    /// The input is expected to be in NDC: `x` and `y` in the range `[-1.0, 1.0]`, and `z` in `[0.0, 1.0]`
752    /// (with `z = 0.0` at the far plane and `z = 1.0` at the near plane).
753    /// The returned value is a position in world space (your game's world units) and is not limited to `[-1.0, 1.0]`.
754    /// To convert from a viewport position to world space, you should use
755    /// [`viewport_to_world`](Self::viewport_to_world).
756    ///
757    /// Returns `None` if the `camera_transform`, the `ndc_point`, or the projection matrix defined by
758    /// [`Projection`](super::projection::Projection) contain `NAN`.
759    ///
760    /// # Panics
761    ///
762    /// Will panic if the projection matrix is invalid (has a determinant of 0) and `glam_assert` is enabled.
763    pub fn ndc_to_world<V: Into<Vec3A> + From<Vec3A>>(
764        &self,
765        camera_transform: &GlobalTransform,
766        ndc_point: V,
767    ) -> Option<V> {
768        // We multiply the point by `view_from_clip` and then `world_from_view` in sequence to avoid the precision loss
769        // (and performance penalty) incurred by pre-composing an affine transform with a projective transform.
770        let view_point = self
771            .computed
772            .clip_from_view
773            .inverse()
774            .project_point3a(ndc_point.into());
775        let world_point = camera_transform.affine().transform_point3a(view_point);
776
777        (!world_point.is_nan()).then_some(world_point.into())
778    }
779
780    /// Converts the depth in Normalized Device Coordinates
781    /// to linear view z for perspective projections.
782    ///
783    /// Note: Depth values in front of the camera will be negative as -z is forward
784    pub fn depth_ndc_to_view_z(&self, ndc_depth: f32) -> f32 {
785        let near = self.clip_from_view().w_axis.z; // [3][2]
786        -near / ndc_depth
787    }
788
789    /// Converts the depth in Normalized Device Coordinates
790    /// to linear view z for orthographic projections.
791    ///
792    /// Note: Depth values in front of the camera will be negative as -z is forward
793    pub fn depth_ndc_to_view_z_2d(&self, ndc_depth: f32) -> f32 {
794        -(self.clip_from_view().w_axis.z - ndc_depth) / self.clip_from_view().z_axis.z
795        //                       [3][2]                                         [2][2]
796    }
797
798    /// Converts a position in viewport coordinates to NDC.
799    pub fn viewport_to_ndc(
800        &self,
801        viewport_position: Vec2,
802    ) -> Result<Vec2, ViewportConversionError> {
803        let target_rect = self
804            .logical_viewport_rect()
805            .ok_or(ViewportConversionError::NoViewportSize)?;
806        let rect_relative = (viewport_position - target_rect.min) / target_rect.size();
807        let mut ndc = rect_relative * 2. - Vec2::ONE;
808        // Flip the Y co-ordinate from the top to the bottom to enter NDC.
809        ndc.y = -ndc.y;
810        Ok(ndc)
811    }
812}
813
814/// The entity that Bevy uses to resolve visibility ranges when no specific
815/// camera is applicable.
816///
817/// For efficiency, Bevy currently renders point and spot light shadow maps only
818/// once per frame, regardless of the number of cameras in use, rather than
819/// rendering the shadow maps anew for each camera each frame. Most of the time,
820/// this optimization doesn't change the result relative to a rendering that
821/// rendered such shadow maps separately for each camera. However, there's one
822/// exception: visibility ranges. Visibility ranges cause meshes to be visible
823/// or invisible depending on the distance from the mesh to the camera. When
824/// rendering a shadow map for a point or spot light, Bevy must therefore select
825/// an entity to use as the reference point for the purposes of visibility
826/// ranges. This entity is called the *LOD origin*.
827///
828/// Placing this component on an entity makes that entity the origin from which
829/// LOD distances are computed for the purposes of shadow mapping of point and
830/// spot lights. Typically, you place this component on a camera, but you may
831/// place it on another entity if you wish.
832///
833/// The exact algorithm that Bevy uses to determine the LOD origin is as
834/// follows. Once the LOD origin is determined, all further steps are skipped.
835///
836/// 1. If an entity has this [`ShadowLodOrigin`] component, then it's the LOD
837///    origin. If there's more than one entity with the [`ShadowLodOrigin`]
838///    component, one is chosen arbitrarily in a manner that's stable from frame to
839///    frame.
840///
841/// 2. If a camera renders to a window (that is, the camera's [`RenderTarget`]
842///    is [`RenderTarget::Window`]), then that camera is the shadow LOD origin. If
843///    there's more than one such camera that renders to a window, then one is
844///    chosen arbitrarily in a manner that's stable from frame to frame.
845///
846/// 3. A camera is chosen to be the LOD origin arbitrarily from all cameras in
847///    the scene in a manner that's stable from frame to frame.
848///
849/// This algorithm means that, in most cases, you don't need to add this
850/// [`ShadowLodOrigin`] component explicitly to the scene; usually, Bevy chooses
851/// the right origin automatically. You only need to use this component
852/// explicitly if you have multiple cameras rendering to the window: e.g. in a
853/// split-screen game.
854#[derive(#[automatically_derived]
impl ::core::clone::Clone for ShadowLodOrigin {
    #[inline]
    fn clone(&self) -> ShadowLodOrigin { *self }
}Clone, #[automatically_derived]
impl ::core::marker::Copy for ShadowLodOrigin { }Copy, #[automatically_derived]
impl ::core::default::Default for ShadowLodOrigin {
    #[inline]
    fn default() -> ShadowLodOrigin { ShadowLodOrigin {} }
}Default, #[doc =
"**Required Components**: [`Transform`]. \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 ShadowLodOrigin 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);
    }
    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 ShadowLodOrigin {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        ::core::fmt::Formatter::write_str(f, "ShadowLodOrigin")
    }
}Debug, const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for ShadowLodOrigin 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::<ReflectDefault, Self>();
                registration.register_type_data::<ReflectComponent, Self>();
                registration
            }
            #[inline(never)]
            fn register_type_dependencies(registry:
                    &mut bevy_reflect::TypeRegistry) {}
        }
        impl bevy_reflect::Typed for ShadowLodOrigin 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 ShadowLodOrigin where  {
            fn type_path() -> &'static str {
                "bevy_camera::camera::ShadowLodOrigin"
            }
            fn short_type_path() -> &'static str { "ShadowLodOrigin" }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("ShadowLodOrigin")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera")
            }
        }
        impl bevy_reflect::Reflect for ShadowLodOrigin 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(<ShadowLodOrigin
                                        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 ShadowLodOrigin 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 ShadowLodOrigin 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)
            }
            #[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 ShadowLodOrigin 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)]
855#[reflect(Clone, Default, Component)]
856#[require(Transform)]
857pub struct ShadowLodOrigin;
858
859/// Control how this [`Camera`] outputs once rendering is completed.
860#[derive(#[automatically_derived]
impl ::core::fmt::Debug for CameraOutputMode {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        match self {
            CameraOutputMode::Write {
                blend_state: __self_0, clear_color: __self_1 } =>
                ::core::fmt::Formatter::debug_struct_field2_finish(f, "Write",
                    "blend_state", __self_0, "clear_color", &__self_1),
            CameraOutputMode::Skip =>
                ::core::fmt::Formatter::write_str(f, "Skip"),
        }
    }
}Debug, #[automatically_derived]
impl ::core::clone::Clone for CameraOutputMode {
    #[inline]
    fn clone(&self) -> CameraOutputMode {
        let _: ::core::clone::AssertParamIsClone<Option<BlendState>>;
        let _: ::core::clone::AssertParamIsClone<ClearColorConfig>;
        *self
    }
}Clone, #[automatically_derived]
impl ::core::marker::Copy for CameraOutputMode { }Copy, const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for CameraOutputMode 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
            }
            #[inline(never)]
            fn register_type_dependencies(registry:
                    &mut bevy_reflect::TypeRegistry) {
                <Option<BlendState> as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <ClearColorConfig as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
            }
        }
        impl bevy_reflect::Typed for CameraOutputMode 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::Enum(bevy_reflect::enums::EnumInfo::new::<Self>(&[bevy_reflect::enums::VariantInfo::Struct(bevy_reflect::enums::StructVariantInfo::new("Write",
                                                        &[bevy_reflect::NamedField::new::<Option<BlendState>>("blend_state"),
                                                                    bevy_reflect::NamedField::new::<ClearColorConfig>("clear_color")])),
                                                bevy_reflect::enums::VariantInfo::Unit(bevy_reflect::enums::UnitVariantInfo::new("Skip"))]))
                        })
            }
        }
        #[allow(deprecated, reason =
        "derives on a deprecated type shouldn't be considered a usage")]
        impl bevy_reflect::TypePath for CameraOutputMode where  {
            fn type_path() -> &'static str {
                "bevy_camera::camera::CameraOutputMode"
            }
            fn short_type_path() -> &'static str { "CameraOutputMode" }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("CameraOutputMode")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera")
            }
        }
        impl bevy_reflect::Reflect for CameraOutputMode 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(<CameraOutputMode
                                        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::enums::Enum for CameraOutputMode where  {
            fn field(&self, __name_param: &str)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match self {
                    CameraOutputMode::Write { blend_state: __value, .. } if
                        __name_param == "blend_state" =>
                        ::core::option::Option::Some(__value),
                    CameraOutputMode::Write { clear_color: __value, .. } if
                        __name_param == "clear_color" =>
                        ::core::option::Option::Some(__value),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_at(&self, __index_param: usize)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match self {
                    CameraOutputMode::Write { blend_state: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    CameraOutputMode::Write { clear_color: __value, .. } if
                        __index_param == 1usize =>
                        ::core::option::Option::Some(__value),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_mut(&mut self, __name_param: &str)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match self {
                    CameraOutputMode::Write { blend_state: __value, .. } if
                        __name_param == "blend_state" =>
                        ::core::option::Option::Some(__value),
                    CameraOutputMode::Write { clear_color: __value, .. } if
                        __name_param == "clear_color" =>
                        ::core::option::Option::Some(__value),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_at_mut(&mut self, __index_param: usize)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match self {
                    CameraOutputMode::Write { blend_state: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    CameraOutputMode::Write { clear_color: __value, .. } if
                        __index_param == 1usize =>
                        ::core::option::Option::Some(__value),
                    _ => ::core::option::Option::None,
                }
            }
            fn index_of(&self, __name_param: &str)
                -> ::core::option::Option<usize> {
                match self {
                    CameraOutputMode::Write { .. } if
                        __name_param == "blend_state" =>
                        ::core::option::Option::Some(0usize),
                    CameraOutputMode::Write { .. } if
                        __name_param == "clear_color" =>
                        ::core::option::Option::Some(1usize),
                    _ => ::core::option::Option::None,
                }
            }
            fn name_at(&self, __index_param: usize)
                -> ::core::option::Option<&str> {
                match self {
                    CameraOutputMode::Write { .. } if __index_param == 0usize =>
                        ::core::option::Option::Some("blend_state"),
                    CameraOutputMode::Write { .. } if __index_param == 1usize =>
                        ::core::option::Option::Some("clear_color"),
                    _ => ::core::option::Option::None,
                }
            }
            fn iter_fields(&self) -> bevy_reflect::enums::VariantFieldIter {
                bevy_reflect::enums::VariantFieldIter::new(self)
            }
            #[inline]
            fn field_len(&self) -> usize {
                match self {
                    CameraOutputMode::Write { .. } => 2usize,
                    CameraOutputMode::Skip { .. } => 0usize,
                    _ => 0,
                }
            }
            #[inline]
            fn variant_name(&self) -> &str {
                match self {
                    CameraOutputMode::Write { .. } => "Write",
                    CameraOutputMode::Skip { .. } => "Skip",
                    _ =>
                        ::core::panicking::panic("internal error: entered unreachable code"),
                }
            }
            #[inline]
            fn variant_index(&self) -> usize {
                match self {
                    CameraOutputMode::Write { .. } => 0usize,
                    CameraOutputMode::Skip { .. } => 1usize,
                    _ =>
                        ::core::panicking::panic("internal error: entered unreachable code"),
                }
            }
            #[inline]
            fn variant_type(&self) -> bevy_reflect::enums::VariantType {
                match self {
                    CameraOutputMode::Write { .. } =>
                        bevy_reflect::enums::VariantType::Struct,
                    CameraOutputMode::Skip { .. } =>
                        bevy_reflect::enums::VariantType::Unit,
                    _ =>
                        ::core::panicking::panic("internal error: entered unreachable code"),
                }
            }
            fn to_dynamic_enum(&self) -> bevy_reflect::enums::DynamicEnum {
                bevy_reflect::enums::DynamicEnum::from_ref::<Self>(self)
            }
        }
        impl bevy_reflect::PartialReflect for CameraOutputMode 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_param: &dyn bevy_reflect::PartialReflect)
                -> ::core::result::Result<(), bevy_reflect::ApplyError> {
                if let bevy_reflect::ReflectRef::Enum(__value_param) =
                        bevy_reflect::PartialReflect::reflect_ref(__value_param) {
                    if bevy_reflect::enums::Enum::variant_name(self) ==
                            bevy_reflect::enums::Enum::variant_name(__value_param) {
                        match bevy_reflect::enums::Enum::variant_type(__value_param)
                            {
                            bevy_reflect::enums::VariantType::Struct => {
                                for field in
                                    bevy_reflect::enums::Enum::iter_fields(__value_param) {
                                    let name = field.name().unwrap();
                                    if let ::core::option::Option::Some(v) =
                                            bevy_reflect::enums::Enum::field_mut(self, name) {
                                        bevy_reflect::PartialReflect::try_apply(v, field.value())?;
                                    }
                                }
                            }
                            bevy_reflect::enums::VariantType::Tuple => {
                                for (index, field) in
                                    ::core::iter::Iterator::enumerate(bevy_reflect::enums::Enum::iter_fields(__value_param))
                                    {
                                    if let ::core::option::Option::Some(v) =
                                            bevy_reflect::enums::Enum::field_at_mut(self, index) {
                                        bevy_reflect::PartialReflect::try_apply(v, field.value())?;
                                    }
                                }
                            }
                            _ => {}
                        }
                    } else {
                        match bevy_reflect::enums::Enum::variant_name(__value_param)
                            {
                            "Write" => {
                                *self =
                                    CameraOutputMode::Write {
                                        blend_state: {
                                            let __blend_state = __value_param.field("blend_state");
                                            let __blend_state =
                                                __blend_state.ok_or(bevy_reflect::ApplyError::MissingEnumField {
                                                            variant_name: ::core::convert::Into::into("Write"),
                                                            field_name: ::core::convert::Into::into("blend_state"),
                                                        })?;
                                            <Option<BlendState> as
                                                            bevy_reflect::FromReflect>::from_reflect(__blend_state).ok_or(bevy_reflect::ApplyError::MismatchedTypes {
                                                        from_type: ::core::convert::Into::into(bevy_reflect::DynamicTypePath::reflect_type_path(__blend_state)),
                                                        to_type: ::core::convert::Into::into(<Option<BlendState> as
                                                                    bevy_reflect::TypePath>::type_path()),
                                                    })?
                                        },
                                        clear_color: {
                                            let __clear_color = __value_param.field("clear_color");
                                            let __clear_color =
                                                __clear_color.ok_or(bevy_reflect::ApplyError::MissingEnumField {
                                                            variant_name: ::core::convert::Into::into("Write"),
                                                            field_name: ::core::convert::Into::into("clear_color"),
                                                        })?;
                                            <ClearColorConfig as
                                                            bevy_reflect::FromReflect>::from_reflect(__clear_color).ok_or(bevy_reflect::ApplyError::MismatchedTypes {
                                                        from_type: ::core::convert::Into::into(bevy_reflect::DynamicTypePath::reflect_type_path(__clear_color)),
                                                        to_type: ::core::convert::Into::into(<ClearColorConfig as
                                                                    bevy_reflect::TypePath>::type_path()),
                                                    })?
                                        },
                                    }
                            }
                            "Skip" => { *self = CameraOutputMode::Skip {} }
                            name => {
                                return ::core::result::Result::Err(bevy_reflect::ApplyError::UnknownVariant {
                                            enum_name: ::core::convert::Into::into(bevy_reflect::DynamicTypePath::reflect_type_path(self)),
                                            variant_name: ::core::convert::Into::into(name),
                                        });
                            }
                        }
                    }
                } else {
                    return ::core::result::Result::Err(bevy_reflect::ApplyError::MismatchedKinds {
                                from_kind: bevy_reflect::PartialReflect::reflect_kind(__value_param),
                                to_kind: bevy_reflect::ReflectKind::Enum,
                            });
                }
                ::core::result::Result::Ok(())
            }
            fn reflect_kind(&self) -> bevy_reflect::ReflectKind {
                bevy_reflect::ReflectKind::Enum
            }
            fn reflect_ref(&self) -> bevy_reflect::ReflectRef {
                bevy_reflect::ReflectRef::Enum(self)
            }
            fn reflect_mut(&mut self) -> bevy_reflect::ReflectMut {
                bevy_reflect::ReflectMut::Enum(self)
            }
            fn reflect_owned(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                -> bevy_reflect::ReflectOwned {
                bevy_reflect::ReflectOwned::Enum(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_hash(&self) -> ::core::option::Option<u64> {
                (bevy_reflect::enums::enum_hash)(self)
            }
            fn reflect_partial_eq(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<bool> {
                (bevy_reflect::enums::enum_partial_eq)(self, value)
            }
            fn reflect_partial_cmp(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<::core::cmp::Ordering> {
                (bevy_reflect::enums::enum_partial_cmp)(self, value)
            }
            #[inline]
            #[allow(unreachable_code, reason =
            "Ignored fields without a `clone` attribute will early-return with an error")]
            fn reflect_clone(&self)
                ->
                    ::core::result::Result<bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::Reflect>,
                    bevy_reflect::ReflectCloneError> {
                let this = self;
                ::core::result::Result::Ok(bevy_reflect::__macro_exports::alloc_utils::Box::new(match this
                            {
                            CameraOutputMode::Write {
                                blend_state: __blend_state, clear_color: __clear_color } =>
                                CameraOutputMode::Write {
                                    blend_state: <Option<BlendState> as
                                                bevy_reflect::PartialReflect>::reflect_clone_and_take(__blend_state)?,
                                    clear_color: <ClearColorConfig as
                                                bevy_reflect::PartialReflect>::reflect_clone_and_take(__clear_color)?,
                                },
                            CameraOutputMode::Skip {} => CameraOutputMode::Skip {},
                        }))
            }
        }
        impl bevy_reflect::FromReflect for CameraOutputMode where  {
            fn from_reflect(__param0: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<Self> {
                if let bevy_reflect::ReflectRef::Enum(__param0) =
                        bevy_reflect::PartialReflect::reflect_ref(__param0) {
                    match bevy_reflect::enums::Enum::variant_name(__param0) {
                        "Write" =>
                            ::core::option::Option::Some(CameraOutputMode::Write {
                                    blend_state: {
                                        let __blend_state = __param0.field("blend_state");
                                        let __blend_state = __blend_state?;
                                        <Option<BlendState> as
                                                    bevy_reflect::FromReflect>::from_reflect(__blend_state)?
                                    },
                                    clear_color: {
                                        let __clear_color = __param0.field("clear_color");
                                        let __clear_color = __clear_color?;
                                        <ClearColorConfig as
                                                    bevy_reflect::FromReflect>::from_reflect(__clear_color)?
                                    },
                                }),
                        "Skip" =>
                            ::core::option::Option::Some(CameraOutputMode::Skip {}),
                        name => ::core::option::Option::None,
                    }
                } else { ::core::option::Option::None }
            }
        }
    };Reflect)]
861pub enum CameraOutputMode {
862    /// Writes the camera output to configured render target.
863    Write {
864        /// The blend state that will be used by the pipeline that writes the intermediate render textures to the final render target texture.
865        /// If not set, the output will be written as-is, ignoring `clear_color` and the existing data in the final render target texture.
866        blend_state: Option<BlendState>,
867        /// The clear color operation to perform on the final render target texture.
868        clear_color: ClearColorConfig,
869    },
870    /// Skips writing the camera output to the configured render target. The output will remain in the
871    /// Render Target's "intermediate" textures, which a camera with a higher order should write to the render target
872    /// using [`CameraOutputMode::Write`]. The "skip" mode can easily prevent render results from being displayed, or cause
873    /// them to be lost. Only use this if you know what you are doing!
874    /// In camera setups with multiple active cameras rendering to the same [`RenderTarget`], the Skip mode can be used to remove
875    /// unnecessary / redundant writes to the final output texture, removing unnecessary render passes.
876    Skip,
877}
878
879impl Default for CameraOutputMode {
880    fn default() -> Self {
881        CameraOutputMode::Write {
882            blend_state: None,
883            clear_color: ClearColorConfig::Default,
884        }
885    }
886}
887
888/// The "target" that a [`Camera`] will render to. For example, this could be a `Window`
889/// swapchain or an [`Image`].
890#[derive(impl bevy_ecs::component::Component for RenderTarget 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 map_entities<M: bevy_ecs::entity::EntityMapper>(this: &mut Self,
        mapper: &mut M) {
        use bevy_ecs::entity::MapEntities;
        match this {
            Self::Window { .. } => {}
            Self::Image { .. } => {}
            Self::TextureView { .. } => {}
            Self::None { .. } => {}
            _ => {}
        }
    }
    fn relationship_accessor()
        ->
            ::core::option::Option<bevy_ecs::relationship::ComponentRelationshipAccessor<Self>> {
        ::core::option::Option::None
    }
}Component, #[automatically_derived]
impl ::core::fmt::Debug for RenderTarget {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        match self {
            RenderTarget::Window(__self_0) =>
                ::core::fmt::Formatter::debug_tuple_field1_finish(f, "Window",
                    &__self_0),
            RenderTarget::Image(__self_0) =>
                ::core::fmt::Formatter::debug_tuple_field1_finish(f, "Image",
                    &__self_0),
            RenderTarget::TextureView(__self_0) =>
                ::core::fmt::Formatter::debug_tuple_field1_finish(f,
                    "TextureView", &__self_0),
            RenderTarget::None { size: __self_0 } =>
                ::core::fmt::Formatter::debug_struct_field1_finish(f, "None",
                    "size", &__self_0),
        }
    }
}Debug, #[automatically_derived]
impl ::core::clone::Clone for RenderTarget {
    #[inline]
    fn clone(&self) -> RenderTarget {
        match self {
            RenderTarget::Window(__self_0) =>
                RenderTarget::Window(::core::clone::Clone::clone(__self_0)),
            RenderTarget::Image(__self_0) =>
                RenderTarget::Image(::core::clone::Clone::clone(__self_0)),
            RenderTarget::TextureView(__self_0) =>
                RenderTarget::TextureView(::core::clone::Clone::clone(__self_0)),
            RenderTarget::None { size: __self_0 } =>
                RenderTarget::None {
                    size: ::core::clone::Clone::clone(__self_0),
                },
        }
    }
}Clone, const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for RenderTarget 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
            }
            #[inline(never)]
            fn register_type_dependencies(registry:
                    &mut bevy_reflect::TypeRegistry) {
                <WindowRef as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <ImageRenderTarget as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <ManualTextureViewHandle as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <UVec2 as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
            }
        }
        impl bevy_reflect::Typed for RenderTarget 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::Enum(bevy_reflect::enums::EnumInfo::new::<Self>(&[bevy_reflect::enums::VariantInfo::Tuple(bevy_reflect::enums::TupleVariantInfo::new("Window",
                                                        &[bevy_reflect::UnnamedField::new::<WindowRef>(0usize)])),
                                                bevy_reflect::enums::VariantInfo::Tuple(bevy_reflect::enums::TupleVariantInfo::new("Image",
                                                        &[bevy_reflect::UnnamedField::new::<ImageRenderTarget>(0usize)])),
                                                bevy_reflect::enums::VariantInfo::Tuple(bevy_reflect::enums::TupleVariantInfo::new("TextureView",
                                                        &[bevy_reflect::UnnamedField::new::<ManualTextureViewHandle>(0usize)])),
                                                bevy_reflect::enums::VariantInfo::Struct(bevy_reflect::enums::StructVariantInfo::new("None",
                                                        &[bevy_reflect::NamedField::new::<UVec2>("size")]))]))
                        })
            }
        }
        #[allow(deprecated, reason =
        "derives on a deprecated type shouldn't be considered a usage")]
        impl bevy_reflect::TypePath for RenderTarget where  {
            fn type_path() -> &'static str {
                "bevy_camera::camera::RenderTarget"
            }
            fn short_type_path() -> &'static str { "RenderTarget" }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("RenderTarget")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera")
            }
        }
        impl bevy_reflect::Reflect for RenderTarget 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(<RenderTarget
                                        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::enums::Enum for RenderTarget where  {
            fn field(&self, __name_param: &str)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match self {
                    RenderTarget::None { size: __value, .. } if
                        __name_param == "size" =>
                        ::core::option::Option::Some(__value),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_at(&self, __index_param: usize)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match self {
                    RenderTarget::Window { 0: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    RenderTarget::Image { 0: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    RenderTarget::TextureView { 0: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    RenderTarget::None { size: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_mut(&mut self, __name_param: &str)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match self {
                    RenderTarget::None { size: __value, .. } if
                        __name_param == "size" =>
                        ::core::option::Option::Some(__value),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_at_mut(&mut self, __index_param: usize)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match self {
                    RenderTarget::Window { 0: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    RenderTarget::Image { 0: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    RenderTarget::TextureView { 0: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    RenderTarget::None { size: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    _ => ::core::option::Option::None,
                }
            }
            fn index_of(&self, __name_param: &str)
                -> ::core::option::Option<usize> {
                match self {
                    RenderTarget::None { .. } if __name_param == "size" =>
                        ::core::option::Option::Some(0usize),
                    _ => ::core::option::Option::None,
                }
            }
            fn name_at(&self, __index_param: usize)
                -> ::core::option::Option<&str> {
                match self {
                    RenderTarget::None { .. } if __index_param == 0usize =>
                        ::core::option::Option::Some("size"),
                    _ => ::core::option::Option::None,
                }
            }
            fn iter_fields(&self) -> bevy_reflect::enums::VariantFieldIter {
                bevy_reflect::enums::VariantFieldIter::new(self)
            }
            #[inline]
            fn field_len(&self) -> usize {
                match self {
                    RenderTarget::Window { .. } => 1usize,
                    RenderTarget::Image { .. } => 1usize,
                    RenderTarget::TextureView { .. } => 1usize,
                    RenderTarget::None { .. } => 1usize,
                    _ => 0,
                }
            }
            #[inline]
            fn variant_name(&self) -> &str {
                match self {
                    RenderTarget::Window { .. } => "Window",
                    RenderTarget::Image { .. } => "Image",
                    RenderTarget::TextureView { .. } => "TextureView",
                    RenderTarget::None { .. } => "None",
                    _ =>
                        ::core::panicking::panic("internal error: entered unreachable code"),
                }
            }
            #[inline]
            fn variant_index(&self) -> usize {
                match self {
                    RenderTarget::Window { .. } => 0usize,
                    RenderTarget::Image { .. } => 1usize,
                    RenderTarget::TextureView { .. } => 2usize,
                    RenderTarget::None { .. } => 3usize,
                    _ =>
                        ::core::panicking::panic("internal error: entered unreachable code"),
                }
            }
            #[inline]
            fn variant_type(&self) -> bevy_reflect::enums::VariantType {
                match self {
                    RenderTarget::Window { .. } =>
                        bevy_reflect::enums::VariantType::Tuple,
                    RenderTarget::Image { .. } =>
                        bevy_reflect::enums::VariantType::Tuple,
                    RenderTarget::TextureView { .. } =>
                        bevy_reflect::enums::VariantType::Tuple,
                    RenderTarget::None { .. } =>
                        bevy_reflect::enums::VariantType::Struct,
                    _ =>
                        ::core::panicking::panic("internal error: entered unreachable code"),
                }
            }
            fn to_dynamic_enum(&self) -> bevy_reflect::enums::DynamicEnum {
                bevy_reflect::enums::DynamicEnum::from_ref::<Self>(self)
            }
        }
        impl bevy_reflect::PartialReflect for RenderTarget 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_param: &dyn bevy_reflect::PartialReflect)
                -> ::core::result::Result<(), bevy_reflect::ApplyError> {
                if let bevy_reflect::ReflectRef::Enum(__value_param) =
                        bevy_reflect::PartialReflect::reflect_ref(__value_param) {
                    if bevy_reflect::enums::Enum::variant_name(self) ==
                            bevy_reflect::enums::Enum::variant_name(__value_param) {
                        match bevy_reflect::enums::Enum::variant_type(__value_param)
                            {
                            bevy_reflect::enums::VariantType::Struct => {
                                for field in
                                    bevy_reflect::enums::Enum::iter_fields(__value_param) {
                                    let name = field.name().unwrap();
                                    if let ::core::option::Option::Some(v) =
                                            bevy_reflect::enums::Enum::field_mut(self, name) {
                                        bevy_reflect::PartialReflect::try_apply(v, field.value())?;
                                    }
                                }
                            }
                            bevy_reflect::enums::VariantType::Tuple => {
                                for (index, field) in
                                    ::core::iter::Iterator::enumerate(bevy_reflect::enums::Enum::iter_fields(__value_param))
                                    {
                                    if let ::core::option::Option::Some(v) =
                                            bevy_reflect::enums::Enum::field_at_mut(self, index) {
                                        bevy_reflect::PartialReflect::try_apply(v, field.value())?;
                                    }
                                }
                            }
                            _ => {}
                        }
                    } else {
                        match bevy_reflect::enums::Enum::variant_name(__value_param)
                            {
                            "Window" => {
                                *self =
                                    RenderTarget::Window {
                                        0: {
                                            let __0 = __value_param.field_at(0usize);
                                            let __0 =
                                                __0.ok_or(bevy_reflect::ApplyError::MissingEnumField {
                                                            variant_name: ::core::convert::Into::into("Window"),
                                                            field_name: ::core::convert::Into::into(".0"),
                                                        })?;
                                            <WindowRef as
                                                            bevy_reflect::FromReflect>::from_reflect(__0).ok_or(bevy_reflect::ApplyError::MismatchedTypes {
                                                        from_type: ::core::convert::Into::into(bevy_reflect::DynamicTypePath::reflect_type_path(__0)),
                                                        to_type: ::core::convert::Into::into(<WindowRef as
                                                                    bevy_reflect::TypePath>::type_path()),
                                                    })?
                                        },
                                    }
                            }
                            "Image" => {
                                *self =
                                    RenderTarget::Image {
                                        0: {
                                            let __0 = __value_param.field_at(0usize);
                                            let __0 =
                                                __0.ok_or(bevy_reflect::ApplyError::MissingEnumField {
                                                            variant_name: ::core::convert::Into::into("Image"),
                                                            field_name: ::core::convert::Into::into(".0"),
                                                        })?;
                                            <ImageRenderTarget as
                                                            bevy_reflect::FromReflect>::from_reflect(__0).ok_or(bevy_reflect::ApplyError::MismatchedTypes {
                                                        from_type: ::core::convert::Into::into(bevy_reflect::DynamicTypePath::reflect_type_path(__0)),
                                                        to_type: ::core::convert::Into::into(<ImageRenderTarget as
                                                                    bevy_reflect::TypePath>::type_path()),
                                                    })?
                                        },
                                    }
                            }
                            "TextureView" => {
                                *self =
                                    RenderTarget::TextureView {
                                        0: {
                                            let __0 = __value_param.field_at(0usize);
                                            let __0 =
                                                __0.ok_or(bevy_reflect::ApplyError::MissingEnumField {
                                                            variant_name: ::core::convert::Into::into("TextureView"),
                                                            field_name: ::core::convert::Into::into(".0"),
                                                        })?;
                                            <ManualTextureViewHandle as
                                                            bevy_reflect::FromReflect>::from_reflect(__0).ok_or(bevy_reflect::ApplyError::MismatchedTypes {
                                                        from_type: ::core::convert::Into::into(bevy_reflect::DynamicTypePath::reflect_type_path(__0)),
                                                        to_type: ::core::convert::Into::into(<ManualTextureViewHandle
                                                                    as bevy_reflect::TypePath>::type_path()),
                                                    })?
                                        },
                                    }
                            }
                            "None" => {
                                *self =
                                    RenderTarget::None {
                                        size: {
                                            let __size = __value_param.field("size");
                                            let __size =
                                                __size.ok_or(bevy_reflect::ApplyError::MissingEnumField {
                                                            variant_name: ::core::convert::Into::into("None"),
                                                            field_name: ::core::convert::Into::into("size"),
                                                        })?;
                                            <UVec2 as
                                                            bevy_reflect::FromReflect>::from_reflect(__size).ok_or(bevy_reflect::ApplyError::MismatchedTypes {
                                                        from_type: ::core::convert::Into::into(bevy_reflect::DynamicTypePath::reflect_type_path(__size)),
                                                        to_type: ::core::convert::Into::into(<UVec2 as
                                                                    bevy_reflect::TypePath>::type_path()),
                                                    })?
                                        },
                                    }
                            }
                            name => {
                                return ::core::result::Result::Err(bevy_reflect::ApplyError::UnknownVariant {
                                            enum_name: ::core::convert::Into::into(bevy_reflect::DynamicTypePath::reflect_type_path(self)),
                                            variant_name: ::core::convert::Into::into(name),
                                        });
                            }
                        }
                    }
                } else {
                    return ::core::result::Result::Err(bevy_reflect::ApplyError::MismatchedKinds {
                                from_kind: bevy_reflect::PartialReflect::reflect_kind(__value_param),
                                to_kind: bevy_reflect::ReflectKind::Enum,
                            });
                }
                ::core::result::Result::Ok(())
            }
            fn reflect_kind(&self) -> bevy_reflect::ReflectKind {
                bevy_reflect::ReflectKind::Enum
            }
            fn reflect_ref(&self) -> bevy_reflect::ReflectRef {
                bevy_reflect::ReflectRef::Enum(self)
            }
            fn reflect_mut(&mut self) -> bevy_reflect::ReflectMut {
                bevy_reflect::ReflectMut::Enum(self)
            }
            fn reflect_owned(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                -> bevy_reflect::ReflectOwned {
                bevy_reflect::ReflectOwned::Enum(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_hash(&self) -> ::core::option::Option<u64> {
                (bevy_reflect::enums::enum_hash)(self)
            }
            fn reflect_partial_eq(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<bool> {
                (bevy_reflect::enums::enum_partial_eq)(self, value)
            }
            fn reflect_partial_cmp(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<::core::cmp::Ordering> {
                (bevy_reflect::enums::enum_partial_cmp)(self, value)
            }
            #[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 RenderTarget where  {
            fn from_reflect(__param0: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<Self> {
                if let bevy_reflect::ReflectRef::Enum(__param0) =
                        bevy_reflect::PartialReflect::reflect_ref(__param0) {
                    match bevy_reflect::enums::Enum::variant_name(__param0) {
                        "Window" =>
                            ::core::option::Option::Some(RenderTarget::Window {
                                    0: {
                                        let __0 = __param0.field_at(0usize);
                                        let __0 = __0?;
                                        <WindowRef as bevy_reflect::FromReflect>::from_reflect(__0)?
                                    },
                                }),
                        "Image" =>
                            ::core::option::Option::Some(RenderTarget::Image {
                                    0: {
                                        let __0 = __param0.field_at(0usize);
                                        let __0 = __0?;
                                        <ImageRenderTarget as
                                                    bevy_reflect::FromReflect>::from_reflect(__0)?
                                    },
                                }),
                        "TextureView" =>
                            ::core::option::Option::Some(RenderTarget::TextureView {
                                    0: {
                                        let __0 = __param0.field_at(0usize);
                                        let __0 = __0?;
                                        <ManualTextureViewHandle as
                                                    bevy_reflect::FromReflect>::from_reflect(__0)?
                                    },
                                }),
                        "None" =>
                            ::core::option::Option::Some(RenderTarget::None {
                                    size: {
                                        let __size = __param0.field("size");
                                        let __size = __size?;
                                        <UVec2 as bevy_reflect::FromReflect>::from_reflect(__size)?
                                    },
                                }),
                        name => ::core::option::Option::None,
                    }
                } else { ::core::option::Option::None }
            }
        }
    };Reflect, #[allow(deprecated)]
#[allow(unreachable_code)]
#[automatically_derived]
impl derive_more::core::convert::From<(UVec2)> for RenderTarget {
    #[inline]
    fn from(value: (UVec2)) -> Self { RenderTarget::None { size: value } }
}From)]
891#[reflect(Clone, Component)]
892pub enum RenderTarget {
893    /// Window to which the camera's view is rendered.
894    Window(WindowRef),
895    /// Image to which the camera's view is rendered.
896    Image(ImageRenderTarget),
897    /// Texture View to which the camera's view is rendered.
898    /// Useful when the texture view needs to be created outside of Bevy, for example OpenXR.
899    TextureView(ManualTextureViewHandle),
900    /// The camera won't render to any color target.
901    ///
902    /// This is useful when you want a camera that *only* renders prepasses, for
903    /// example a depth prepass. See the `render_depth_to_texture` example.
904    None {
905        /// The physical size of the viewport.
906        size: UVec2,
907    },
908}
909
910impl RenderTarget {
911    /// Get a handle to the render target's image,
912    /// or `None` if the render target is another variant.
913    pub fn as_image(&self) -> Option<&Handle<Image>> {
914        if let Self::Image(image_target) = self {
915            Some(&image_target.handle)
916        } else {
917            None
918        }
919    }
920
921    /// Normalize the render target down to a more concrete value, mostly used for equality comparisons.
922    pub fn normalize(&self, primary_window: Option<Entity>) -> Option<NormalizedRenderTarget> {
923        match self {
924            RenderTarget::Window(window_ref) => window_ref
925                .normalize(primary_window)
926                .map(NormalizedRenderTarget::Window),
927            RenderTarget::Image(handle) => Some(NormalizedRenderTarget::Image(handle.clone())),
928            RenderTarget::TextureView(id) => Some(NormalizedRenderTarget::TextureView(*id)),
929            RenderTarget::None { size } => Some(NormalizedRenderTarget::None {
930                width: size.x,
931                height: size.y,
932            }),
933        }
934    }
935}
936
937/// Normalized version of the render target.
938///
939/// Once we have this we shouldn't need to resolve it down anymore.
940#[derive(#[automatically_derived]
impl ::core::fmt::Debug for NormalizedRenderTarget {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        match self {
            NormalizedRenderTarget::Window(__self_0) =>
                ::core::fmt::Formatter::debug_tuple_field1_finish(f, "Window",
                    &__self_0),
            NormalizedRenderTarget::Image(__self_0) =>
                ::core::fmt::Formatter::debug_tuple_field1_finish(f, "Image",
                    &__self_0),
            NormalizedRenderTarget::TextureView(__self_0) =>
                ::core::fmt::Formatter::debug_tuple_field1_finish(f,
                    "TextureView", &__self_0),
            NormalizedRenderTarget::None { width: __self_0, height: __self_1 }
                =>
                ::core::fmt::Formatter::debug_struct_field2_finish(f, "None",
                    "width", __self_0, "height", &__self_1),
        }
    }
}Debug, #[automatically_derived]
impl ::core::clone::Clone for NormalizedRenderTarget {
    #[inline]
    fn clone(&self) -> NormalizedRenderTarget {
        match self {
            NormalizedRenderTarget::Window(__self_0) =>
                NormalizedRenderTarget::Window(::core::clone::Clone::clone(__self_0)),
            NormalizedRenderTarget::Image(__self_0) =>
                NormalizedRenderTarget::Image(::core::clone::Clone::clone(__self_0)),
            NormalizedRenderTarget::TextureView(__self_0) =>
                NormalizedRenderTarget::TextureView(::core::clone::Clone::clone(__self_0)),
            NormalizedRenderTarget::None { width: __self_0, height: __self_1 }
                =>
                NormalizedRenderTarget::None {
                    width: ::core::clone::Clone::clone(__self_0),
                    height: ::core::clone::Clone::clone(__self_1),
                },
        }
    }
}Clone, const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for NormalizedRenderTarget
            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
            }
            #[inline(never)]
            fn register_type_dependencies(registry:
                    &mut bevy_reflect::TypeRegistry) {
                <NormalizedWindowRef as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <ImageRenderTarget as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <ManualTextureViewHandle as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <u32 as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
            }
        }
        impl bevy_reflect::Typed for NormalizedRenderTarget 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::Enum(bevy_reflect::enums::EnumInfo::new::<Self>(&[bevy_reflect::enums::VariantInfo::Tuple(bevy_reflect::enums::TupleVariantInfo::new("Window",
                                                        &[bevy_reflect::UnnamedField::new::<NormalizedWindowRef>(0usize)])),
                                                bevy_reflect::enums::VariantInfo::Tuple(bevy_reflect::enums::TupleVariantInfo::new("Image",
                                                        &[bevy_reflect::UnnamedField::new::<ImageRenderTarget>(0usize)])),
                                                bevy_reflect::enums::VariantInfo::Tuple(bevy_reflect::enums::TupleVariantInfo::new("TextureView",
                                                        &[bevy_reflect::UnnamedField::new::<ManualTextureViewHandle>(0usize)])),
                                                bevy_reflect::enums::VariantInfo::Struct(bevy_reflect::enums::StructVariantInfo::new("None",
                                                        &[bevy_reflect::NamedField::new::<u32>("width"),
                                                                    bevy_reflect::NamedField::new::<u32>("height")]))]))
                        })
            }
        }
        #[allow(deprecated, reason =
        "derives on a deprecated type shouldn't be considered a usage")]
        impl bevy_reflect::TypePath for NormalizedRenderTarget where  {
            fn type_path() -> &'static str {
                "bevy_camera::camera::NormalizedRenderTarget"
            }
            fn short_type_path() -> &'static str { "NormalizedRenderTarget" }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("NormalizedRenderTarget")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera")
            }
        }
        impl bevy_reflect::Reflect for NormalizedRenderTarget 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(<NormalizedRenderTarget
                                        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::enums::Enum for NormalizedRenderTarget where  {
            fn field(&self, __name_param: &str)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match self {
                    NormalizedRenderTarget::None { width: __value, .. } if
                        __name_param == "width" =>
                        ::core::option::Option::Some(__value),
                    NormalizedRenderTarget::None { height: __value, .. } if
                        __name_param == "height" =>
                        ::core::option::Option::Some(__value),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_at(&self, __index_param: usize)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match self {
                    NormalizedRenderTarget::Window { 0: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    NormalizedRenderTarget::Image { 0: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    NormalizedRenderTarget::TextureView { 0: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    NormalizedRenderTarget::None { width: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    NormalizedRenderTarget::None { height: __value, .. } if
                        __index_param == 1usize =>
                        ::core::option::Option::Some(__value),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_mut(&mut self, __name_param: &str)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match self {
                    NormalizedRenderTarget::None { width: __value, .. } if
                        __name_param == "width" =>
                        ::core::option::Option::Some(__value),
                    NormalizedRenderTarget::None { height: __value, .. } if
                        __name_param == "height" =>
                        ::core::option::Option::Some(__value),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_at_mut(&mut self, __index_param: usize)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match self {
                    NormalizedRenderTarget::Window { 0: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    NormalizedRenderTarget::Image { 0: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    NormalizedRenderTarget::TextureView { 0: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    NormalizedRenderTarget::None { width: __value, .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some(__value),
                    NormalizedRenderTarget::None { height: __value, .. } if
                        __index_param == 1usize =>
                        ::core::option::Option::Some(__value),
                    _ => ::core::option::Option::None,
                }
            }
            fn index_of(&self, __name_param: &str)
                -> ::core::option::Option<usize> {
                match self {
                    NormalizedRenderTarget::None { .. } if
                        __name_param == "width" =>
                        ::core::option::Option::Some(0usize),
                    NormalizedRenderTarget::None { .. } if
                        __name_param == "height" =>
                        ::core::option::Option::Some(1usize),
                    _ => ::core::option::Option::None,
                }
            }
            fn name_at(&self, __index_param: usize)
                -> ::core::option::Option<&str> {
                match self {
                    NormalizedRenderTarget::None { .. } if
                        __index_param == 0usize =>
                        ::core::option::Option::Some("width"),
                    NormalizedRenderTarget::None { .. } if
                        __index_param == 1usize =>
                        ::core::option::Option::Some("height"),
                    _ => ::core::option::Option::None,
                }
            }
            fn iter_fields(&self) -> bevy_reflect::enums::VariantFieldIter {
                bevy_reflect::enums::VariantFieldIter::new(self)
            }
            #[inline]
            fn field_len(&self) -> usize {
                match self {
                    NormalizedRenderTarget::Window { .. } => 1usize,
                    NormalizedRenderTarget::Image { .. } => 1usize,
                    NormalizedRenderTarget::TextureView { .. } => 1usize,
                    NormalizedRenderTarget::None { .. } => 2usize,
                    _ => 0,
                }
            }
            #[inline]
            fn variant_name(&self) -> &str {
                match self {
                    NormalizedRenderTarget::Window { .. } => "Window",
                    NormalizedRenderTarget::Image { .. } => "Image",
                    NormalizedRenderTarget::TextureView { .. } => "TextureView",
                    NormalizedRenderTarget::None { .. } => "None",
                    _ =>
                        ::core::panicking::panic("internal error: entered unreachable code"),
                }
            }
            #[inline]
            fn variant_index(&self) -> usize {
                match self {
                    NormalizedRenderTarget::Window { .. } => 0usize,
                    NormalizedRenderTarget::Image { .. } => 1usize,
                    NormalizedRenderTarget::TextureView { .. } => 2usize,
                    NormalizedRenderTarget::None { .. } => 3usize,
                    _ =>
                        ::core::panicking::panic("internal error: entered unreachable code"),
                }
            }
            #[inline]
            fn variant_type(&self) -> bevy_reflect::enums::VariantType {
                match self {
                    NormalizedRenderTarget::Window { .. } =>
                        bevy_reflect::enums::VariantType::Tuple,
                    NormalizedRenderTarget::Image { .. } =>
                        bevy_reflect::enums::VariantType::Tuple,
                    NormalizedRenderTarget::TextureView { .. } =>
                        bevy_reflect::enums::VariantType::Tuple,
                    NormalizedRenderTarget::None { .. } =>
                        bevy_reflect::enums::VariantType::Struct,
                    _ =>
                        ::core::panicking::panic("internal error: entered unreachable code"),
                }
            }
            fn to_dynamic_enum(&self) -> bevy_reflect::enums::DynamicEnum {
                bevy_reflect::enums::DynamicEnum::from_ref::<Self>(self)
            }
        }
        impl bevy_reflect::PartialReflect for NormalizedRenderTarget 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_param: &dyn bevy_reflect::PartialReflect)
                -> ::core::result::Result<(), bevy_reflect::ApplyError> {
                if let bevy_reflect::ReflectRef::Enum(__value_param) =
                        bevy_reflect::PartialReflect::reflect_ref(__value_param) {
                    if bevy_reflect::enums::Enum::variant_name(self) ==
                            bevy_reflect::enums::Enum::variant_name(__value_param) {
                        match bevy_reflect::enums::Enum::variant_type(__value_param)
                            {
                            bevy_reflect::enums::VariantType::Struct => {
                                for field in
                                    bevy_reflect::enums::Enum::iter_fields(__value_param) {
                                    let name = field.name().unwrap();
                                    if let ::core::option::Option::Some(v) =
                                            bevy_reflect::enums::Enum::field_mut(self, name) {
                                        bevy_reflect::PartialReflect::try_apply(v, field.value())?;
                                    }
                                }
                            }
                            bevy_reflect::enums::VariantType::Tuple => {
                                for (index, field) in
                                    ::core::iter::Iterator::enumerate(bevy_reflect::enums::Enum::iter_fields(__value_param))
                                    {
                                    if let ::core::option::Option::Some(v) =
                                            bevy_reflect::enums::Enum::field_at_mut(self, index) {
                                        bevy_reflect::PartialReflect::try_apply(v, field.value())?;
                                    }
                                }
                            }
                            _ => {}
                        }
                    } else {
                        match bevy_reflect::enums::Enum::variant_name(__value_param)
                            {
                            "Window" => {
                                *self =
                                    NormalizedRenderTarget::Window {
                                        0: {
                                            let __0 = __value_param.field_at(0usize);
                                            let __0 =
                                                __0.ok_or(bevy_reflect::ApplyError::MissingEnumField {
                                                            variant_name: ::core::convert::Into::into("Window"),
                                                            field_name: ::core::convert::Into::into(".0"),
                                                        })?;
                                            <NormalizedWindowRef as
                                                            bevy_reflect::FromReflect>::from_reflect(__0).ok_or(bevy_reflect::ApplyError::MismatchedTypes {
                                                        from_type: ::core::convert::Into::into(bevy_reflect::DynamicTypePath::reflect_type_path(__0)),
                                                        to_type: ::core::convert::Into::into(<NormalizedWindowRef as
                                                                    bevy_reflect::TypePath>::type_path()),
                                                    })?
                                        },
                                    }
                            }
                            "Image" => {
                                *self =
                                    NormalizedRenderTarget::Image {
                                        0: {
                                            let __0 = __value_param.field_at(0usize);
                                            let __0 =
                                                __0.ok_or(bevy_reflect::ApplyError::MissingEnumField {
                                                            variant_name: ::core::convert::Into::into("Image"),
                                                            field_name: ::core::convert::Into::into(".0"),
                                                        })?;
                                            <ImageRenderTarget as
                                                            bevy_reflect::FromReflect>::from_reflect(__0).ok_or(bevy_reflect::ApplyError::MismatchedTypes {
                                                        from_type: ::core::convert::Into::into(bevy_reflect::DynamicTypePath::reflect_type_path(__0)),
                                                        to_type: ::core::convert::Into::into(<ImageRenderTarget as
                                                                    bevy_reflect::TypePath>::type_path()),
                                                    })?
                                        },
                                    }
                            }
                            "TextureView" => {
                                *self =
                                    NormalizedRenderTarget::TextureView {
                                        0: {
                                            let __0 = __value_param.field_at(0usize);
                                            let __0 =
                                                __0.ok_or(bevy_reflect::ApplyError::MissingEnumField {
                                                            variant_name: ::core::convert::Into::into("TextureView"),
                                                            field_name: ::core::convert::Into::into(".0"),
                                                        })?;
                                            <ManualTextureViewHandle as
                                                            bevy_reflect::FromReflect>::from_reflect(__0).ok_or(bevy_reflect::ApplyError::MismatchedTypes {
                                                        from_type: ::core::convert::Into::into(bevy_reflect::DynamicTypePath::reflect_type_path(__0)),
                                                        to_type: ::core::convert::Into::into(<ManualTextureViewHandle
                                                                    as bevy_reflect::TypePath>::type_path()),
                                                    })?
                                        },
                                    }
                            }
                            "None" => {
                                *self =
                                    NormalizedRenderTarget::None {
                                        width: {
                                            let __width = __value_param.field("width");
                                            let __width =
                                                __width.ok_or(bevy_reflect::ApplyError::MissingEnumField {
                                                            variant_name: ::core::convert::Into::into("None"),
                                                            field_name: ::core::convert::Into::into("width"),
                                                        })?;
                                            <u32 as
                                                            bevy_reflect::FromReflect>::from_reflect(__width).ok_or(bevy_reflect::ApplyError::MismatchedTypes {
                                                        from_type: ::core::convert::Into::into(bevy_reflect::DynamicTypePath::reflect_type_path(__width)),
                                                        to_type: ::core::convert::Into::into(<u32 as
                                                                    bevy_reflect::TypePath>::type_path()),
                                                    })?
                                        },
                                        height: {
                                            let __height = __value_param.field("height");
                                            let __height =
                                                __height.ok_or(bevy_reflect::ApplyError::MissingEnumField {
                                                            variant_name: ::core::convert::Into::into("None"),
                                                            field_name: ::core::convert::Into::into("height"),
                                                        })?;
                                            <u32 as
                                                            bevy_reflect::FromReflect>::from_reflect(__height).ok_or(bevy_reflect::ApplyError::MismatchedTypes {
                                                        from_type: ::core::convert::Into::into(bevy_reflect::DynamicTypePath::reflect_type_path(__height)),
                                                        to_type: ::core::convert::Into::into(<u32 as
                                                                    bevy_reflect::TypePath>::type_path()),
                                                    })?
                                        },
                                    }
                            }
                            name => {
                                return ::core::result::Result::Err(bevy_reflect::ApplyError::UnknownVariant {
                                            enum_name: ::core::convert::Into::into(bevy_reflect::DynamicTypePath::reflect_type_path(self)),
                                            variant_name: ::core::convert::Into::into(name),
                                        });
                            }
                        }
                    }
                } else {
                    return ::core::result::Result::Err(bevy_reflect::ApplyError::MismatchedKinds {
                                from_kind: bevy_reflect::PartialReflect::reflect_kind(__value_param),
                                to_kind: bevy_reflect::ReflectKind::Enum,
                            });
                }
                ::core::result::Result::Ok(())
            }
            fn reflect_kind(&self) -> bevy_reflect::ReflectKind {
                bevy_reflect::ReflectKind::Enum
            }
            fn reflect_ref(&self) -> bevy_reflect::ReflectRef {
                bevy_reflect::ReflectRef::Enum(self)
            }
            fn reflect_mut(&mut self) -> bevy_reflect::ReflectMut {
                bevy_reflect::ReflectMut::Enum(self)
            }
            fn reflect_owned(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                -> bevy_reflect::ReflectOwned {
                bevy_reflect::ReflectOwned::Enum(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_hash(&self) -> ::core::option::Option<u64> {
                use ::core::hash::{Hash, Hasher};
                let mut hasher = bevy_reflect::utility::reflect_hasher();
                Hash::hash(&::core::any::Any::type_id(self), &mut hasher);
                Hash::hash(self, &mut hasher);
                ::core::option::Option::Some(Hasher::finish(&hasher))
            }
            fn reflect_partial_eq(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<bool> {
                let value =
                    <dyn bevy_reflect::PartialReflect>::try_downcast_ref::<Self>(value);
                if let ::core::option::Option::Some(value) = value {
                    ::core::option::Option::Some(::core::cmp::PartialEq::eq(self,
                            value))
                } else { ::core::option::Option::Some(false) }
            }
            fn reflect_partial_cmp(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<::core::cmp::Ordering> {
                (bevy_reflect::enums::enum_partial_cmp)(self, value)
            }
            #[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 NormalizedRenderTarget where  {
            fn from_reflect(__param0: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<Self> {
                if let bevy_reflect::ReflectRef::Enum(__param0) =
                        bevy_reflect::PartialReflect::reflect_ref(__param0) {
                    match bevy_reflect::enums::Enum::variant_name(__param0) {
                        "Window" =>
                            ::core::option::Option::Some(NormalizedRenderTarget::Window {
                                    0: {
                                        let __0 = __param0.field_at(0usize);
                                        let __0 = __0?;
                                        <NormalizedWindowRef as
                                                    bevy_reflect::FromReflect>::from_reflect(__0)?
                                    },
                                }),
                        "Image" =>
                            ::core::option::Option::Some(NormalizedRenderTarget::Image {
                                    0: {
                                        let __0 = __param0.field_at(0usize);
                                        let __0 = __0?;
                                        <ImageRenderTarget as
                                                    bevy_reflect::FromReflect>::from_reflect(__0)?
                                    },
                                }),
                        "TextureView" =>
                            ::core::option::Option::Some(NormalizedRenderTarget::TextureView {
                                    0: {
                                        let __0 = __param0.field_at(0usize);
                                        let __0 = __0?;
                                        <ManualTextureViewHandle as
                                                    bevy_reflect::FromReflect>::from_reflect(__0)?
                                    },
                                }),
                        "None" =>
                            ::core::option::Option::Some(NormalizedRenderTarget::None {
                                    width: {
                                        let __width = __param0.field("width");
                                        let __width = __width?;
                                        <u32 as bevy_reflect::FromReflect>::from_reflect(__width)?
                                    },
                                    height: {
                                        let __height = __param0.field("height");
                                        let __height = __height?;
                                        <u32 as bevy_reflect::FromReflect>::from_reflect(__height)?
                                    },
                                }),
                        name => ::core::option::Option::None,
                    }
                } else { ::core::option::Option::None }
            }
        }
    };Reflect, #[automatically_derived]
impl ::core::cmp::PartialEq for NormalizedRenderTarget {
    #[inline]
    fn eq(&self, other: &NormalizedRenderTarget) -> bool {
        let __self_discr = ::core::intrinsics::discriminant_value(self);
        let __arg1_discr = ::core::intrinsics::discriminant_value(other);
        __self_discr == __arg1_discr &&
            match (self, other) {
                (NormalizedRenderTarget::Window(__self_0),
                    NormalizedRenderTarget::Window(__arg1_0)) =>
                    __self_0 == __arg1_0,
                (NormalizedRenderTarget::Image(__self_0),
                    NormalizedRenderTarget::Image(__arg1_0)) =>
                    __self_0 == __arg1_0,
                (NormalizedRenderTarget::TextureView(__self_0),
                    NormalizedRenderTarget::TextureView(__arg1_0)) =>
                    __self_0 == __arg1_0,
                (NormalizedRenderTarget::None {
                    width: __self_0, height: __self_1 },
                    NormalizedRenderTarget::None {
                    width: __arg1_0, height: __arg1_1 }) =>
                    __self_0 == __arg1_0 && __self_1 == __arg1_1,
                _ => unsafe { ::core::intrinsics::unreachable() }
            }
    }
}PartialEq, #[automatically_derived]
impl ::core::cmp::Eq for NormalizedRenderTarget {
    #[inline]
    #[doc(hidden)]
    #[coverage(off)]
    fn assert_fields_are_eq(&self) {
        let _: ::core::cmp::AssertParamIsEq<NormalizedWindowRef>;
        let _: ::core::cmp::AssertParamIsEq<ImageRenderTarget>;
        let _: ::core::cmp::AssertParamIsEq<ManualTextureViewHandle>;
        let _: ::core::cmp::AssertParamIsEq<u32>;
    }
}Eq, #[automatically_derived]
impl ::core::hash::Hash for NormalizedRenderTarget {
    #[inline]
    fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) {
        let __self_discr = ::core::intrinsics::discriminant_value(self);
        ::core::hash::Hash::hash(&__self_discr, state);
        match self {
            NormalizedRenderTarget::Window(__self_0) =>
                ::core::hash::Hash::hash(__self_0, state),
            NormalizedRenderTarget::Image(__self_0) =>
                ::core::hash::Hash::hash(__self_0, state),
            NormalizedRenderTarget::TextureView(__self_0) =>
                ::core::hash::Hash::hash(__self_0, state),
            NormalizedRenderTarget::None { width: __self_0, height: __self_1 }
                => {
                ::core::hash::Hash::hash(__self_0, state);
                ::core::hash::Hash::hash(__self_1, state)
            }
        }
    }
}Hash, #[automatically_derived]
impl ::core::cmp::PartialOrd for NormalizedRenderTarget {
    #[inline]
    fn partial_cmp(&self, other: &NormalizedRenderTarget)
        -> ::core::option::Option<::core::cmp::Ordering> {
        ::core::option::Option::Some(::core::cmp::Ord::cmp(self, other))
    }
}PartialOrd, #[automatically_derived]
impl ::core::cmp::Ord for NormalizedRenderTarget {
    #[inline]
    fn cmp(&self, other: &NormalizedRenderTarget) -> ::core::cmp::Ordering {
        let __self_discr = ::core::intrinsics::discriminant_value(self);
        let __arg1_discr = ::core::intrinsics::discriminant_value(other);
        match ::core::cmp::Ord::cmp(&__self_discr, &__arg1_discr) {
            ::core::cmp::Ordering::Equal =>
                match (self, other) {
                    (NormalizedRenderTarget::Window(__self_0),
                        NormalizedRenderTarget::Window(__arg1_0)) =>
                        ::core::cmp::Ord::cmp(__self_0, __arg1_0),
                    (NormalizedRenderTarget::Image(__self_0),
                        NormalizedRenderTarget::Image(__arg1_0)) =>
                        ::core::cmp::Ord::cmp(__self_0, __arg1_0),
                    (NormalizedRenderTarget::TextureView(__self_0),
                        NormalizedRenderTarget::TextureView(__arg1_0)) =>
                        ::core::cmp::Ord::cmp(__self_0, __arg1_0),
                    (NormalizedRenderTarget::None {
                        width: __self_0, height: __self_1 },
                        NormalizedRenderTarget::None {
                        width: __arg1_0, height: __arg1_1 }) =>
                        match ::core::cmp::Ord::cmp(__self_0, __arg1_0) {
                            ::core::cmp::Ordering::Equal =>
                                ::core::cmp::Ord::cmp(__self_1, __arg1_1),
                            cmp => cmp,
                        },
                    _ => unsafe { ::core::intrinsics::unreachable() }
                },
            cmp => cmp,
        }
    }
}Ord, #[allow(deprecated)]
#[allow(unreachable_code)]
#[automatically_derived]
impl derive_more::core::convert::From<(u32, u32)> for NormalizedRenderTarget {
    #[inline]
    fn from(value: (u32, u32)) -> Self {
        NormalizedRenderTarget::None { width: value.0, height: value.1 }
    }
}From)]
941#[reflect(Clone, PartialEq, Hash)]
942pub enum NormalizedRenderTarget {
943    /// Window to which the camera's view is rendered.
944    Window(NormalizedWindowRef),
945    /// Image to which the camera's view is rendered.
946    Image(ImageRenderTarget),
947    /// Texture View to which the camera's view is rendered.
948    /// Useful when the texture view needs to be created outside of Bevy, for example OpenXR.
949    TextureView(ManualTextureViewHandle),
950    /// The camera won't render to any color target.
951    ///
952    /// This is useful when you want a camera that *only* renders prepasses, for
953    /// example a depth prepass. See the `render_depth_to_texture` example.
954    None {
955        /// The physical width of the viewport.
956        width: u32,
957        /// The physical height of the viewport.
958        height: u32,
959    },
960}
961
962/// A unique id that corresponds to a specific `ManualTextureView` in the `ManualTextureViews` collection.
963///
964/// See `ManualTextureViews` in `bevy_camera` for more details.
965#[derive(
966    #[automatically_derived]
impl ::core::default::Default for ManualTextureViewHandle {
    #[inline]
    fn default() -> ManualTextureViewHandle {
        ManualTextureViewHandle(::core::default::Default::default())
    }
}Default,
967    #[automatically_derived]
impl ::core::fmt::Debug for ManualTextureViewHandle {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        ::core::fmt::Formatter::debug_tuple_field1_finish(f,
            "ManualTextureViewHandle", &&self.0)
    }
}Debug,
968    #[automatically_derived]
impl ::core::clone::Clone for ManualTextureViewHandle {
    #[inline]
    fn clone(&self) -> ManualTextureViewHandle {
        let _: ::core::clone::AssertParamIsClone<u32>;
        *self
    }
}Clone,
969    #[automatically_derived]
impl ::core::marker::Copy for ManualTextureViewHandle { }Copy,
970    #[automatically_derived]
impl ::core::cmp::PartialEq for ManualTextureViewHandle {
    #[inline]
    fn eq(&self, other: &ManualTextureViewHandle) -> bool {
        self.0 == other.0
    }
}PartialEq,
971    #[automatically_derived]
impl ::core::cmp::Eq for ManualTextureViewHandle {
    #[inline]
    #[doc(hidden)]
    #[coverage(off)]
    fn assert_fields_are_eq(&self) {
        let _: ::core::cmp::AssertParamIsEq<u32>;
    }
}Eq,
972    #[automatically_derived]
impl ::core::hash::Hash for ManualTextureViewHandle {
    #[inline]
    fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) {
        ::core::hash::Hash::hash(&self.0, state)
    }
}Hash,
973    #[automatically_derived]
impl ::core::cmp::PartialOrd for ManualTextureViewHandle {
    #[inline]
    fn partial_cmp(&self, other: &ManualTextureViewHandle)
        -> ::core::option::Option<::core::cmp::Ordering> {
        ::core::option::Option::Some(::core::cmp::Ord::cmp(self, other))
    }
}PartialOrd,
974    #[automatically_derived]
impl ::core::cmp::Ord for ManualTextureViewHandle {
    #[inline]
    fn cmp(&self, other: &ManualTextureViewHandle) -> ::core::cmp::Ordering {
        ::core::cmp::Ord::cmp(&self.0, &other.0)
    }
}Ord,
975    impl bevy_ecs::component::Component for ManualTextureViewHandle 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,
976    const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for ManualTextureViewHandle
            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) {
                <u32 as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
            }
        }
        impl bevy_reflect::Typed for ManualTextureViewHandle 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::TupleStruct(bevy_reflect::tuple_struct::TupleStructInfo::new::<Self>(&[bevy_reflect::UnnamedField::new::<u32>(0usize)]))
                        })
            }
        }
        #[allow(deprecated, reason =
        "derives on a deprecated type shouldn't be considered a usage")]
        impl bevy_reflect::TypePath for ManualTextureViewHandle where  {
            fn type_path() -> &'static str {
                "bevy_camera::camera::ManualTextureViewHandle"
            }
            fn short_type_path() -> &'static str { "ManualTextureViewHandle" }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("ManualTextureViewHandle")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera")
            }
        }
        impl bevy_reflect::Reflect for ManualTextureViewHandle 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(<ManualTextureViewHandle
                                        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::tuple_struct::TupleStruct for
            ManualTextureViewHandle where  {
            fn field(&self, index: usize)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match index {
                    0usize => ::core::option::Option::Some(&self.0),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_mut(&mut self, index: usize)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match index {
                    0usize => ::core::option::Option::Some(&mut self.0),
                    _ => ::core::option::Option::None,
                }
            }
            #[inline]
            fn field_len(&self) -> usize { 1usize }
            #[inline]
            fn iter_fields(&self)
                -> bevy_reflect::tuple_struct::TupleStructFieldIter {
                bevy_reflect::tuple_struct::TupleStructFieldIter::new(self)
            }
            fn to_dynamic_tuple_struct(&self)
                -> bevy_reflect::tuple_struct::DynamicTupleStruct {
                let mut dynamic:
                        bevy_reflect::tuple_struct::DynamicTupleStruct =
                    ::core::default::Default::default();
                dynamic.set_represented_type(bevy_reflect::PartialReflect::get_represented_type_info(self));
                dynamic.insert_boxed(bevy_reflect::PartialReflect::to_dynamic(&self.0));
                dynamic
            }
        }
        impl bevy_reflect::PartialReflect for ManualTextureViewHandle 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::TupleStruct(struct_value) =
                        bevy_reflect::PartialReflect::reflect_ref(value) {
                    for (i, value) in
                        ::core::iter::Iterator::enumerate(bevy_reflect::tuple_struct::TupleStruct::iter_fields(struct_value))
                        {
                        if let ::core::option::Option::Some(v) =
                                bevy_reflect::tuple_struct::TupleStruct::field_mut(self, i)
                            {
                            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::TupleStruct,
                            });
                }
                ::core::result::Result::Ok(())
            }
            #[inline]
            fn reflect_kind(&self) -> bevy_reflect::ReflectKind {
                bevy_reflect::ReflectKind::TupleStruct
            }
            #[inline]
            fn reflect_ref(&self) -> bevy_reflect::ReflectRef {
                bevy_reflect::ReflectRef::TupleStruct(self)
            }
            #[inline]
            fn reflect_mut(&mut self) -> bevy_reflect::ReflectMut {
                bevy_reflect::ReflectMut::TupleStruct(self)
            }
            #[inline]
            fn reflect_owned(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                -> bevy_reflect::ReflectOwned {
                bevy_reflect::ReflectOwned::TupleStruct(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_hash(&self) -> ::core::option::Option<u64> {
                use ::core::hash::{Hash, Hasher};
                let mut hasher = bevy_reflect::utility::reflect_hasher();
                Hash::hash(&::core::any::Any::type_id(self), &mut hasher);
                Hash::hash(self, &mut hasher);
                ::core::option::Option::Some(Hasher::finish(&hasher))
            }
            fn reflect_partial_eq(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<bool> {
                let value =
                    <dyn bevy_reflect::PartialReflect>::try_downcast_ref::<Self>(value);
                if let ::core::option::Option::Some(value) = value {
                    ::core::option::Option::Some(::core::cmp::PartialEq::eq(self,
                            value))
                } else { ::core::option::Option::Some(false) }
            }
            fn reflect_partial_cmp(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<::core::cmp::Ordering> {
                (bevy_reflect::tuple_struct::tuple_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 ManualTextureViewHandle where  {
            fn from_reflect(reflect: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<Self> {
                if let bevy_reflect::ReflectRef::TupleStruct(__ref_struct) =
                        bevy_reflect::PartialReflect::reflect_ref(reflect) {
                    let mut __this =
                        <Self as ::core::default::Default>::default();
                    if let ::core::option::Option::Some(__field) =
                            (||
                                        <u32 as
                                                bevy_reflect::FromReflect>::from_reflect(bevy_reflect::tuple_struct::TupleStruct::field(__ref_struct,
                                                    0)?))() {
                        __this.0 = __field;
                    }
                    ::core::option::Option::Some(__this)
                } else { ::core::option::Option::None }
            }
        }
    };Reflect,
977    impl ::core::default::Default for ManualTextureViewHandleTemplate {
    fn default() -> Self { Self(::core::default::Default::default()) }
}FromTemplate,
978)]
979#[reflect(Component, Default, Debug, PartialEq, Hash, Clone)]
980pub struct ManualTextureViewHandle(pub u32);
981
982/// A render target that renders to an [`Image`].
983#[derive(#[automatically_derived]
impl ::core::fmt::Debug for ImageRenderTarget {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        ::core::fmt::Formatter::debug_struct_field2_finish(f,
            "ImageRenderTarget", "handle", &self.handle, "scale_factor",
            &&self.scale_factor)
    }
}Debug, #[automatically_derived]
impl ::core::clone::Clone for ImageRenderTarget {
    #[inline]
    fn clone(&self) -> ImageRenderTarget {
        ImageRenderTarget {
            handle: ::core::clone::Clone::clone(&self.handle),
            scale_factor: ::core::clone::Clone::clone(&self.scale_factor),
        }
    }
}Clone, const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for ImageRenderTarget 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
            }
            #[inline(never)]
            fn register_type_dependencies(registry:
                    &mut bevy_reflect::TypeRegistry) {
                <Handle<Image> as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
                <f32 as
                        bevy_reflect::__macro_exports::RegisterForReflection>::__register(registry);
            }
        }
        impl bevy_reflect::Typed for ImageRenderTarget 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::<Handle<Image>>("handle"),
                                                bevy_reflect::NamedField::new::<f32>("scale_factor")]))
                        })
            }
        }
        #[allow(deprecated, reason =
        "derives on a deprecated type shouldn't be considered a usage")]
        impl bevy_reflect::TypePath for ImageRenderTarget where  {
            fn type_path() -> &'static str {
                "bevy_camera::camera::ImageRenderTarget"
            }
            fn short_type_path() -> &'static str { "ImageRenderTarget" }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("ImageRenderTarget")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera")
            }
        }
        impl bevy_reflect::Reflect for ImageRenderTarget 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(<ImageRenderTarget
                                        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 ImageRenderTarget where  {
            fn field(&self, name: &str)
                -> ::core::option::Option<&dyn bevy_reflect::PartialReflect> {
                match name {
                    "handle" => ::core::option::Option::Some(&self.handle),
                    "scale_factor" =>
                        ::core::option::Option::Some(&self.scale_factor),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_mut(&mut self, name: &str)
                ->
                    ::core::option::Option<&mut dyn bevy_reflect::PartialReflect> {
                match name {
                    "handle" => ::core::option::Option::Some(&mut self.handle),
                    "scale_factor" =>
                        ::core::option::Option::Some(&mut self.scale_factor),
                    _ => ::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.handle),
                    1usize => ::core::option::Option::Some(&self.scale_factor),
                    _ => ::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.handle),
                    1usize =>
                        ::core::option::Option::Some(&mut self.scale_factor),
                    _ => ::core::option::Option::None,
                }
            }
            fn name_at(&self, index: usize) -> ::core::option::Option<&str> {
                match index {
                    0usize => ::core::option::Option::Some("handle"),
                    1usize => ::core::option::Option::Some("scale_factor"),
                    _ => ::core::option::Option::None,
                }
            }
            fn index_of_name(&self, name: &str)
                -> ::core::option::Option<usize> {
                match name {
                    "handle" => ::core::option::Option::Some(0usize),
                    "scale_factor" => ::core::option::Option::Some(1usize),
                    _ => ::core::option::Option::None,
                }
            }
            fn field_len(&self) -> usize { 2usize }
            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("handle",
                    bevy_reflect::PartialReflect::to_dynamic(&self.handle));
                dynamic.insert_boxed("scale_factor",
                    bevy_reflect::PartialReflect::to_dynamic(&self.scale_factor));
                dynamic
            }
        }
        impl bevy_reflect::PartialReflect for ImageRenderTarget 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_hash(&self) -> ::core::option::Option<u64> {
                use ::core::hash::{Hash, Hasher};
                let mut hasher = bevy_reflect::utility::reflect_hasher();
                Hash::hash(&::core::any::Any::type_id(self), &mut hasher);
                Hash::hash(self, &mut hasher);
                ::core::option::Option::Some(Hasher::finish(&hasher))
            }
            fn reflect_partial_eq(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<bool> {
                let value =
                    <dyn bevy_reflect::PartialReflect>::try_downcast_ref::<Self>(value);
                if let ::core::option::Option::Some(value) = value {
                    ::core::option::Option::Some(::core::cmp::PartialEq::eq(self,
                            value))
                } else { ::core::option::Option::Some(false) }
            }
            fn reflect_partial_cmp(&self,
                value: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<::core::cmp::Ordering> {
                (bevy_reflect::structs::struct_partial_cmp)(self, value)
            }
            #[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 ImageRenderTarget 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 __this =
                        Self {
                            handle: <Handle<Image> as
                                        bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                            "handle")?)?,
                            scale_factor: <f32 as
                                        bevy_reflect::FromReflect>::from_reflect(bevy_reflect::structs::Struct::field(__ref_struct,
                                            "scale_factor")?)?,
                        };
                    ::core::option::Option::Some(__this)
                } else { ::core::option::Option::None }
            }
        }
    };Reflect)]
984#[reflect(Clone, PartialEq, Hash)]
985pub struct ImageRenderTarget {
986    /// The image to render to.
987    pub handle: Handle<Image>,
988    /// The scale factor of the render target image, corresponding to the scale
989    /// factor for a window target. This should almost always be 1.0.
990    pub scale_factor: f32,
991}
992
993impl Eq for ImageRenderTarget {}
994
995impl PartialEq for ImageRenderTarget {
996    fn eq(&self, other: &Self) -> bool {
997        self.handle == other.handle && FloatOrd(self.scale_factor) == FloatOrd(other.scale_factor)
998    }
999}
1000
1001impl core::hash::Hash for ImageRenderTarget {
1002    fn hash<H: core::hash::Hasher>(&self, state: &mut H) {
1003        self.handle.hash(state);
1004        FloatOrd(self.scale_factor).hash(state);
1005    }
1006}
1007
1008impl PartialOrd for ImageRenderTarget {
1009    fn partial_cmp(&self, other: &Self) -> Option<core::cmp::Ordering> {
1010        Some(self.cmp(other))
1011    }
1012}
1013
1014impl Ord for ImageRenderTarget {
1015    fn cmp(&self, other: &Self) -> core::cmp::Ordering {
1016        self.handle
1017            .cmp(&other.handle)
1018            .then_with(|| FloatOrd(self.scale_factor).cmp(&FloatOrd(other.scale_factor)))
1019    }
1020}
1021
1022impl From<Handle<Image>> for RenderTarget {
1023    fn from(handle: Handle<Image>) -> Self {
1024        Self::Image(handle.into())
1025    }
1026}
1027
1028impl From<Handle<Image>> for ImageRenderTarget {
1029    fn from(handle: Handle<Image>) -> Self {
1030        Self {
1031            handle,
1032            scale_factor: 1.0,
1033        }
1034    }
1035}
1036
1037impl Default for RenderTarget {
1038    fn default() -> Self {
1039        Self::Window(Default::default())
1040    }
1041}
1042
1043/// This component lets you control the [`TextureUsages`] field of the main texture generated for the camera
1044#[derive(impl bevy_ecs::component::Component for CameraMainTextureUsages 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::clone::Clone for CameraMainTextureUsages {
    #[inline]
    fn clone(&self) -> CameraMainTextureUsages {
        let _: ::core::clone::AssertParamIsClone<TextureUsages>;
        *self
    }
}Clone, #[automatically_derived]
impl ::core::marker::Copy for CameraMainTextureUsages { }Copy, const _: () =
    {
        impl bevy_reflect::GetTypeRegistration for CameraMainTextureUsages
            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
            }
        }
        #[allow(deprecated, reason =
        "derives on a deprecated type shouldn't be considered a usage")]
        impl bevy_reflect::TypePath for CameraMainTextureUsages where  {
            fn type_path() -> &'static str {
                "bevy_camera::camera::CameraMainTextureUsages"
            }
            fn short_type_path() -> &'static str { "CameraMainTextureUsages" }
            fn type_ident() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("CameraMainTextureUsages")
            }
            fn crate_name() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera".split(':').next().unwrap())
            }
            fn module_path() -> ::core::option::Option<&'static str> {
                ::core::option::Option::Some("bevy_camera::camera")
            }
        }
        impl bevy_reflect::Typed for CameraMainTextureUsages where  {
            #[inline]
            fn type_info() -> &'static bevy_reflect::TypeInfo {
                static CELL: bevy_reflect::utility::NonGenericTypeInfoCell =
                    bevy_reflect::utility::NonGenericTypeInfoCell::new();
                CELL.get_or_set(||
                        {
                            let info = bevy_reflect::OpaqueInfo::new::<Self>();
                            bevy_reflect::TypeInfo::Opaque(info)
                        })
            }
        }
        impl bevy_reflect::Reflect for CameraMainTextureUsages 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(<CameraMainTextureUsages
                                        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::PartialReflect for CameraMainTextureUsages 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 to_dynamic(&self)
                ->
                    bevy_reflect::__macro_exports::alloc_utils::Box<dyn bevy_reflect::PartialReflect> {
                bevy_reflect::__macro_exports::alloc_utils::Box::new(::core::clone::Clone::clone(self))
            }
            #[inline]
            fn try_apply(&mut self, value: &dyn bevy_reflect::PartialReflect)
                -> ::core::result::Result<(), bevy_reflect::ApplyError> {
                if let ::core::option::Option::Some(value) =
                        <dyn bevy_reflect::PartialReflect>::try_downcast_ref::<Self>(value)
                    {
                    *self = ::core::clone::Clone::clone(value);
                    return ::core::result::Result::Ok(());
                }
                ::core::result::Result::Err(bevy_reflect::ApplyError::MismatchedTypes {
                        from_type: ::core::convert::Into::into(bevy_reflect::DynamicTypePath::reflect_type_path(value)),
                        to_type: ::core::convert::Into::into(<Self as
                                    bevy_reflect::TypePath>::type_path()),
                    })
            }
            #[inline]
            fn reflect_kind(&self) -> bevy_reflect::ReflectKind {
                bevy_reflect::ReflectKind::Opaque
            }
            #[inline]
            fn reflect_ref(&self) -> bevy_reflect::ReflectRef {
                bevy_reflect::ReflectRef::Opaque(self)
            }
            #[inline]
            fn reflect_mut(&mut self) -> bevy_reflect::ReflectMut {
                bevy_reflect::ReflectMut::Opaque(self)
            }
            #[inline]
            fn reflect_owned(self:
                    bevy_reflect::__macro_exports::alloc_utils::Box<Self>)
                -> bevy_reflect::ReflectOwned {
                bevy_reflect::ReflectOwned::Opaque(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
            }
            #[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 CameraMainTextureUsages where  {
            fn from_reflect(reflect: &dyn bevy_reflect::PartialReflect)
                -> ::core::option::Option<Self> {
                ::core::option::Option::Some(::core::clone::Clone::clone(<dyn bevy_reflect::PartialReflect>::try_downcast_ref::<CameraMainTextureUsages>(reflect)?))
            }
        }
    };Reflect)]
1045#[reflect(opaque)]
1046#[reflect(Component, Default, Clone)]
1047pub struct CameraMainTextureUsages(pub TextureUsages);
1048
1049impl Default for CameraMainTextureUsages {
1050    fn default() -> Self {
1051        Self(
1052            TextureUsages::RENDER_ATTACHMENT
1053                | TextureUsages::TEXTURE_BINDING
1054                | TextureUsages::COPY_SRC,
1055        )
1056    }
1057}
1058
1059impl CameraMainTextureUsages {
1060    pub fn with(mut self, usages: TextureUsages) -> Self {
1061        self.0 |= usages;
1062        self
1063    }
1064}
1065
1066#[cfg(test)]
1067mod test {
1068    use bevy_math::{Vec2, Vec3};
1069    use bevy_transform::components::GlobalTransform;
1070
1071    use crate::{
1072        Camera, OrthographicProjection, PerspectiveProjection, Projection, RenderTargetInfo,
1073        Viewport,
1074    };
1075
1076    fn make_camera(mut projection: Projection, physical_size: Vec2) -> Camera {
1077        let viewport = Viewport {
1078            physical_size: physical_size.as_uvec2(),
1079            ..Default::default()
1080        };
1081        let mut camera = Camera {
1082            viewport: Some(viewport.clone()),
1083            ..Default::default()
1084        };
1085        camera.computed.target_info = Some(RenderTargetInfo {
1086            physical_size: viewport.physical_size,
1087            scale_factor: 1.0,
1088        });
1089        projection.update(
1090            viewport.physical_size.x as f32,
1091            viewport.physical_size.y as f32,
1092        );
1093        camera.computed.clip_from_view = projection.get_clip_from_view();
1094        camera
1095    }
1096
1097    #[test]
1098    fn viewport_to_world_orthographic_3d_returns_forward() {
1099        let transform = GlobalTransform::default();
1100        let size = Vec2::new(1600.0, 900.0);
1101        let camera = make_camera(
1102            Projection::Orthographic(OrthographicProjection::default_3d()),
1103            size,
1104        );
1105        let ray = camera.viewport_to_world(&transform, Vec2::ZERO).unwrap();
1106        assert_eq!(ray.direction, transform.forward());
1107        assert!(ray
1108            .origin
1109            .abs_diff_eq(Vec3::new(-size.x * 0.5, size.y * 0.5, 0.0), 1e-4));
1110        let ray = camera.viewport_to_world(&transform, size).unwrap();
1111        assert_eq!(ray.direction, transform.forward());
1112        assert!(ray
1113            .origin
1114            .abs_diff_eq(Vec3::new(size.x * 0.5, -size.y * 0.5, 0.0), 1e-4));
1115    }
1116
1117    #[test]
1118    fn viewport_to_world_orthographic_2d_returns_forward() {
1119        let transform = GlobalTransform::default();
1120        let size = Vec2::new(1600.0, 900.0);
1121        let camera = make_camera(
1122            Projection::Orthographic(OrthographicProjection::default_2d()),
1123            size,
1124        );
1125        let ray = camera.viewport_to_world(&transform, Vec2::ZERO).unwrap();
1126        assert_eq!(ray.direction, transform.forward());
1127        assert!(ray
1128            .origin
1129            .abs_diff_eq(Vec3::new(-size.x * 0.5, size.y * 0.5, 1000.0), 1e-4));
1130        let ray = camera.viewport_to_world(&transform, size).unwrap();
1131        assert_eq!(ray.direction, transform.forward());
1132        assert!(ray
1133            .origin
1134            .abs_diff_eq(Vec3::new(size.x * 0.5, -size.y * 0.5, 1000.0), 1e-4));
1135    }
1136
1137    #[test]
1138    fn viewport_to_world_perspective_center_returns_forward() {
1139        let transform = GlobalTransform::default();
1140        let size = Vec2::new(1600.0, 900.0);
1141        let camera = make_camera(
1142            Projection::Perspective(PerspectiveProjection::default()),
1143            size,
1144        );
1145        let ray = camera.viewport_to_world(&transform, size * 0.5).unwrap();
1146        assert_eq!(ray.direction, transform.forward());
1147        assert_eq!(ray.origin, transform.forward() * 0.1);
1148    }
1149}