[−][src]Struct nannou::wgpu::TextureSnapshot
A snapshot captured by a Capturer.
A snapshot is a thin wrapper around a wgpu::BufferImage that knows that the image format is specifically non-linear sRGBA8.
Implementations
impl Snapshot
[src]
pub async fn read_async(
self
) -> Result<Rgba8AsyncMappedImageBuffer, BufferAsyncErr>
[src]
self
) -> Result<Rgba8AsyncMappedImageBuffer, BufferAsyncErr>
Reads the non-linear sRGBA image from mapped memory.
Specifically, this asynchronously maps the buffer of bytes from GPU to host memory and
returns the result as an ImageBuffer
with non-linear, RGBA 8 pixels.
pub fn read<F>(
self,
callback: F
) -> Result<(), AwaitWorkerTimeout<impl Future<Output = ()>>> where
F: 'static + Send + FnOnce(Result<Rgba8AsyncMappedImageBuffer, BufferAsyncErr>),
[src]
self,
callback: F
) -> Result<(), AwaitWorkerTimeout<impl Future<Output = ()>>> where
F: 'static + Send + FnOnce(Result<Rgba8AsyncMappedImageBuffer, BufferAsyncErr>),
The same as read_async
, but runs the resulting future on an inner threadpool and calls
the given callback with the mapped image buffer once complete.
Note: The given callback will not be called until the memory is mapped and the device is polled. You should not rely on the callback being called immediately.
Note: The given callback will be called on the inner thread pool and will not be called on the current thread.
Note: This method may block if the associated wgpu::TextureCapturer
has an
active_futures
count that is greater than the number of worker threads with which it was
created. This is necessary in order to avoid "out of memory" errors resulting from an
accumulating queue of pending texture buffers waiting to be mapped. To avoid blocking, you
can try using a higher thread count, capturing a smaller texture, or using read_async
instead and running the resulting future on a custom runtime or threadpool.
Auto Trait Implementations
impl !RefUnwindSafe for Snapshot
impl Send for Snapshot
impl Sync for Snapshot
impl Unpin for Snapshot
impl !UnwindSafe for Snapshot
Blanket Implementations
impl<S, D, Swp, Dwp, T> AdaptInto<D, Swp, Dwp, T> for S where
D: AdaptFrom<S, Swp, Dwp, T>,
Dwp: WhitePoint,
Swp: WhitePoint,
T: Component + Float,
[src]
D: AdaptFrom<S, Swp, Dwp, T>,
Dwp: WhitePoint,
Swp: WhitePoint,
T: Component + Float,
fn adapt_into_using<M>(self, method: M) -> D where
M: TransformMatrix<Swp, Dwp, T>,
[src]
M: TransformMatrix<Swp, Dwp, T>,
fn adapt_into(self) -> D
[src]
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T, U> ConvertInto<U> for T where
U: ConvertFrom<T>,
[src]
U: ConvertFrom<T>,
fn convert_into(self) -> U
[src]
fn convert_unclamped_into(self) -> U
[src]
fn try_convert_into(self) -> Result<U, OutOfBounds<U>>
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> SetParameter for T
fn set<T>(&mut self, value: T) -> <T as Parameter<Self>>::Result where
T: Parameter<Self>,
T: Parameter<Self>,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
V: MultiLane<T>,