Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Retain Rendering World #14449

Closed
wants to merge 66 commits into from
Closed
Show file tree
Hide file tree
Changes from 33 commits
Commits
Show all changes
66 commits
Select commit Hold shift + click to select a range
95b7f0b
init
re0312 Jul 6, 2024
17f2bb0
sync
re0312 Jul 7, 2024
35fe01e
cleanup
re0312 Jul 22, 2024
f9bae87
clean
re0312 Jul 22, 2024
34853b2
fix
re0312 Jul 22, 2024
000cef4
Fly
re0312 Jul 22, 2024
2255b21
Merge branch 'main' into retain_world
re0312 Jul 22, 2024
f90c360
fly entity
re0312 Jul 22, 2024
756b082
sync world
re0312 Jul 22, 2024
5b5ef76
ui
re0312 Jul 22, 2024
e15e3a3
lighting
re0312 Jul 22, 2024
e4e0bc0
fix example
re0312 Jul 22, 2024
33cae8d
ui
re0312 Jul 22, 2024
4a58b0e
fix ui
re0312 Jul 22, 2024
3fc2207
fix gizmos
re0312 Jul 22, 2024
f9c8d5a
fix light
re0312 Jul 22, 2024
44d36a4
cleanup
re0312 Jul 22, 2024
9a7d641
Merge branch 'main' into retain_world
re0312 Jul 22, 2024
7989d21
fix cli
re0312 Jul 22, 2024
9485455
fix ui
re0312 Jul 23, 2024
bb3289b
clean
re0312 Jul 23, 2024
39e4f2e
fix cli
re0312 Jul 23, 2024
4b6506e
fix ui_material
re0312 Jul 23, 2024
03a6e09
fix sprite
re0312 Jul 23, 2024
b8b8225
whilelist
re0312 Jul 23, 2024
24212f5
Revert "whilelist"
re0312 Jul 23, 2024
2de636a
address review
re0312 Jul 24, 2024
1fbb76c
Update crates/bevy_render/src/world_sync.rs
re0312 Jul 24, 2024
c25d560
Update crates/bevy_render/src/world_sync.rs
re0312 Jul 24, 2024
457e83f
Update crates/bevy_render/src/world_sync.rs
re0312 Jul 24, 2024
16c1093
Merge branch 'main' into retain_world
re0312 Jul 25, 2024
cba1183
address review
re0312 Jul 25, 2024
2821849
fmt
re0312 Jul 25, 2024
a86dd39
address review
re0312 Jul 25, 2024
8422a48
comment
re0312 Jul 25, 2024
dc5f10f
remove mapping
re0312 Jul 26, 2024
2a6df8d
retain sprite
re0312 Jul 27, 2024
ce2ea36
cache state
re0312 Aug 1, 2024
c1a4fb9
fix cli
re0312 Aug 1, 2024
672778d
fix
re0312 Aug 1, 2024
0eed037
fix point light
re0312 Aug 1, 2024
5a83da4
fix regression
re0312 Aug 9, 2024
ed296f1
fix cli
re0312 Aug 9, 2024
bb8774d
Merge branch 'main' into retain_world
re0312 Aug 9, 2024
94be0cd
fix conflict
re0312 Aug 9, 2024
560ce59
Merge branch 'main' into retain_world
re0312 Aug 9, 2024
ab22138
Merge branch 'main' into retain_world
re0312 Aug 11, 2024
fd36379
Apply suggestions from code review
re0312 Aug 12, 2024
4bdfd60
Merge branch 'main' into retain_world
re0312 Aug 12, 2024
6214e6d
Merge branch 'retain_world' of https://github.com/re0312/bevy into re…
re0312 Aug 12, 2024
67e7a07
fix cli
re0312 Aug 12, 2024
1507437
Merge branch 'main' into retain_world
re0312 Aug 25, 2024
e5254be
fix
re0312 Aug 25, 2024
d9ecccd
Merge branch 'main' into retain_world
re0312 Aug 27, 2024
faf5ef2
fix
re0312 Aug 27, 2024
f127719
to render world
re0312 Aug 27, 2024
c7ba466
SyncRenderWorld
re0312 Aug 27, 2024
23a8bba
extract_component
re0312 Aug 27, 2024
37944a8
document and test
re0312 Aug 28, 2024
1e8601f
fix
re0312 Aug 28, 2024
7167cc0
typo
re0312 Aug 28, 2024
bfad1de
cleanup
re0312 Aug 28, 2024
8d2c81a
rename
re0312 Aug 28, 2024
d857e6e
Apply suggestions from code review
re0312 Aug 31, 2024
9c1a523
Cleared up some documentation
Trashtalk217 Sep 3, 2024
753d286
Merge pull request #1 from Trashtalk217/retain_world
re0312 Sep 8, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 3 additions & 2 deletions crates/bevy_core_pipeline/src/auto_exposure/buffers.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ use bevy_ecs::prelude::*;
use bevy_render::{
render_resource::{StorageBuffer, UniformBuffer},
renderer::{RenderDevice, RenderQueue},
world_sync::RenderEntity,
Extract,
};
use bevy_utils::{Entry, HashMap};
Expand All @@ -27,13 +28,13 @@ pub(super) struct ExtractedStateBuffers {

pub(super) fn extract_buffers(
mut commands: Commands,
changed: Extract<Query<(Entity, &AutoExposureSettings), Changed<AutoExposureSettings>>>,
changed: Extract<Query<(&RenderEntity, &AutoExposureSettings), Changed<AutoExposureSettings>>>,
mut removed: Extract<RemovedComponents<AutoExposureSettings>>,
) {
commands.insert_resource(ExtractedStateBuffers {
changed: changed
.iter()
.map(|(entity, settings)| (entity, settings.clone()))
.map(|(entity, settings)| (entity.entity(), settings.clone()))
.collect(),
removed: removed.read().collect(),
});
Expand Down
8 changes: 3 additions & 5 deletions crates/bevy_core_pipeline/src/core_2d/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ use bevy_render::{
PhaseItemExtraIndex, SortedPhaseItem, ViewSortedRenderPhases,
},
render_resource::CachedRenderPipelineId,
world_sync::RenderEntity,
Extract, ExtractSchedule, Render, RenderApp, RenderSet,
};

Expand Down Expand Up @@ -160,9 +161,8 @@ impl CachedRenderPipelinePhaseItem for Transparent2d {
}

pub fn extract_core_2d_camera_phases(
mut commands: Commands,
mut transparent_2d_phases: ResMut<ViewSortedRenderPhases<Transparent2d>>,
cameras_2d: Extract<Query<(Entity, &Camera), With<Camera2d>>>,
cameras_2d: Extract<Query<(&RenderEntity, &Camera), With<Camera2d>>>,
mut live_entities: Local<EntityHashSet>,
) {
live_entities.clear();
Expand All @@ -171,10 +171,8 @@ pub fn extract_core_2d_camera_phases(
if !camera.is_active {
continue;
}

commands.get_or_spawn(entity);
let entity = entity.entity();
transparent_2d_phases.insert_or_clear(entity);

live_entities.insert(entity);
}

Expand Down
23 changes: 14 additions & 9 deletions crates/bevy_core_pipeline/src/core_3d/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -91,6 +91,7 @@ use bevy_render::{
renderer::RenderDevice,
texture::{BevyDefault, ColorAttachment, Image, TextureCache},
view::{ExtractedView, ViewDepthTexture, ViewTarget},
world_sync::RenderEntity,
Extract, ExtractSchedule, Render, RenderApp, RenderSet,
};
use bevy_utils::{tracing::warn, HashMap};
Expand Down Expand Up @@ -504,23 +505,21 @@ impl CachedRenderPipelinePhaseItem for Transparent3d {
}

pub fn extract_core_3d_camera_phases(
mut commands: Commands,
mut opaque_3d_phases: ResMut<ViewBinnedRenderPhases<Opaque3d>>,
mut alpha_mask_3d_phases: ResMut<ViewBinnedRenderPhases<AlphaMask3d>>,
mut transmissive_3d_phases: ResMut<ViewSortedRenderPhases<Transmissive3d>>,
mut transparent_3d_phases: ResMut<ViewSortedRenderPhases<Transparent3d>>,
cameras_3d: Extract<Query<(Entity, &Camera), With<Camera3d>>>,
cameras_3d: Extract<Query<(&RenderEntity, &Camera), With<Camera3d>>>,
mut live_entities: Local<EntityHashSet>,
) {
live_entities.clear();

for (entity, camera) in &cameras_3d {
for (render_entity, camera) in &cameras_3d {
if !camera.is_active {
continue;
}

commands.get_or_spawn(entity);

let entity = render_entity.entity();
opaque_3d_phases.insert_or_clear(entity);
alpha_mask_3d_phases.insert_or_clear(entity);
transmissive_3d_phases.insert_or_clear(entity);
Expand All @@ -545,7 +544,7 @@ pub fn extract_camera_prepass_phase(
cameras_3d: Extract<
Query<
(
Entity,
&RenderEntity,
&Camera,
Has<DepthPrepass>,
Has<NormalPrepass>,
Expand All @@ -559,13 +558,20 @@ pub fn extract_camera_prepass_phase(
) {
live_entities.clear();

for (entity, camera, depth_prepass, normal_prepass, motion_vector_prepass, deferred_prepass) in
cameras_3d.iter()
for (
render_entity,
camera,
depth_prepass,
normal_prepass,
motion_vector_prepass,
deferred_prepass,
) in cameras_3d.iter()
{
if !camera.is_active {
continue;
}

let entity = render_entity.entity();
if depth_prepass || normal_prepass || motion_vector_prepass {
opaque_3d_prepass_phases.insert_or_clear(entity);
alpha_mask_3d_prepass_phases.insert_or_clear(entity);
Expand All @@ -581,7 +587,6 @@ pub fn extract_camera_prepass_phase(
opaque_3d_deferred_phases.remove(&entity);
alpha_mask_3d_deferred_phases.remove(&entity);
}

live_entities.insert(entity);

let mut entity = commands.get_or_spawn(entity);
Expand Down
4 changes: 3 additions & 1 deletion crates/bevy_core_pipeline/src/dof/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@ use bevy_render::{
prepare_view_targets, ExtractedView, Msaa, ViewDepthTexture, ViewTarget, ViewUniform,
ViewUniformOffset, ViewUniforms,
},
world_sync::RenderEntity,
Extract, ExtractSchedule, Render, RenderApp, RenderSet,
};
use bevy_utils::{info_once, prelude::default, warn_once};
Expand Down Expand Up @@ -792,7 +793,7 @@ impl SpecializedRenderPipeline for DepthOfFieldPipeline {
/// Extracts all [`DepthOfFieldSettings`] components into the render world.
fn extract_depth_of_field_settings(
mut commands: Commands,
mut query: Extract<Query<(Entity, &DepthOfFieldSettings, &Projection)>>,
mut query: Extract<Query<(&RenderEntity, &DepthOfFieldSettings, &Projection)>>,
) {
if !DEPTH_TEXTURE_SAMPLING_SUPPORTED {
info_once!(
Expand All @@ -802,6 +803,7 @@ fn extract_depth_of_field_settings(
}

for (entity, dof_settings, projection) in query.iter_mut() {
let entity = entity.entity();
// Depth of field is nonsensical without a perspective projection.
let Projection::Perspective(ref perspective_projection) = *projection else {
continue;
Expand Down
20 changes: 13 additions & 7 deletions crates/bevy_core_pipeline/src/taa/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ use bevy_render::{
renderer::{RenderContext, RenderDevice},
texture::{BevyDefault, CachedTexture, TextureCache},
view::{ExtractedView, Msaa, ViewTarget},
world_sync::RenderEntity,
ExtractSchedule, MainWorld, Render, RenderApp, RenderSet,
};
use bevy_utils::tracing::warn;
Expand Down Expand Up @@ -346,17 +347,22 @@ impl SpecializedRenderPipeline for TaaPipeline {
}

fn extract_taa_settings(mut commands: Commands, mut main_world: ResMut<MainWorld>) {
let mut cameras_3d = main_world
.query_filtered::<(Entity, &Camera, &Projection, &mut TemporalAntiAliasSettings), (
With<Camera3d>,
With<TemporalJitter>,
With<DepthPrepass>,
With<MotionVectorPrepass>,
)>();
let mut cameras_3d = main_world.query_filtered::<(
&RenderEntity,
&Camera,
&Projection,
&mut TemporalAntiAliasSettings,
), (
With<Camera3d>,
With<TemporalJitter>,
With<DepthPrepass>,
With<MotionVectorPrepass>,
)>();

for (entity, camera, camera_projection, mut taa_settings) in
cameras_3d.iter_mut(&mut main_world)
{
let entity = entity.entity();
let has_perspective_projection = matches!(camera_projection, Projection::Perspective(_));
if camera.is_active && has_perspective_projection {
commands.get_or_spawn(entity).insert(taa_settings.clone());
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Lets see if I understand this correctly: this could be just get_mut() here instead of get_or_spawn(), as the entity should already exist as camera bundles have SyncRenderWorld, correct?

(That said I do think we should leave it as get_or_spawn() in case users aren't using the bundle, this comment is just to see if I understand this PR correctly or not)

Expand Down
2 changes: 2 additions & 0 deletions crates/bevy_gizmos/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -93,6 +93,7 @@ use bevy_render::{
ShaderType, VertexAttribute, VertexBufferLayout, VertexFormat, VertexStepMode,
},
renderer::RenderDevice,
world_sync::RenderFlyEntity,
Extract, ExtractSchedule, Render, RenderApp, RenderSet,
};
use bevy_time::Fixed;
Expand Down Expand Up @@ -432,6 +433,7 @@ fn extract_gizmo_data(
},
(*handle).clone_weak(),
GizmoMeshConfig::from(config),
RenderFlyEntity,
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We discussed this before and it still might be the best option for now, but it feels not great to require users to remember this while extracting.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This should definitely be renamed before merging. My suggestion would be Transient. But open to 🚲 🏠

));
}
}
Expand Down
13 changes: 9 additions & 4 deletions crates/bevy_pbr/src/cluster/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ use bevy_render::{
UniformBuffer,
},
renderer::{RenderDevice, RenderQueue},
world_sync::{MainToRenderEntityMap, RenderEntity},
Extract,
};
use bevy_utils::{hashbrown::HashSet, tracing::warn};
Expand Down Expand Up @@ -511,7 +512,8 @@ pub(crate) fn clusterable_object_order(
/// Extracts clusters from the main world from the render world.
pub fn extract_clusters(
mut commands: Commands,
views: Extract<Query<(Entity, &Clusters, &Camera)>>,
views: Extract<Query<(&RenderEntity, &Clusters, &Camera)>>,
mapper: Res<MainToRenderEntityMap>,
re0312 marked this conversation as resolved.
Show resolved Hide resolved
) {
for (entity, clusters, camera) in &views {
if !camera.is_active {
Expand All @@ -530,12 +532,15 @@ pub fn extract_clusters(
cluster_objects.spot_light_count as u32,
));
for clusterable_entity in &cluster_objects.entities {
data.push(ExtractedClusterableObjectElement::ClusterableObjectEntity(
*clusterable_entity,
));
if let Some(entity) = mapper.get(clusterable_entity) {
data.push(ExtractedClusterableObjectElement::ClusterableObjectEntity(
*entity,
));
}
}
}

let entity = entity.entity();
commands.get_or_spawn(entity).insert((
ExtractedClusterableObjects { data },
ExtractedClusterConfig {
Expand Down
16 changes: 11 additions & 5 deletions crates/bevy_pbr/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -118,6 +118,7 @@ use bevy_render::{
render_resource::Shader,
texture::{GpuImage, Image},
view::{check_visibility, VisibilitySystems},
world_sync::WorldSyncPlugin,
ExtractSchedule, Render, RenderApp, RenderSet,
};
use bevy_transform::TransformSystem;
Expand Down Expand Up @@ -319,18 +320,23 @@ impl Plugin for PbrPlugin {
ScreenSpaceAmbientOcclusionPlugin,
ExtractResourcePlugin::<AmbientLight>::default(),
FogPlugin,
ExtractResourcePlugin::<DefaultOpaqueRendererMethod>::default(),
ExtractComponentPlugin::<ShadowFilteringMethod>::default(),
(
re0312 marked this conversation as resolved.
Show resolved Hide resolved
ExtractResourcePlugin::<DefaultOpaqueRendererMethod>::default(),
ExtractComponentPlugin::<ShadowFilteringMethod>::default(),
),
LightmapPlugin,
LightProbePlugin,
PbrProjectionPlugin::<Projection>::default(),
PbrProjectionPlugin::<PerspectiveProjection>::default(),
PbrProjectionPlugin::<OrthographicProjection>::default(),
(
PbrProjectionPlugin::<Projection>::default(),
PbrProjectionPlugin::<PerspectiveProjection>::default(),
PbrProjectionPlugin::<OrthographicProjection>::default(),
),
GpuMeshPreprocessPlugin {
use_gpu_instance_buffer_builder: self.use_gpu_instance_buffer_builder,
},
VolumetricFogPlugin,
ScreenSpaceReflectionsPlugin,
WorldSyncPlugin::<(PointLight, SpotLight, DirectionalLight)>::default(),
))
.configure_sets(
PostUpdate,
Expand Down
14 changes: 9 additions & 5 deletions crates/bevy_pbr/src/light_probe/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ use bevy_render::{
settings::WgpuFeatures,
texture::{FallbackImage, GpuImage, Image},
view::ExtractedView,
world_sync::RenderEntity,
Extract, ExtractSchedule, Render, RenderApp, RenderSet,
};
use bevy_transform::{components::Transform, prelude::GlobalTransform};
Expand Down Expand Up @@ -371,7 +372,7 @@ impl Plugin for LightProbePlugin {
/// Compared to the `ExtractComponentPlugin`, this implementation will create a default instance
/// if one does not already exist.
fn gather_environment_map_uniform(
view_query: Extract<Query<(Entity, Option<&EnvironmentMapLight>), With<Camera3d>>>,
view_query: Extract<Query<(&RenderEntity, Option<&EnvironmentMapLight>), With<Camera3d>>>,
mut commands: Commands,
) {
for (view_entity, environment_map_light) in view_query.iter() {
Expand All @@ -385,7 +386,7 @@ fn gather_environment_map_uniform(
EnvironmentMapUniform::default()
};
commands
.get_or_spawn(view_entity)
.get_or_spawn(view_entity.entity())
.insert(environment_map_uniform);
}
}
Expand All @@ -395,7 +396,9 @@ fn gather_environment_map_uniform(
fn gather_light_probes<C>(
image_assets: Res<RenderAssets<GpuImage>>,
light_probe_query: Extract<Query<(&GlobalTransform, &C), With<LightProbe>>>,
view_query: Extract<Query<(Entity, &GlobalTransform, &Frustum, Option<&C>), With<Camera3d>>>,
view_query: Extract<
Query<(&RenderEntity, &GlobalTransform, &Frustum, Option<&C>), With<Camera3d>>,
>,
mut reflection_probes: Local<Vec<LightProbeInfo<C>>>,
mut view_reflection_probes: Local<Vec<LightProbeInfo<C>>>,
mut commands: Commands,
Expand Down Expand Up @@ -433,14 +436,15 @@ fn gather_light_probes<C>(
// Gather up the light probes in the list.
render_view_light_probes.maybe_gather_light_probes(&view_reflection_probes);

let entity = view_entity.entity();
re0312 marked this conversation as resolved.
Show resolved Hide resolved
// Record the per-view light probes.
if render_view_light_probes.is_empty() {
commands
.get_or_spawn(view_entity)
.get_or_spawn(entity)
.remove::<RenderViewLightProbes<C>>();
} else {
commands
.get_or_spawn(view_entity)
.get_or_spawn(entity)
.insert(render_view_light_probes);
}
}
Expand Down
4 changes: 3 additions & 1 deletion crates/bevy_pbr/src/prepass/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ mod prepass_bindings;
use bevy_render::mesh::{MeshVertexBufferLayoutRef, RenderMesh};
use bevy_render::render_resource::binding_types::uniform_buffer;
use bevy_render::view::WithMesh;
use bevy_render::world_sync::RenderEntity;
pub use prepass_bindings::*;

use bevy_asset::{load_internal_asset, AssetServer};
Expand Down Expand Up @@ -577,10 +578,11 @@ where
// Extract the render phases for the prepass
pub fn extract_camera_previous_view_data(
mut commands: Commands,
cameras_3d: Extract<Query<(Entity, &Camera, Option<&PreviousViewData>), With<Camera3d>>>,
cameras_3d: Extract<Query<(&RenderEntity, &Camera, Option<&PreviousViewData>), With<Camera3d>>>,
) {
for (entity, camera, maybe_previous_view_data) in cameras_3d.iter() {
if camera.is_active {
let entity = entity.entity();
let mut entity = commands.get_or_spawn(entity);

if let Some(previous_view_data) = maybe_previous_view_data {
Expand Down
Loading