summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLibravatar rhysd <lin90162@yahoo.co.jp>2025-02-06 01:50:25 +0900
committerLibravatar rhysd <lin90162@yahoo.co.jp>2025-02-06 02:01:52 +0900
commitfcdf53afdee9cd12bf2e01c5f6e572859b9a3f96 (patch)
tree0f28b34b42e88db0dc379e3c3b8b6deb88192df2
parent4bbb5cbc1f8b2a0ee8e09be18071368df3ba5bbd (diff)
downloadiced-fcdf53afdee9cd12bf2e01c5f6e572859b9a3f96.tar.gz
iced-fcdf53afdee9cd12bf2e01c5f6e572859b9a3f96.tar.bz2
iced-fcdf53afdee9cd12bf2e01c5f6e572859b9a3f96.zip
Set correct text size for text in preedit window
-rw-r--r--core/src/input_method.rs17
-rw-r--r--widget/src/text_editor.rs12
-rw-r--r--widget/src/text_input.rs3
-rw-r--r--winit/src/program/window_manager.rs4
4 files changed, 25 insertions, 11 deletions
diff --git a/core/src/input_method.rs b/core/src/input_method.rs
index 4e8c383b..ab00b5af 100644
--- a/core/src/input_method.rs
+++ b/core/src/input_method.rs
@@ -1,5 +1,5 @@
//! Listen to input method events.
-use crate::Point;
+use crate::{Pixels, Point};
use std::ops::Range;
@@ -34,15 +34,20 @@ pub struct Preedit<T = String> {
pub content: T,
/// The selected range of the content.
pub selection: Option<Range<usize>>,
+ /// The text size of the content.
+ pub text_size: Option<Pixels>,
}
impl<T> Preedit<T> {
/// Creates a new empty [`Preedit`].
- pub fn new() -> Self
+ pub fn new(text_size: Option<impl Into<Pixels>>) -> Self
where
T: Default,
{
- Self::default()
+ Self {
+ text_size: text_size.map(Into::into),
+ ..Default::default()
+ }
}
/// Turns a [`Preedit`] into its owned version.
@@ -53,6 +58,7 @@ impl<T> Preedit<T> {
Preedit {
content: self.content.as_ref().to_owned(),
selection: self.selection.clone(),
+ text_size: self.text_size,
}
}
}
@@ -63,6 +69,7 @@ impl Preedit {
Preedit {
content: &self.content,
selection: self.selection.clone(),
+ text_size: self.text_size,
}
}
}
@@ -90,13 +97,13 @@ impl InputMethod {
/// let open = InputMethod::Open {
/// position: Point::ORIGIN,
/// purpose: Purpose::Normal,
- /// preedit: Some(Preedit { content: "1".to_owned(), selection: None }),
+ /// preedit: Some(Preedit { content: "1".to_owned(), selection: None, text_size: None }),
/// };
///
/// let open_2 = InputMethod::Open {
/// position: Point::ORIGIN,
/// purpose: Purpose::Secure,
- /// preedit: Some(Preedit { content: "2".to_owned(), selection: None }),
+ /// preedit: Some(Preedit { content: "2".to_owned(), selection: None, text_size: None }),
/// };
///
/// let mut ime = InputMethod::Disabled;
diff --git a/widget/src/text_editor.rs b/widget/src/text_editor.rs
index e685256b..df42d601 100644
--- a/widget/src/text_editor.rs
+++ b/widget/src/text_editor.rs
@@ -753,14 +753,18 @@ where
}
Update::InputMethod(update) => match update {
Ime::Toggle(is_open) => {
- state.preedit =
- is_open.then(input_method::Preedit::new);
+ state.preedit = is_open.then(|| {
+ input_method::Preedit::new(self.text_size)
+ });
shell.request_redraw();
}
Ime::Preedit { content, selection } => {
- state.preedit =
- Some(input_method::Preedit { content, selection });
+ state.preedit = Some(input_method::Preedit {
+ content,
+ selection,
+ text_size: self.text_size,
+ });
shell.request_redraw();
}
diff --git a/widget/src/text_input.rs b/widget/src/text_input.rs
index 7be5bbd9..de957e14 100644
--- a/widget/src/text_input.rs
+++ b/widget/src/text_input.rs
@@ -1262,7 +1262,7 @@ where
state.is_ime_open =
matches!(event, input_method::Event::Opened)
- .then(input_method::Preedit::new);
+ .then(|| input_method::Preedit::new(self.size));
shell.request_redraw();
}
@@ -1273,6 +1273,7 @@ where
state.is_ime_open = Some(input_method::Preedit {
content: content.to_owned(),
selection: selection.clone(),
+ text_size: self.size,
});
shell.request_redraw();
diff --git a/winit/src/program/window_manager.rs b/winit/src/program/window_manager.rs
index ae214e7c..d5b334df 100644
--- a/winit/src/program/window_manager.rs
+++ b/winit/src/program/window_manager.rs
@@ -322,7 +322,9 @@ where
self.content = Renderer::Paragraph::with_spans(Text {
content: &spans,
bounds: Size::INFINITY,
- size: renderer.default_size(),
+ size: preedit
+ .text_size
+ .unwrap_or_else(|| renderer.default_size()),
line_height: text::LineHeight::default(),
font: renderer.default_font(),
horizontal_alignment: alignment::Horizontal::Left,