pub struct Image {
pub rgba: Arc<Vec<u8>>,
pub width: u32,
pub height: u32,
pub cover: bool,
pub display_size: Option<(Length, Length)>,
pub opacity: f32,
}Expand description
A static image widget that renders RGBA pixel data.
Images are scaled to fill their allocated rect. Alpha blending against the background is handled automatically (straight → premultiplied conversion).
The pixel buffer is shared via Arc so reusing the same image across
frames (e.g. a background decoded once at startup) is a cheap pointer
copy instead of a full Vec<u8> clone.
// Display at 40 % of the viewport width by 20 % of its height instead of
// the source's intrinsic pixel size — scales across screens with no tweaks.
img_widget( rgba_bytes, width, height )
.size( Length::vw( 40.0 ), Length::vh( 20.0 ) )
.opacity( 0.8 )
.into()Fields§
§rgba: Arc<Vec<u8>>Raw RGBA pixel data (4 bytes per pixel, straight alpha).
width: u32Pixel width of the source image.
height: u32Pixel height of the source image.
cover: boolWhen true the image scales to fill the available width (cover mode).
display_size: Option<(Length, Length)>Optional explicit display size (Length values, resolved at layout time).
opacity: f32Opacity multiplier in [0.0, 1.0]. Default: 1.0.
Implementations§
Source§impl Image
impl Image
Sourcepub fn new(rgba: Arc<Vec<u8>>, width: u32, height: u32) -> Self
pub fn new(rgba: Arc<Vec<u8>>, width: u32, height: u32) -> Self
Create an image from a shared RGBA buffer.
width and height must match the dimensions of rgba.
Sourcepub fn from_path(path: &str) -> Result<Self, Box<dyn Error>>
pub fn from_path(path: &str) -> Result<Self, Box<dyn Error>>
Load an image from a file path. Supports PNG, JPEG, and other formats
supported by the image crate.
Sourcepub fn cover(self) -> Self
pub fn cover(self) -> Self
Scale the image to fill the available width, preserving aspect ratio (cover mode).
Sourcepub fn size(self, width: impl Into<Length>, height: impl Into<Length>) -> Self
pub fn size(self, width: impl Into<Length>, height: impl Into<Length>) -> Self
Set an explicit display size. Accepts logical f32 pixels or any
Length variant (e.g. Length::vw(13.0) for 13 % of viewport width).
Trait Implementations§
Auto Trait Implementations§
impl Freeze for Image
impl RefUnwindSafe for Image
impl Send for Image
impl Sync for Image
impl Unpin for Image
impl UnwindSafe for Image
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
§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