diff options
| author | 2024-09-04 21:42:11 +0200 | |
|---|---|---|
| committer | 2024-09-04 21:42:11 +0200 | |
| commit | 6009420b57933ccf799f1b7eac8debab950cdd5e (patch) | |
| tree | e6218826131a702e51adf3041a45871140bae0be /widget/src/text | |
| parent | 8d826cc662554b337282e7c982383f5db428d7aa (diff) | |
| parent | 3a70462a7232cc2b3a7cc3fe8d07f0c29cc578cc (diff) | |
| download | iced-6009420b57933ccf799f1b7eac8debab950cdd5e.tar.gz iced-6009420b57933ccf799f1b7eac8debab950cdd5e.tar.bz2 iced-6009420b57933ccf799f1b7eac8debab950cdd5e.zip | |
Merge pull request #2279 from nrjais/wrapping
Add `text::Wrapping` support
Diffstat (limited to '')
| -rw-r--r-- | widget/src/text/rich.rs | 14 | ||||
| -rw-r--r-- | widget/src/text_editor.rs | 13 | ||||
| -rw-r--r-- | widget/src/text_input.rs | 3 | 
3 files changed, 28 insertions, 2 deletions
| diff --git a/widget/src/text/rich.rs b/widget/src/text/rich.rs index 1eb0d296..921c55a5 100644 --- a/widget/src/text/rich.rs +++ b/widget/src/text/rich.rs @@ -5,7 +5,7 @@ use crate::core::mouse;  use crate::core::renderer;  use crate::core::text::{Paragraph, Span};  use crate::core::widget::text::{ -    self, Catalog, LineHeight, Shaping, Style, StyleFn, +    self, Catalog, LineHeight, Shaping, Style, StyleFn, Wrapping,  };  use crate::core::widget::tree::{self, Tree};  use crate::core::{ @@ -29,6 +29,7 @@ where      font: Option<Renderer::Font>,      align_x: alignment::Horizontal,      align_y: alignment::Vertical, +    wrapping: Wrapping,      class: Theme::Class<'a>,  } @@ -50,6 +51,7 @@ where              font: None,              align_x: alignment::Horizontal::Left,              align_y: alignment::Vertical::Top, +            wrapping: Wrapping::default(),              class: Theme::default(),          }      } @@ -118,6 +120,12 @@ where          self      } +    /// Sets the [`Wrapping`] strategy of the [`Rich`] text. +    pub fn wrapping(mut self, wrapping: Wrapping) -> Self { +        self.wrapping = wrapping; +        self +    } +      /// Sets the default style of the [`Rich`] text.      #[must_use]      pub fn style(mut self, style: impl Fn(&Theme) -> Style + 'a) -> Self @@ -218,6 +226,7 @@ where              self.font,              self.align_x,              self.align_y, +            self.wrapping,          )      } @@ -444,6 +453,7 @@ fn layout<Link, Renderer>(      font: Option<Renderer::Font>,      horizontal_alignment: alignment::Horizontal,      vertical_alignment: alignment::Vertical, +    wrapping: Wrapping,  ) -> layout::Node  where      Link: Clone, @@ -464,6 +474,7 @@ where              horizontal_alignment,              vertical_alignment,              shaping: Shaping::Advanced, +            wrapping,          };          if state.spans != spans { @@ -480,6 +491,7 @@ where                  horizontal_alignment,                  vertical_alignment,                  shaping: Shaping::Advanced, +                wrapping,              }) {                  core::text::Difference::None => {}                  core::text::Difference::Bounds => { diff --git a/widget/src/text_editor.rs b/widget/src/text_editor.rs index 745e3ae8..d1aa4640 100644 --- a/widget/src/text_editor.rs +++ b/widget/src/text_editor.rs @@ -9,7 +9,7 @@ use crate::core::mouse;  use crate::core::renderer;  use crate::core::text::editor::{Cursor, Editor as _};  use crate::core::text::highlighter::{self, Highlighter}; -use crate::core::text::{self, LineHeight, Text}; +use crate::core::text::{self, LineHeight, Text, Wrapping};  use crate::core::time::{Duration, Instant};  use crate::core::widget::operation;  use crate::core::widget::{self, Widget}; @@ -47,6 +47,7 @@ pub struct TextEditor<      width: Length,      height: Length,      padding: Padding, +    wrapping: Wrapping,      class: Theme::Class<'a>,      key_binding: Option<Box<dyn Fn(KeyPress) -> Option<Binding<Message>> + 'a>>,      on_edit: Option<Box<dyn Fn(Action) -> Message + 'a>>, @@ -74,6 +75,7 @@ where              width: Length::Fill,              height: Length::Shrink,              padding: Padding::new(5.0), +            wrapping: Wrapping::default(),              class: Theme::default(),              key_binding: None,              on_edit: None, @@ -148,6 +150,12 @@ where          self      } +    /// Sets the [`Wrapping`] strategy of the [`TextEditor`]. +    pub fn wrapping(mut self, wrapping: Wrapping) -> Self { +        self.wrapping = wrapping; +        self +    } +      /// Highlights the [`TextEditor`] using the given syntax and theme.      #[cfg(feature = "highlighter")]      pub fn highlight( @@ -186,6 +194,7 @@ where              width: self.width,              height: self.height,              padding: self.padding, +            wrapping: self.wrapping,              class: self.class,              key_binding: self.key_binding,              on_edit: self.on_edit, @@ -496,6 +505,7 @@ where              self.font.unwrap_or_else(|| renderer.default_font()),              self.text_size.unwrap_or_else(|| renderer.default_size()),              self.line_height, +            self.wrapping,              state.highlighter.borrow_mut().deref_mut(),          ); @@ -784,6 +794,7 @@ where                          horizontal_alignment: alignment::Horizontal::Left,                          vertical_alignment: alignment::Vertical::Top,                          shaping: text::Shaping::Advanced, +                        wrapping: self.wrapping,                      },                      text_bounds.position(),                      style.placeholder, diff --git a/widget/src/text_input.rs b/widget/src/text_input.rs index 52e37388..92047381 100644 --- a/widget/src/text_input.rs +++ b/widget/src/text_input.rs @@ -251,6 +251,7 @@ where              horizontal_alignment: alignment::Horizontal::Left,              vertical_alignment: alignment::Vertical::Center,              shaping: text::Shaping::Advanced, +            wrapping: text::Wrapping::default(),          };          state.placeholder.update(placeholder_text); @@ -275,6 +276,7 @@ where                  horizontal_alignment: alignment::Horizontal::Center,                  vertical_alignment: alignment::Vertical::Center,                  shaping: text::Shaping::Advanced, +                wrapping: text::Wrapping::default(),              };              state.icon.update(icon_text); @@ -1432,6 +1434,7 @@ fn replace_paragraph<Renderer>(          horizontal_alignment: alignment::Horizontal::Left,          vertical_alignment: alignment::Vertical::Top,          shaping: text::Shaping::Advanced, +        wrapping: text::Wrapping::default(),      });  } | 
