Struct exr::image::read::specific_channels::ReadOptionalChannel
source · [−]pub struct ReadOptionalChannel<ReadChannels, Sample> { /* private fields */ }
Expand description
Used to read another specific channel from an image.
Contains the previous ReadChannels
objects.
Trait Implementations
sourceimpl<Inner: CheckDuplicates, Sample> CheckDuplicates for ReadOptionalChannel<Inner, Sample>
impl<Inner: CheckDuplicates, Sample> CheckDuplicates for ReadOptionalChannel<Inner, Sample>
sourcefn already_contains(&self, name: &Text) -> bool
fn already_contains(&self, name: &Text) -> bool
Check for duplicate channel names.
sourceimpl<ReadChannels: Clone, Sample: Clone> Clone for ReadOptionalChannel<ReadChannels, Sample>
impl<ReadChannels: Clone, Sample: Clone> Clone for ReadOptionalChannel<ReadChannels, Sample>
sourcefn clone(&self) -> ReadOptionalChannel<ReadChannels, Sample>
fn clone(&self) -> ReadOptionalChannel<ReadChannels, Sample>
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
sourceimpl<ReadChannels: Debug, Sample: Debug> Debug for ReadOptionalChannel<ReadChannels, Sample>
impl<ReadChannels: Debug, Sample: Debug> Debug for ReadOptionalChannel<ReadChannels, Sample>
sourceimpl<DefaultSample, ReadChannels> ReadSpecificChannel for ReadOptionalChannel<ReadChannels, DefaultSample> where
ReadChannels: ReadSpecificChannel,
DefaultSample: FromNativeSample + 'static,
impl<DefaultSample, ReadChannels> ReadSpecificChannel for ReadOptionalChannel<ReadChannels, DefaultSample> where
ReadChannels: ReadSpecificChannel,
DefaultSample: FromNativeSample + 'static,
type RecursivePixelReader = Recursive<<ReadChannels as ReadSpecificChannel>::RecursivePixelReader, OptionalSampleReader<DefaultSample>>
type RecursivePixelReader = Recursive<<ReadChannels as ReadSpecificChannel>::RecursivePixelReader, OptionalSampleReader<DefaultSample>>
A separate internal reader for the pixels. Will be of type Recursive<_, SampleReader<_>>
,
depending on the pixels of the specific channel combination. Read more
sourcefn create_recursive_reader(
&self,
channels: &ChannelList
) -> Result<Self::RecursivePixelReader>
fn create_recursive_reader(
&self,
channels: &ChannelList
) -> Result<Self::RecursivePixelReader>
Create a separate internal reader for the pixels of the specific channel combination.
sourcefn required<Sample>(
self,
channel_name: impl Into<Text>
) -> ReadRequiredChannel<Self, Sample>
fn required<Sample>(
self,
channel_name: impl Into<Text>
) -> ReadRequiredChannel<Self, Sample>
Plan to read an additional channel from the image, with the specified name.
If the channel cannot be found in the image when the image is read, the image will not be loaded.
The generic parameter can usually be inferred from the closure in collect_pixels
. Read more
sourcefn optional<Sample>(
self,
channel_name: impl Into<Text>,
default_sample: Sample
) -> ReadOptionalChannel<Self, Sample>
fn optional<Sample>(
self,
channel_name: impl Into<Text>,
default_sample: Sample
) -> ReadOptionalChannel<Self, Sample>
Plan to read an additional channel from the image, with the specified name.
If the file does not contain this channel, the specified default sample will be returned instead.
You can check whether the channel has been loaded by
checking the presence of the optional channel description before instantiating your own image.
The generic parameter can usually be inferred from the closure in collect_pixels
. Read more
sourcefn collect_pixels<Pixel, PixelStorage, CreatePixels, SetPixel>(
self,
create_pixels: CreatePixels,
set_pixel: SetPixel
) -> CollectPixels<Self, Pixel, PixelStorage, CreatePixels, SetPixel> where
<Self::RecursivePixelReader as RecursivePixelReader>::RecursivePixel: IntoTuple<Pixel>,
<Self::RecursivePixelReader as RecursivePixelReader>::RecursiveChannelDescriptions: IntoNonRecursive,
CreatePixels: Fn(Vec2<usize>, &<<Self::RecursivePixelReader as RecursivePixelReader>::RecursiveChannelDescriptions as IntoNonRecursive>::NonRecursive) -> PixelStorage,
SetPixel: Fn(&mut PixelStorage, Vec2<usize>, Pixel),
fn collect_pixels<Pixel, PixelStorage, CreatePixels, SetPixel>(
self,
create_pixels: CreatePixels,
set_pixel: SetPixel
) -> CollectPixels<Self, Pixel, PixelStorage, CreatePixels, SetPixel> where
<Self::RecursivePixelReader as RecursivePixelReader>::RecursivePixel: IntoTuple<Pixel>,
<Self::RecursivePixelReader as RecursivePixelReader>::RecursiveChannelDescriptions: IntoNonRecursive,
CreatePixels: Fn(Vec2<usize>, &<<Self::RecursivePixelReader as RecursivePixelReader>::RecursiveChannelDescriptions as IntoNonRecursive>::NonRecursive) -> PixelStorage,
SetPixel: Fn(&mut PixelStorage, Vec2<usize>, Pixel),
Using two closures, define how to store the pixels.
The first closure creates an image, and the second closure inserts a single pixel.
The type of the pixel can be defined by the second closure;
it must be a tuple containing f16
, f32
, u32
or Sample
values.
See the examples for more information. Read more
Auto Trait Implementations
impl<ReadChannels, Sample> RefUnwindSafe for ReadOptionalChannel<ReadChannels, Sample> where
ReadChannels: RefUnwindSafe,
Sample: RefUnwindSafe,
impl<ReadChannels, Sample> Send for ReadOptionalChannel<ReadChannels, Sample> where
ReadChannels: Send,
Sample: Send,
impl<ReadChannels, Sample> Sync for ReadOptionalChannel<ReadChannels, Sample> where
ReadChannels: Sync,
Sample: Sync,
impl<ReadChannels, Sample> Unpin for ReadOptionalChannel<ReadChannels, Sample> where
ReadChannels: Unpin,
Sample: Unpin,
impl<ReadChannels, Sample> UnwindSafe for ReadOptionalChannel<ReadChannels, Sample> where
ReadChannels: UnwindSafe,
Sample: UnwindSafe,
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more