Compare commits
7 Commits
5a26829f3e
...
0bfbfb9246
Author | SHA1 | Date | |
---|---|---|---|
0bfbfb9246 | |||
7d60d26607 | |||
73e8ea31c3 | |||
8da65d0246 | |||
b91b0f95ef | |||
092b56799e | |||
218d732249 |
1
.gitignore
vendored
1
.gitignore
vendored
@ -1 +1,2 @@
|
||||
/target
|
||||
Cargo.lock
|
||||
|
3187
Cargo.lock
generated
3187
Cargo.lock
generated
File diff suppressed because it is too large
Load Diff
@ -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<Image> {
|
||||
pub fn handle(&self) -> Handle<Image> {
|
||||
self.0.clone()
|
||||
}
|
||||
}
|
||||
|
13
src/lib.rs
13
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::<SpecializedRenderPipelines<DitherPostProcessPipeline>>()
|
||||
.add_render_graph_node::<ViewNodeRunner<nodes::DitherRenderNode>>(
|
||||
Core3d,
|
||||
@ -89,6 +90,8 @@ fn prepare_post_processing_pipelines(
|
||||
},
|
||||
);
|
||||
|
||||
commands.entity(entity).insert(DitherPostProcessPipelineId(pipeline_id));
|
||||
commands
|
||||
.entity(entity)
|
||||
.insert(DitherPostProcessPipelineId(pipeline_id));
|
||||
}
|
||||
}
|
||||
|
@ -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,
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user