[Blocking] Flutter IME key event interception for editing implementation
znjameswu opened this issue ยท 4 comments
Currently there is no good way of intercepting IME's key event in Flutter, e.g. Backspace, Enter, Home, End, Up, Down, etc, which is essential for the implementation of UnicodeMath-style editing.
Of course, we can infer IME key events by monitoring TextEditingValue
and diffing them. But considering we are repurposing IME key events, this will either break copy/paste or undo/redo invoked from keyboard (either you get a garbled clipboard or a garbled history). It is unacceptable to break hardware keyboard shortcut just to fix IME interactions. But it is equally unacceptable to drop IME support on mobile.
We'll wait for Flutter team's solution. If anyone has experience in handling mobile IMEs on Flutter, please leave comments here.
Text diffing is not a viable option due to the following reasons according to testing.
- Flutter Web's IME composition string implementation is broken. Composing range is always empty and any changes to the composition string are implemented by two steps: delete all & reinsert. This completely breaks text diffing method.
- Flutter Window's has a different event model. When input
N
characters at once, instead of sending oneTextEditingValue
update, it will sendN
updates representing different input progress, all at the same time.
According to flutter/flutter#50401, these discrepencies are not considered as bug.
The problem with Flutter Windows is solvable with a change of diffing algorithm.
But the problem with Flutter Web seems to be not solvable, mixing typed text with composing text means any arbitrary region of text can be reverted at any time, which makes it impossible to perform diffing to capture key event. flutter/flutter#65357
@znjameswu I did not look into the issue deeply - out of curiousity: what are the problems you are facing with using RawKeyboardEventListener
? Is that not a feasible approach when using TextEditingValue
?
(I think you notice that I really did not look into it ๐ )
@znjameswu I did not look into the issue deeply - out of curiousity: what are the problems you are facing with using
RawKeyboardEventListener
? Is that not a feasible approach when usingTextEditingValue
?(I think you notice that I really did not look into it ๐ )
When I opened this issue, I remember that RawKeyboardEventListener
was unable to capture some software keyboard event on Android (i.e. complex keys from Hacker's keyboard). I just tested. It works now.
Another problem is IME handling. RawKeyboardEventListener
only deals with a plain software keyboard without IME. Popping up a plain keyboard instead of user's default IME is wierd, and prevents users from inputting non-ascii characters. And I still wish to integrate this to some markdown editor in the future. So, neither constantly switching keyboard types nor dropping support for non-ascii characters seems a good idea.
It seems that RawKeyboardEventListener
can partially fulfill the requirement now. But IMO this implementation would largely defeat the purpose of editing.