Revert "revert: #9769 (#9780)" (#9783)

This reverts commit 0f5f9f65245e40b6c0ebb434308be0fe4b2b129b.
This commit is contained in:
RustDesk 2024-10-30 13:12:18 +08:00 committed by GitHub
parent e6c5064ce5
commit 711ed28846
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -57,9 +57,7 @@ class _RemotePageState extends State<RemotePage> {
final TextEditingController _textController = final TextEditingController _textController =
TextEditingController(text: initText); TextEditingController(text: initText);
// This timer is used to check the composing status of the soft keyboard. bool _lastComposingChangeValid = false;
// It is used for Android, Korean(and other similar) input method.
Timer? _composingTimer;
_RemotePageState(String id) { _RemotePageState(String id) {
initSharedStates(id); initSharedStates(id);
@ -99,6 +97,9 @@ class _RemotePageState extends State<RemotePage> {
showToast(translate('Automatically record outgoing sessions')); showToast(translate('Automatically record outgoing sessions'));
} }
}); });
if (isAndroid) {
_textController.addListener(textAndroidListener);
}
} }
@override @override
@ -114,7 +115,6 @@ class _RemotePageState extends State<RemotePage> {
_physicalFocusNode.dispose(); _physicalFocusNode.dispose();
await gFFI.close(); await gFFI.close();
_timer?.cancel(); _timer?.cancel();
_composingTimer?.cancel();
gFFI.dialogManager.dismissAll(); gFFI.dialogManager.dismissAll();
await SystemChrome.setEnabledSystemUIMode(SystemUiMode.manual, await SystemChrome.setEnabledSystemUIMode(SystemUiMode.manual,
overlays: SystemUiOverlay.values); overlays: SystemUiOverlay.values);
@ -127,6 +127,16 @@ class _RemotePageState extends State<RemotePage> {
// The inner logic of `on_voice_call_closed` will check if the voice call is active. // The inner logic of `on_voice_call_closed` will check if the voice call is active.
// Only one client is considered here for now. // Only one client is considered here for now.
gFFI.chatModel.onVoiceCallClosed("End connetion"); gFFI.chatModel.onVoiceCallClosed("End connetion");
if (isAndroid) {
_textController.removeListener(textAndroidListener);
}
}
// This listener is used to handle the composing region changes for Android soft keyboard input.
void textAndroidListener() {
if (_lastComposingChangeValid) {
_handleNonIOSSoftKeyboardInput(_textController.text);
}
} }
// to-do: It should be better to use transparent color instead of the bgColor. // to-do: It should be better to use transparent color instead of the bgColor.
@ -150,7 +160,6 @@ class _RemotePageState extends State<RemotePage> {
gFFI.ffiModel.pi.version.isNotEmpty) { gFFI.ffiModel.pi.version.isNotEmpty) {
gFFI.invokeMethod("enable_soft_keyboard", false); gFFI.invokeMethod("enable_soft_keyboard", false);
} }
_composingTimer?.cancel();
} else { } else {
_timer?.cancel(); _timer?.cancel();
_timer = Timer(kMobileDelaySoftKeyboardFocus, () { _timer = Timer(kMobileDelaySoftKeyboardFocus, () {
@ -214,11 +223,8 @@ class _RemotePageState extends State<RemotePage> {
} }
void _handleNonIOSSoftKeyboardInput(String newValue) { void _handleNonIOSSoftKeyboardInput(String newValue) {
_composingTimer?.cancel(); _lastComposingChangeValid = _textController.value.isComposingRangeValid;
if (_textController.value.isComposingRangeValid) { if (_lastComposingChangeValid) {
_composingTimer = Timer(Duration(milliseconds: 25), () {
_handleNonIOSSoftKeyboardInput(_textController.value.text);
});
return; return;
} }
var oldValue = _value; var oldValue = _value;