diff options
| author | 2025-02-13 05:19:32 +0100 | |
|---|---|---|
| committer | 2025-02-13 05:19:32 +0100 | |
| commit | f889008e21971b461ec7c54d9a7667a23f6ab35b (patch) | |
| tree | 91d9d34c87796da424104c46705e9f1aceb69f92 /widget | |
| parent | 97f1db3783dca5a4f60a9f89668613de4dfe9edd (diff) | |
| parent | 89a4dc2ac2a751fdcae921997bb93a76f9b667f9 (diff) | |
| download | iced-f889008e21971b461ec7c54d9a7667a23f6ab35b.tar.gz iced-f889008e21971b461ec7c54d9a7667a23f6ab35b.tar.bz2 iced-f889008e21971b461ec7c54d9a7667a23f6ab35b.zip | |
Merge pull request #2793 from rhysd/issue-2792
Fix the initial candidate window position
Diffstat (limited to 'widget')
| -rw-r--r-- | widget/src/scrollable.rs | 4 | ||||
| -rw-r--r-- | widget/src/text_editor.rs | 8 | ||||
| -rw-r--r-- | widget/src/text_input.rs | 59 | 
3 files changed, 32 insertions, 39 deletions
| diff --git a/widget/src/scrollable.rs b/widget/src/scrollable.rs index fe71fd6b..0cf75c04 100644 --- a/widget/src/scrollable.rs +++ b/widget/src/scrollable.rs @@ -729,7 +729,7 @@ where                      _ => mouse::Cursor::Unavailable,                  }; -                let had_input_method = shell.input_method().is_open(); +                let had_input_method = shell.input_method().is_enabled();                  let translation =                      state.translation(self.direction, bounds, content_bounds); @@ -750,7 +750,7 @@ where                  );                  if !had_input_method { -                    if let InputMethod::Open { position, .. } = +                    if let InputMethod::Enabled { position, .. } =                          shell.input_method_mut()                      {                          *position = *position - translation; diff --git a/widget/src/text_editor.rs b/widget/src/text_editor.rs index ce5da9ef..7e40a56a 100644 --- a/widget/src/text_editor.rs +++ b/widget/src/text_editor.rs @@ -339,10 +339,6 @@ where              return InputMethod::Disabled;          }; -        let Some(preedit) = &state.preedit else { -            return InputMethod::Allowed; -        }; -          let bounds = layout.bounds();          let internal = self.content.0.borrow_mut(); @@ -363,10 +359,10 @@ where          let position =              cursor + translation + Vector::new(0.0, f32::from(line_height)); -        InputMethod::Open { +        InputMethod::Enabled {              position,              purpose: input_method::Purpose::Normal, -            preedit: Some(preedit.as_ref()), +            preedit: state.preedit.as_ref().map(input_method::Preedit::as_ref),          }      }  } diff --git a/widget/src/text_input.rs b/widget/src/text_input.rs index bb2685bd..ae3dfe4c 100644 --- a/widget/src/text_input.rs +++ b/widget/src/text_input.rs @@ -406,10 +406,6 @@ where              return InputMethod::Disabled;          }; -        let Some(preedit) = &state.is_ime_open else { -            return InputMethod::Allowed; -        }; -          let secure_value = self.is_secure.then(|| value.secure());          let value = secure_value.as_ref().unwrap_or(value); @@ -433,14 +429,14 @@ where          let x = (text_bounds.x + cursor_x).floor() - scroll_offset              + alignment_offset; -        InputMethod::Open { +        InputMethod::Enabled {              position: Point::new(x, text_bounds.y + text_bounds.height),              purpose: if self.is_secure {                  input_method::Purpose::Secure              } else {                  input_method::Purpose::Normal              }, -            preedit: Some(preedit.as_ref()), +            preedit: state.preedit.as_ref().map(input_method::Preedit::as_ref),          }      } @@ -584,7 +580,7 @@ where          let draw = |renderer: &mut Renderer, viewport| {              let paragraph = if text.is_empty()                  && state -                    .is_ime_open +                    .preedit                      .as_ref()                      .map(|preedit| preedit.content.is_empty())                      .unwrap_or(true) @@ -1260,7 +1256,7 @@ where                  input_method::Event::Opened | input_method::Event::Closed => {                      let state = state::<Renderer>(tree); -                    state.is_ime_open = +                    state.preedit =                          matches!(event, input_method::Event::Opened)                              .then(input_method::Preedit::new); @@ -1270,7 +1266,7 @@ where                      let state = state::<Renderer>(tree);                      if state.is_focused.is_some() { -                        state.is_ime_open = Some(input_method::Preedit { +                        state.preedit = Some(input_method::Preedit {                              content: content.to_owned(),                              selection: selection.clone(),                              text_size: self.size, @@ -1323,23 +1319,30 @@ where                  let state = state::<Renderer>(tree);                  if let Some(focus) = &mut state.is_focused { -                    if focus.is_window_focused -                        && matches!( +                    if focus.is_window_focused { +                        if matches!(                              state.cursor.state(&self.value),                              cursor::State::Index(_) -                        ) -                    { -                        focus.now = *now; - -                        let millis_until_redraw = CURSOR_BLINK_INTERVAL_MILLIS -                            - (*now - focus.updated_at).as_millis() -                                % CURSOR_BLINK_INTERVAL_MILLIS; - -                        shell.request_redraw_at( -                            *now + Duration::from_millis( -                                millis_until_redraw as u64, -                            ), -                        ); +                        ) { +                            focus.now = *now; + +                            let millis_until_redraw = +                                CURSOR_BLINK_INTERVAL_MILLIS +                                    - (*now - focus.updated_at).as_millis() +                                        % CURSOR_BLINK_INTERVAL_MILLIS; + +                            shell.request_redraw_at( +                                *now + Duration::from_millis( +                                    millis_until_redraw as u64, +                                ), +                            ); +                        } + +                        shell.request_input_method(&self.input_method( +                            state, +                            layout, +                            &self.value, +                        ));                      }                  }              } @@ -1363,12 +1366,6 @@ where          if let Event::Window(window::Event::RedrawRequested(_now)) = event {              self.last_status = Some(status); - -            shell.request_input_method(&self.input_method( -                state, -                layout, -                &self.value, -            ));          } else if self              .last_status              .is_some_and(|last_status| status != last_status) @@ -1528,9 +1525,9 @@ pub struct State<P: text::Paragraph> {      placeholder: paragraph::Plain<P>,      icon: paragraph::Plain<P>,      is_focused: Option<Focus>, -    is_ime_open: Option<input_method::Preedit>,      is_dragging: bool,      is_pasting: Option<Value>, +    preedit: Option<input_method::Preedit>,      last_click: Option<mouse::Click>,      cursor: Cursor,      keyboard_modifiers: keyboard::Modifiers, | 
