Skip to main content

DisplayContext

Struct DisplayContext 

Source
pub struct DisplayContext { /* private fields */ }
Available on crate feature debug-window only.
Expand description

Handle for displaying images from a background thread.

Obtained inside the closure passed to DebugDisplay::run(). All methods are safe to call from the background thread.

§Examples

use fovea_display::{DebugDisplay, Identity};
use fovea::image::Image;
use fovea::pixel::Srgba8;

DebugDisplay::run(|ctx| {
    let img = Image::fill(100, 100, Srgba8::new(255, 0, 0, 255));
    ctx.show("Red", &img, Identity);
    ctx.wait_key();
});

Implementations§

Source§

impl DisplayContext

Source

pub fn show<V, S>(&self, title: &str, image: &V, strategy: S)
where V: ImageView, V::Pixel: Copy, S: DisplayStrategy<V::Pixel>,

Display an image in a window with the given title.

Converts the image to a framebuffer using the given strategy on the calling thread, then sends the framebuffer to the event loop for display. If a window with this title already exists, its contents are updated; otherwise a new window is created.

This method is non-blocking — it returns immediately after sending the command.

§Type parameters
Source

pub fn wait_key(&self) -> Option<KeyCode>

Block until a key is pressed in any window.

Returns the KeyCode of the pressed key, or None if all windows were closed or the event loop exited.

§Examples
use fovea_display::{DebugDisplay, Identity};
use fovea::image::Image;
use fovea::pixel::Srgba8;

DebugDisplay::run(|ctx| {
    let img = Image::fill(100, 100, Srgba8::new(0, 255, 0, 255));
    ctx.show("Green", &img, Identity);
    match ctx.wait_key() {
        Some(key) => println!("Key pressed: {:?}", key),
        None => println!("All windows closed"),
    }
});
Source

pub fn wait_key_timeout(&self, timeout: Duration) -> Option<KeyCode>

Block until a key is pressed, with a timeout.

Returns Some(key) if a key was pressed within the timeout, None if the timeout elapsed or all windows were closed.

Source

pub fn exit(&self)

Request the event loop to close all windows and exit.

This is called automatically when the user closure returns, but can be called explicitly if needed.

Source§

impl DisplayContext

Source

pub fn show_histogram<S, V>(&self, title: &str, h: &Histogram<S, V>)

Display a histogram inside a DebugDisplay::run session, using default render options.

Non-blocking. Uses the same window-update semantics as DisplayContext::show: passing the same title again updates the existing window in place.

Source

pub fn show_histogram_with<S, V>( &self, title: &str, h: &Histogram<S, V>, opts: &HistogramRenderOptions, )

Display a histogram inside a DebugDisplay::run session with custom render options.

Source

pub fn show_histogram_layers( &self, title: &str, layers: &[HistogramLayer<'_>], opts: &HistogramPlotOptions, )

Display a multi-layer histogram inside a DebugDisplay::run session.

Non-blocking. See render_histogram_layers for the rendering model.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<T> ConvertPixelExt for T

Source§

fn then<Mid, B>(self, next: B) -> Then<Self, B, Mid>

Chain this strategy with a second strategy, producing a Then combinator that converts Src → Mid → Dst in a single step. Read more
Source§

impl<T> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert 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.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> FromLinear<T> for T

Source§

fn from_linear(acc: T) -> T

Converts a linear-space accumulator value back to this pixel type, applying rounding and clamping. Read more
Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more