Skip to main content

InputBox

Struct InputBox 

Source
pub struct InputBox {
Show 16 fields pub rect: Rect, pub text: String, pub text_size: f32, pub text_color: ColorLinPremul, pub placeholder: Option<String>, pub text_align: TextAlign, pub focused: bool, pub disabled: bool, pub bg_color: ColorLinPremul, pub border_color: ColorLinPremul, pub border_width: f32, pub corner_radius: f32, pub input_type: String, pub validation_error: Option<String>, pub cursor_position: usize, pub focus_id: FocusId, /* private fields */
}
Expand description

A single-line text input with cursor, placeholder, and basic editing.

This is a simplified standalone version that stores text as a String and tracks a cursor byte position. It does not depend on external text-layout crates, making it suitable for lightweight UI toolkits.

Fields§

§rect: Rect

Bounding rect of the input field.

§text: String

Current text content.

§text_size: f32

Font size in logical pixels.

§text_color: ColorLinPremul

Text color.

§placeholder: Option<String>

Placeholder text shown when empty.

§text_align: TextAlign

Text alignment within the field.

§focused: bool

Whether this input is focused.

§disabled: bool

Whether this input is disabled.

§bg_color: ColorLinPremul

Background color.

§border_color: ColorLinPremul

Border color.

§border_width: f32

Border width.

§corner_radius: f32

Corner radius.

§input_type: String

Input type hint (e.g. “text”, “password”, “email”).

§validation_error: Option<String>

Validation error message.

§cursor_position: usize

Cursor byte position in text.

§focus_id: FocusId

Focus identifier.

Implementations§

Source§

impl InputBox

Source

pub fn new(rect: Rect) -> Self

Create a new input box with sensible defaults.

Source

pub fn text(&self) -> &str

Get the current text content.

Source

pub fn set_text(&mut self, text: impl Into<String>)

Set the text content and move cursor to the end.

Source

pub fn set_placeholder(&mut self, placeholder: impl Into<String>)

Set the placeholder text.

Source

pub fn insert_text(&mut self, s: &str)

Insert text at the current cursor position.

Source

pub fn delete_char_before(&mut self)

Delete one character before the cursor (backspace).

Source

pub fn delete_char_after(&mut self)

Delete one character after the cursor (delete key).

Source

pub fn move_cursor_left(&mut self)

Move cursor left by one character.

Source

pub fn move_cursor_right(&mut self)

Move cursor right by one character.

Source

pub fn move_cursor_home(&mut self)

Move cursor to the beginning.

Source

pub fn move_cursor_end(&mut self)

Move cursor to the end.

Source

pub fn hit_test(&self, x: f32, y: f32) -> bool

Hit-test the input field.

Trait Implementations§

Source§

impl Default for InputBox

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl Element for InputBox

Source§

fn rect(&self) -> Rect

The bounding rectangle of this element in logical coordinates.
Source§

fn set_rect(&mut self, rect: Rect)

Update the bounding rectangle (typically called by the layout engine).
Source§

fn render(&self, canvas: &mut Canvas, z: i32)

Paint this element onto canvas at the given z-index.
Source§

fn focus_id(&self) -> Option<FocusId>

The focus identifier for this element, if it is focusable.
Source§

impl EventHandler for InputBox

Source§

fn handle_mouse_click(&mut self, event: &MouseClickEvent) -> EventResult

Handle a mouse click event. Returns Handled if the event was consumed.
Source§

fn handle_keyboard(&mut self, event: &KeyboardEvent) -> EventResult

Handle a keyboard event. Returns Handled if the event was consumed.
Source§

fn handle_mouse_move(&mut self, _event: &MouseMoveEvent) -> EventResult

Handle a mouse-move event.
Source§

fn handle_scroll(&mut self, _event: &ScrollEvent) -> EventResult

Handle a scroll event.
Source§

fn is_focused(&self) -> bool

Whether this element currently has focus.
Source§

fn set_focused(&mut self, focused: bool)

Set focus state for this element.
Source§

fn contains_point(&self, x: f32, y: f32) -> bool

Hit-test: does this element contain the given logical point?

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<S, D, Swp, Dwp, T> AdaptInto<D, Swp, Dwp, T> for S
where T: Real + Zero + Arithmetics + Clone, Swp: WhitePoint<T>, Dwp: WhitePoint<T>, D: AdaptFrom<S, Swp, Dwp, T>,

Source§

fn adapt_into_using<M>(self, method: M) -> D
where M: TransformMatrix<T>,

Convert the source color to the destination color using the specified method.
Source§

fn adapt_into(self) -> D

Convert the source color to the destination color using the bradford method by default.
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, C> ArraysFrom<C> for T
where C: IntoArrays<T>,

Source§

fn arrays_from(colors: C) -> T

Cast a collection of colors into a collection of arrays.
Source§

impl<T, C> ArraysInto<C> for T
where C: FromArrays<T>,

Source§

fn arrays_into(self) -> C

Cast this collection of arrays into a collection of colors.
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<WpParam, T, U> Cam16IntoUnclamped<WpParam, T> for U
where T: FromCam16Unclamped<WpParam, U>,

Source§

type Scalar = <T as FromCam16Unclamped<WpParam, U>>::Scalar

The number type that’s used in parameters when converting.
Source§

fn cam16_into_unclamped( self, parameters: BakedParameters<WpParam, <U as Cam16IntoUnclamped<WpParam, T>>::Scalar>, ) -> T

Converts self into C, using the provided parameters.
Source§

impl<T, C> ComponentsFrom<C> for T
where C: IntoComponents<T>,

Source§

fn components_from(colors: C) -> T

Cast a collection of colors into a collection of color components.
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> FromAngle<T> for T

Source§

fn from_angle(angle: T) -> T

Performs a conversion from angle.
Source§

impl<T, U> FromStimulus<U> for T
where U: IntoStimulus<T>,

Source§

fn from_stimulus(other: U) -> T

Converts other into Self, while performing the appropriate scaling, rounding and clamping.
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, U> IntoAngle<U> for T
where U: FromAngle<T>,

Source§

fn into_angle(self) -> U

Performs a conversion into T.
Source§

impl<WpParam, T, U> IntoCam16Unclamped<WpParam, T> for U
where T: Cam16FromUnclamped<WpParam, U>,

Source§

type Scalar = <T as Cam16FromUnclamped<WpParam, U>>::Scalar

The number type that’s used in parameters when converting.
Source§

fn into_cam16_unclamped( self, parameters: BakedParameters<WpParam, <U as IntoCam16Unclamped<WpParam, T>>::Scalar>, ) -> T

Converts self into C, using the provided parameters.
Source§

impl<T, U> IntoColor<U> for T
where U: FromColor<T>,

Source§

fn into_color(self) -> U

Convert into T with values clamped to the color defined bounds Read more
Source§

impl<T, U> IntoColorUnclamped<U> for T
where U: FromColorUnclamped<T>,

Source§

fn into_color_unclamped(self) -> U

Convert into T. The resulting color might be invalid in its color space Read more
Source§

impl<T> IntoStimulus<T> for T

Source§

fn into_stimulus(self) -> T

Converts self into T, while performing the appropriate scaling, rounding and clamping.
Source§

impl<T, C> TryComponentsInto<C> for T
where C: TryFromComponents<T>,

Source§

type Error = <C as TryFromComponents<T>>::Error

The error for when try_into_colors fails to cast.
Source§

fn try_components_into(self) -> Result<C, <T as TryComponentsInto<C>>::Error>

Try to cast this collection of color components into a collection of colors. Read more
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, U> TryIntoColor<U> for T
where U: TryFromColor<T>,

Source§

fn try_into_color(self) -> Result<U, OutOfBounds<U>>

Convert into T, returning ok if the color is inside of its defined range, otherwise an OutOfBounds error is returned which contains the unclamped color. Read more
Source§

impl<C, U> UintsFrom<C> for U
where C: IntoUints<U>,

Source§

fn uints_from(colors: C) -> U

Cast a collection of colors into a collection of unsigned integers.
Source§

impl<C, U> UintsInto<C> for U
where C: FromUints<U>,

Source§

fn uints_into(self) -> C

Cast this collection of unsigned integers into a collection of colors.
Source§

impl<T> Upcast<T> for T

Source§

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

Source§

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

Source§

impl<T> WasmNotSendSync for T

Source§

impl<T> WasmNotSync for T
where T: Sync,