Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Blocking] Flutter IME key event interception for editing implementation #9

Open
znjameswu opened this issue Sep 4, 2020 · 4 comments
Labels
enhancement New feature or request wait-for-upstream

Comments

@znjameswu
Copy link
Owner

znjameswu commented Sep 4, 2020

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.

flutter/flutter#14809

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.

@znjameswu znjameswu pinned this issue Sep 4, 2020
@znjameswu
Copy link
Owner Author

znjameswu commented Sep 7, 2020

Text diffing is not a viable option due to the following reasons according to testing.

  1. 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.
  2. Flutter Window's has a different event model. When input N characters at once, instead of sending one TextEditingValue update, it will send N updates representing different input progress, all at the same time.

According to flutter/flutter#50401, these discrepencies are not considered as bug.

@znjameswu
Copy link
Owner Author

znjameswu commented Sep 7, 2020

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

@creativecreatorormaybenot
Copy link
Contributor

@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
Copy link
Owner Author

@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 😅)

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.

@znjameswu znjameswu added wait-for-upstream enhancement New feature or request labels Nov 20, 2020
@znjameswu znjameswu unpinned this issue Dec 31, 2020
creativecreatorormaybenot pushed a commit to simpleclub-archive/flutter_math that referenced this issue Sep 20, 2021
…ts in text mode) (znjameswu#9)

* Pass mode properly to symbols to support umlauts in text mode

* Fix formatting

* Fix iOS build settings
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request wait-for-upstream
Projects
None yet
Development

No branches or pull requests

2 participants