pub struct MeshPipelineDescriptor<'a> {
pub label: Option<&'a str>,
pub layout: Option<&'a PipelineLayout>,
pub task: Option<TaskState<'a>>,
pub mesh: MeshState<'a>,
pub primitive: PrimitiveState,
pub depth_stencil: Option<DepthStencilState>,
pub multisample: MultisampleState,
pub fragment: Option<FragmentState<'a>>,
pub multiview: Option<NonZero<u32>>,
pub cache: Option<&'a PipelineCache>,
}unstable-wgpu-27 only.Expand description
Describes a mesh shader (graphics) pipeline.
For use with Device::create_mesh_pipeline.
Fields§
§label: Option<&'a str>Debug label of the pipeline. This will show up in graphics debuggers for easy identification.
layout: Option<&'a PipelineLayout>The layout of bind groups for this pipeline.
If this is set, then Device::create_render_pipeline will raise a validation error if
the layout doesn’t match what the shader module(s) expect.
Using the same PipelineLayout for many RenderPipeline or ComputePipeline
pipelines guarantees that you don’t have to rebind any resources when switching between
those pipelines.
§Default pipeline layout
If layout is None, then the pipeline has a default layout created and used instead.
The default layout is deduced from the shader modules.
You can use RenderPipeline::get_bind_group_layout to create bind groups for use with the
default layout. However, these bind groups cannot be used with any other pipelines. This is
convenient for simple pipelines, but using an explicit layout is recommended in most cases.
task: Option<TaskState<'a>>The compiled task stage, its entry point, and the color targets.
mesh: MeshState<'a>The compiled mesh stage and its entry point
primitive: PrimitiveStateThe properties of the pipeline at the primitive assembly and rasterization level.
depth_stencil: Option<DepthStencilState>The effect of draw calls on the depth and stencil aspects of the output target, if any.
multisample: MultisampleStateThe multi-sampling properties of the pipeline.
fragment: Option<FragmentState<'a>>The compiled fragment stage, its entry point, and the color targets.
multiview: Option<NonZero<u32>>If the pipeline will be used with a multiview render pass, this indicates how many array layers the attachments will have.
cache: Option<&'a PipelineCache>The pipeline cache to use when creating this pipeline.
Trait Implementations§
Source§impl<'a> Clone for MeshPipelineDescriptor<'a>
impl<'a> Clone for MeshPipelineDescriptor<'a>
Source§fn clone(&self) -> MeshPipelineDescriptor<'a>
fn clone(&self) -> MeshPipelineDescriptor<'a>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreAuto Trait Implementations§
impl<'a> Freeze for MeshPipelineDescriptor<'a>
impl<'a> !RefUnwindSafe for MeshPipelineDescriptor<'a>
impl<'a> Send for MeshPipelineDescriptor<'a>
impl<'a> Sync for MeshPipelineDescriptor<'a>
impl<'a> Unpin for MeshPipelineDescriptor<'a>
impl<'a> !UnwindSafe for MeshPipelineDescriptor<'a>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<T> Pointable for T
impl<T> Pointable for T
§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self is actually part of its subset T (and can be converted to it).§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.