diff --git a/src/components.rs b/src/components.rs index 5beee1f..4351d73 100644 --- a/src/components.rs +++ b/src/components.rs @@ -3,10 +3,14 @@ use bevy::{ render::{ extract_component::ExtractComponent, render_asset::RenderAssetUsages, - render_resource::{CachedRenderPipelineId, Extent3d, TextureDimension, TextureFormat, TextureUsages}, + render_resource::{ + CachedRenderPipelineId, Extent3d, TextureDimension, TextureFormat, TextureUsages, + }, }, }; +/// Component for cameras which stores the specialized render pipeline id. Automatically inserted +/// when the pipeline is created. #[derive(Component, Deref, DerefMut)] pub struct DitherPostProcessPipelineId(pub CachedRenderPipelineId); @@ -65,7 +69,7 @@ impl DitherPostProcessSettings { Self(handle) } /// Gets the handle of the texture representing this component's Bayer matrix - pub fn handle(&self) -> Handle { + pub fn handle(&self) -> Handle { self.0.clone() } } diff --git a/src/lib.rs b/src/lib.rs index b614596..eb33dee 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -10,9 +10,7 @@ use bevy::{ render::{ extract_component::ExtractComponentPlugin, render_graph::{RenderGraphApp, ViewNodeRunner}, - render_resource::{ - PipelineCache, SpecializedRenderPipeline, SpecializedRenderPipelines, TextureFormat, - }, + render_resource::{PipelineCache, SpecializedRenderPipelines, TextureFormat}, view::{ExtractedView, ViewTarget}, Render, RenderApp, RenderSet, }, @@ -44,7 +42,10 @@ impl Plugin for DitherPostProcessPlugin { }; render_app - .add_systems(Render, prepare_post_processing_pipelines.in_set(RenderSet::Prepare)) + .add_systems( + Render, + prepare_post_processing_pipelines.in_set(RenderSet::Prepare), + ) .init_resource::>() .add_render_graph_node::>( Core3d, @@ -89,6 +90,8 @@ fn prepare_post_processing_pipelines( }, ); - commands.entity(entity).insert(DitherPostProcessPipelineId(pipeline_id)); + commands + .entity(entity) + .insert(DitherPostProcessPipelineId(pipeline_id)); } } diff --git a/src/resources.rs b/src/resources.rs index 8ce8221..8e91234 100644 --- a/src/resources.rs +++ b/src/resources.rs @@ -1,10 +1,15 @@ use bevy::{ - core_pipeline::fullscreen_vertex_shader, prelude::*, render::{ + core_pipeline::fullscreen_vertex_shader, + prelude::*, + render::{ render_resource::{ - binding_types::{sampler, texture_2d}, BindGroupLayout, BindGroupLayoutEntries, ColorTargetState, ColorWrites, FragmentState, RenderPipelineDescriptor, Sampler, SamplerBindingType, SamplerDescriptor, ShaderStages, SpecializedRenderPipeline, TextureFormat, TextureSampleType + binding_types::{sampler, texture_2d}, + BindGroupLayout, BindGroupLayoutEntries, ColorTargetState, ColorWrites, FragmentState, + RenderPipelineDescriptor, Sampler, SamplerBindingType, SamplerDescriptor, ShaderStages, + SpecializedRenderPipeline, TextureFormat, TextureSampleType, }, renderer::RenderDevice, - } + }, }; #[derive(Resource)] @@ -78,4 +83,5 @@ impl SpecializedRenderPipeline for DitherPostProcessPipeline { zero_initialize_workgroup_memory: false, } } -} \ No newline at end of file +} +