Image display, renders a raster image from a file path or an in-memory handle.
Props
| Name | Type | Default | Description |
|---|---|---|---|
source | term() | required | Path to the image file, or %{handle: name} for in-memory images. |
width | :fill | :shrink | {:fill_portion, pos_integer()} | number() | nil | Image width. Default: shrink. |
height | :fill | :shrink | {:fill_portion, pos_integer()} | number() | nil | Image height. Default: shrink. |
content_fit | :contain | :cover | :fill | :none | :scale_down | nil | How the image fits its bounds. |
rotation | number() | nil | Rotation angle in degrees. |
opacity | number() | nil | Opacity from 0.0 (transparent) to 1.0 (opaque). |
border_radius | number() | nil | Corner radius in pixels. |
filter_method | :nearest | :linear | nil | Image interpolation mode. |
expand | boolean() | nil | Expand image to fill available space. |
scale | number() | nil | Scale factor for the image. |
crop | map() | nil | Crop rectangle: %{x, y, width, height} (integer pixel values). |
alt | String.t() | atom() | nil | Accessible label for the image. |
description | String.t() | atom() | nil | Extended accessible description for the image. |
decorative | boolean() | nil | When true, hides the image from assistive technology. |
event_rate | integer() | nil | Max events per second for coalescable events. |
a11y | %Plushie.Type.A11y{} | map() | keyword() | %{role: :image} | Accessibility annotations. |
Constructor
Image.new(id, source)
Image.new(id, source, opts)
Summary
Functions
Accessibility annotations.
Accessible label for the image.
Corner radius in pixels.
Converts this widget struct to a ui_node() map.
How the image fits its bounds.
Crop rectangle: %{x, y, width, height} (integer pixel values).
When true, hides the image from assistive technology.
Extended accessible description for the image.
Max events per second for coalescable events.
Expand image to fill available space.
Image interpolation mode.
Image height. Default: shrink.
Creates a :image widget.
Creates a new widget struct with the given positional args and keyword options.
Opacity from 0.0 (transparent) to 1.0 (opaque).
Rotation angle in degrees.
Scale factor for the image.
Path to the image file, or %{handle: name} for in-memory images.
Image width. Default: shrink.
Applies keyword options to an existing widget struct.
Types
@type option() :: ((((((((((((({:width, :fill | :shrink | {:fill_portion, pos_integer()} | number()} | {:height, :fill | :shrink | {:fill_portion, pos_integer()} | number()}) | {:content_fit, :contain | :cover | :fill | :none | :scale_down}) | {:rotation, number()}) | {:opacity, number()}) | {:border_radius, number()}) | {:filter_method, :nearest | :linear}) | {:expand, boolean()}) | {:scale, number()}) | {:crop, map()}) | {:alt, String.t() | atom()}) | {:description, String.t() | atom()}) | {:decorative, boolean()}) | {:event_rate, integer()}) | {:a11y, %Plushie.Type.A11y{ active_descendant: term(), busy: term(), described_by: term(), description: term(), disabled: term(), error_message: term(), expanded: term(), has_popup: term(), hidden: term(), invalid: term(), label: term(), label_from: term(), labelled_by: term(), level: term(), live: term(), mnemonic: term(), modal: term(), orientation: term(), position_in_set: term(), radio_group: term(), read_only: term(), required: term(), role: term(), selected: term(), size_of_set: term(), toggled: term(), value: term() } | map() | keyword()}
@type t() :: %Plushie.Widget.Image{ a11y: (%Plushie.Type.A11y{ active_descendant: term(), busy: term(), described_by: term(), description: term(), disabled: term(), error_message: term(), expanded: term(), has_popup: term(), hidden: term(), invalid: term(), label: term(), label_from: term(), labelled_by: term(), level: term(), live: term(), mnemonic: term(), modal: term(), orientation: term(), position_in_set: term(), radio_group: term(), read_only: term(), required: term(), role: term(), selected: term(), size_of_set: term(), toggled: term(), value: term() } | map() | keyword()) | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, alt: (String.t() | atom()) | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, border_radius: number() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, content_fit: (:contain | :cover | :fill | :none | :scale_down) | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, crop: map() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, decorative: boolean() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, description: (String.t() | atom()) | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, event_rate: integer() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, expand: boolean() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, filter_method: (:nearest | :linear) | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, height: (:fill | :shrink | {:fill_portion, pos_integer()} | number()) | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, id: String.t(), opacity: number() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, rotation: number() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, scale: number() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, source: term() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, width: (:fill | :shrink | {:fill_portion, pos_integer()} | number()) | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil }
Functions
@spec a11y( widget :: t(), value :: (%Plushie.Type.A11y{ active_descendant: term(), busy: term(), described_by: term(), description: term(), disabled: term(), error_message: term(), expanded: term(), has_popup: term(), hidden: term(), invalid: term(), label: term(), label_from: term(), labelled_by: term(), level: term(), live: term(), mnemonic: term(), modal: term(), orientation: term(), position_in_set: term(), radio_group: term(), read_only: term(), required: term(), role: term(), selected: term(), size_of_set: term(), toggled: term(), value: term() } | map() | keyword()) | nil ) :: t()
Accessibility annotations.
Accepts %Plushie.Type.A11y{} | map() | keyword().
Accessible label for the image.
Accepts String.t() | atom().
Corner radius in pixels.
Accepts number().
@spec build(widget :: t()) :: Plushie.Widget.ui_node()
Converts this widget struct to a ui_node() map.
@spec content_fit( widget :: t(), value :: (:contain | :cover | :fill | :none | :scale_down) | nil ) :: t()
How the image fits its bounds.
Accepts :contain | :cover | :fill | :none | :scale_down.
Crop rectangle: %{x, y, width, height} (integer pixel values).
Accepts map().
When true, hides the image from assistive technology.
Accepts boolean().
Extended accessible description for the image.
Accepts String.t() | atom().
Max events per second for coalescable events.
Accepts integer().
Expand image to fill available space.
Accepts boolean().
Image interpolation mode.
Accepts :nearest | :linear.
@spec height( widget :: t(), value :: (:fill | :shrink | {:fill_portion, pos_integer()} | number()) | nil ) :: t()
Image height. Default: shrink.
Accepts :fill | :shrink | {:fill_portion, pos_integer()} | number().
Creates a :image widget.
Shorthand for new/2. Import this macro to use the widget name
directly in view functions:
import Plushie.Widget.Image, only: [image: 2]
image("my-id", prop: value)
Creates a new widget struct with the given positional args and keyword options.
Arguments
id- unique widget identifiersource- Path to the image file, or%{handle: name}for in-memory images.opts- keyword list of optional props
Opacity from 0.0 (transparent) to 1.0 (opaque).
Accepts number().
Rotation angle in degrees.
Accepts number().
Scale factor for the image.
Accepts number().
Path to the image file, or %{handle: name} for in-memory images.
Accepts term().
@spec width( widget :: t(), value :: (:fill | :shrink | {:fill_portion, pos_integer()} | number()) | nil ) :: t()
Image width. Default: shrink.
Accepts :fill | :shrink | {:fill_portion, pos_integer()} | number().
Applies keyword options to an existing widget struct.