Skip to main content

BuiltinEditor

Struct BuiltinEditor 

Source
pub struct BuiltinEditor<P: Params> { /* private fields */ }
Expand description

Built-in editor that renders parameter widgets to a pixel buffer.

Uses the CPU backend (tiny-skia) for software rasterization. When open() is called, creates a baseview window and blits pixels via wgpu.

Implementations§

Source§

impl<P: Params + 'static> BuiltinEditor<P>

Source

pub fn request_repaint(&self)

Request a repaint on the next idle tick. Call this if plugin code mutates display state outside the normal param or state_changed pathways (uncommon). User interaction and host automation already flag themselves dirty automatically.

Source

pub fn new(params: Arc<P>, layout: PluginLayout) -> Self

Source

pub fn new_with_layout(params: Arc<P>, layout: Layout) -> Self

Source

pub fn new_grid(params: Arc<P>, layout: GridLayout) -> Self

Source

pub fn with_theme(self, theme: Theme) -> Self

Source

pub fn render(&mut self)

Render the full UI to the internal CPU pixel buffer.

Only available when the cpu feature is on. In gpu-only mode, render through Self::render_to with a truce_gpu::WgpuBackend instead.

§Panics

Panics if the lazy CpuBackend::new allocation fails (out of memory or zero dimensions). The backend is allocated on first render - subsequent calls reuse it.

Source

pub fn dispatch_events(&mut self, events: &[InputEvent])

Feed a batch of input events through interaction::dispatch and apply the resulting param edits. Flags a repaint when hover, dropdown-open state, or any param moved.

Typically callers build the events by running each baseview event through interaction::BaseviewTranslator and batching the non-None results.

Source

pub fn pixel_data(&self) -> Option<&[u8]>

Get the raw pixel data after rendering (RGBA premultiplied). Only available when the cpu feature is on.

Source

pub fn has_context(&self) -> bool

Whether the editor has an active context.

Source

pub fn take_context(&mut self) -> Option<PluginContext>

Take the editor context, leaving None in its place. Used by hot-reload to preserve the context when swapping editors.

Source

pub fn set_context(&mut self, context: PluginContext)

Set the editor context (host callbacks) without opening the CPU view.

Source

pub fn size(&self) -> (u32, u32)

Editor logical size (width, height in points). Inherent method so it stays callable when the Editor trait impl is cfg’d out in gpu-only builds.

Source

pub fn state_changed(&mut self)

Notify the widget tree that plugin state was restored (preset recall, undo, session load). Inherent for the same reason as Self::size above.

Source

pub fn render_to(&mut self, backend: &mut dyn RenderBackend)

Render all widgets to an external RenderBackend.

Used by truce-gpu to draw through the GPU backend instead of the internal CPU backend.

Trait Implementations§

Source§

impl<P: Params + 'static> Editor for BuiltinEditor<P>

Available on crate feature cpu only.
Source§

fn size(&self) -> (u32, u32)

Initial window size in logical points. Read more
Source§

fn state_changed(&mut self)

Plugin state was restored (preset recall, undo, session load). Read more
Source§

fn open(&mut self, parent: RawWindowHandle, context: PluginContext)

Create the GUI as a child of the host-provided parent window.
Source§

fn set_scale_factor(&mut self, factor: f64)

Host notifies the editor of a new content scale factor. Read more
Source§

fn close(&mut self)

Destroy the GUI.
Source§

fn idle(&mut self)

Called ~60fps on the host’s UI thread for repaint/animation.
Source§

fn screenshot( &mut self, _params: Arc<dyn Params>, ) -> Option<(Vec<u8>, u32, u32)>

Render a headless screenshot of the editor at its natural size. Read more
Source§

fn set_size(&mut self, _width: u32, _height: u32) -> bool

Host requests a resize. Return true to accept.
Source§

fn can_resize(&self) -> bool

Whether the plugin supports resizing.
Source§

impl<P: Params> Send for BuiltinEditor<P>

Auto Trait Implementations§

§

impl<P> Freeze for BuiltinEditor<P>

§

impl<P> !RefUnwindSafe for BuiltinEditor<P>

§

impl<P> !Sync for BuiltinEditor<P>

§

impl<P> Unpin for BuiltinEditor<P>

§

impl<P> UnsafeUnpin for BuiltinEditor<P>

§

impl<P> !UnwindSafe for BuiltinEditor<P>

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<T> Downcast<T> for T

Source§

fn downcast(&self) -> &T

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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<E> IntoEditor for E
where E: Editor + 'static,

Source§

fn into_editor(self) -> Box<dyn Editor>

Box this editor into a Box<dyn Editor>.
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> Upcast<T> for T

Source§

fn upcast(&self) -> Option<&T>

Source§

impl<T> WasmNotSend for T
where T: Send,