Struct druid::text::TextComponent

source ·
pub struct TextComponent<T> {
    pub has_focus: bool,
    /* private fields */
}
Expand description

A widget that accepts text input.

This is intended to be used as a component of other widgets.

Text input is more complicated than you think, probably. For a good overview, see druid_shell::text.

This type manages an inner EditSession that is shared with the platform. Unlike other aspects of Druid, the platform interacts with this session, not through discrete events.

This is managed through a simple ‘locking’ mechanism; the platform asks for a lock on a particular text session that it wishes to interact with, calls methods on the locked session, and then later releases the lock.

Importantly, other events may be received while the lock is held.

It is the responsibility of the user of this widget to ensure that the session is not locked before it is accessed. This can be done by checking TextComponent::can_read and TextComponent::can_write; after checking these methods the inner session can be accessed via TextComponent::borrow and TextComponent::borrow_mut.

Sementically, this functions like a RefCell; attempting to borrow while a lock is held will result in a panic.

Fields§

§has_focus: bool

A manual flag set by the parent to control drawing behaviour.

The parent should update this when handling LifeCycle::FocusChanged.

Implementations§

source§

impl TextComponent<()>

source

pub const SCROLL_TO: Selector<bool> = _

A notification sent by the component when the cursor has moved.

If the payload is true, this follows an edit, and the view will need layout before scrolling.

source

pub const RETURN: Selector = _

A notification sent by the component when the user hits return.

This is only sent when send_notification_on_return is true.

source

pub const CANCEL: Selector = _

A notification sent when the user cancels editing.

This is only sent when send_notification_on_cancel is true.

source

pub const TAB: Selector = _

A notification sent by the component when the user presses the tab key.

This is not sent if accepts_tabs is true.

An ancestor can handle this event in order to do things like request a focus change.

source

pub const BACKTAB: Selector = _

A notification sent by the component when the user inserts a backtab.

This is not sent if accepts_tabs is true.

An ancestor can handle this event in order to do things like request a focus change.

source§

impl<T> TextComponent<T>

source

pub fn can_read(&self) -> bool

Returns true if the inner EditSession can be read.

source

pub fn can_write(&self) -> bool

Returns true if the inner EditSession can be mutated.

source

pub fn is_composing(&self) -> bool

Returns true if the IME is actively composing (or the text is locked.)

When text is composing, you should avoid doing things like modifying the selection or copy/pasting text.

source

pub fn borrow_mut(&self) -> RefMut<'_, EditSession<T>>

Attempt to mutably borrow the inner EditSession.

Panics

This method panics if there is an outstanding lock on the session.

source

pub fn borrow(&self) -> Ref<'_, EditSession<T>>

Attempt to borrow the inner EditSession.

Panics

This method panics if there is an outstanding write lock on the session.

source§

impl<T: EditableText + TextStorage> TextComponent<T>

source

pub fn input_handler(&self) -> impl ImeHandlerRef

Returns an ImeHandlerRef that can accept platform text input.

The widget managing this component should call LifeCycleCtx::register_text_input during LifeCycle::WidgetAdded, and pass it this object.

Trait Implementations§

source§

impl<T: Clone> Clone for TextComponent<T>

source§

fn clone(&self) -> TextComponent<T>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<T: Debug> Debug for TextComponent<T>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<T> Default for TextComponent<T>

source§

fn default() -> Self

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

impl<T: TextStorage + EditableText> Widget<T> for TextComponent<T>

source§

fn event( &mut self, ctx: &mut EventCtx<'_, '_>, event: &Event, data: &mut T, env: &Env )

Handle an event. Read more
source§

fn lifecycle( &mut self, ctx: &mut LifeCycleCtx<'_, '_>, event: &LifeCycle, data: &T, env: &Env )

Handle a life cycle notification. Read more
source§

fn update(&mut self, ctx: &mut UpdateCtx<'_, '_>, _old: &T, data: &T, env: &Env)

Update the widget’s appearance in response to a change in the app’s Data or Env. Read more
source§

fn layout( &mut self, ctx: &mut LayoutCtx<'_, '_>, bc: &BoxConstraints, _data: &T, env: &Env ) -> Size

Compute layout. Read more
source§

fn paint(&mut self, ctx: &mut PaintCtx<'_, '_, '_>, _data: &T, env: &Env)

Paint the widget appearance. Read more
source§

fn compute_max_intrinsic( &mut self, axis: Axis, ctx: &mut LayoutCtx<'_, '_>, bc: &BoxConstraints, data: &T, env: &Env ) -> f64

Computes max intrinsic/preferred dimension of a widget on the provided axis. Read more

Auto Trait Implementations§

§

impl<T> !RefUnwindSafe for TextComponent<T>

§

impl<T> !Send for TextComponent<T>

§

impl<T> !Sync for TextComponent<T>

§

impl<T> Unpin for TextComponent<T>

§

impl<T> !UnwindSafe for TextComponent<T>

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

const: unstable · source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

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 Twhere U: From<T>,

const: unstable · 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.

§

impl<T> RoundFrom<T> for T

§

fn round_from(x: T) -> T

Performs the conversion.
§

impl<T, U> RoundInto<U> for Twhere U: RoundFrom<T>,

§

fn round_into(self) -> U

Performs the conversion.
source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T, W> TestWidgetExt<T> for Wwhere T: Data, W: Widget<T> + 'static,

source§

fn record(self, recording: &Recording) -> Recorder<Self>

source§

impl<T> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

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

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
source§

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

§

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

The type returned in the event of a conversion error.
const: unstable · 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