summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/android/jar/src/org/qtproject/qt/android/QtInputConnection.java11
1 files changed, 9 insertions, 2 deletions
diff --git a/src/android/jar/src/org/qtproject/qt/android/QtInputConnection.java b/src/android/jar/src/org/qtproject/qt/android/QtInputConnection.java
index 4327ff0e36f..e89882372d5 100644
--- a/src/android/jar/src/org/qtproject/qt/android/QtInputConnection.java
+++ b/src/android/jar/src/org/qtproject/qt/android/QtInputConnection.java
@@ -66,6 +66,7 @@ class QtInputConnection extends BaseInputConnection
private static final String QtTAG = "QtInputConnection";
+ private boolean m_duringBatchEdit = false;
private final QtInputConnectionListener m_qtInputConnectionListener;
class HideKeyboardRunnable implements Runnable {
@@ -122,7 +123,7 @@ class QtInputConnection extends BaseInputConnection
void restartImmInput()
{
- if (QtNativeInputConnection.fullscreenMode()) {
+ if (QtNativeInputConnection.fullscreenMode() && !m_duringBatchEdit) {
if (m_imm != null)
m_imm.restartInput(m_view);
}
@@ -133,6 +134,7 @@ class QtInputConnection extends BaseInputConnection
public boolean beginBatchEdit()
{
setClosing(false);
+ m_duringBatchEdit = true;
return QtNativeInputConnection.beginBatchEdit();
}
@@ -149,7 +151,12 @@ class QtInputConnection extends BaseInputConnection
public boolean endBatchEdit()
{
setClosing(false);
- return QtNativeInputConnection.endBatchEdit();
+ boolean ret = QtNativeInputConnection.endBatchEdit();
+ if (m_duringBatchEdit) {
+ m_duringBatchEdit = false;
+ restartImmInput();
+ }
+ return ret;
}
@Override