inputmethod: toggle the inputmethod if we get second show request
This is in a way working around bad protocol, input-method-unstable-v1 and also input-method-unstable-v2 does not have a way for input-method to mark itself as "deactivated". This can happen when e.g. user closes the virtual keyboard using swiping down or "close keyboard" button in keyboard. When this happens, the state between compositor, text_input and input_method gets out of sync, compositor does not know that input method got deactivated and hence it will continue sending various events to it. The quick way around it is to change focus, which makes compositor send deactivate request to input-method, that puts compositor and input-method in sync again. This patch aims to solve this by tracking the last state of input method, If we know that input method is active and text input sends us the show event, we toggle the input-method. I will re-iterate that this is in no way proper solution, ideally input-method-unstable-v3 or input-method-unstable-v2 even (since it is not upstream anyway) gains the new request which essentially allows input-method to sync enabled/disabled state with compositor.
This commit is contained in:
parent
378ecbc88c
commit
892b8cf6cb
2 changed files with 15 additions and 6 deletions
|
@ -111,13 +111,21 @@ void InputMethod::init()
|
|||
|
||||
void InputMethod::show()
|
||||
{
|
||||
if (m_shown) {
|
||||
waylandServer()->inputMethod()->sendDeactivate();
|
||||
}
|
||||
waylandServer()->inputMethod()->sendActivate();
|
||||
if (m_shown) {
|
||||
adoptInputMethodContext();
|
||||
}
|
||||
m_shown = true;
|
||||
}
|
||||
|
||||
void InputMethod::hide()
|
||||
{
|
||||
waylandServer()->inputMethod()->sendDeactivate();
|
||||
updateInputPanelState();
|
||||
m_shown = false;
|
||||
}
|
||||
|
||||
void InputMethod::clientAdded(AbstractClient* client)
|
||||
|
@ -433,12 +441,12 @@ void InputMethod::adoptInputMethodContext()
|
|||
inputContext->sendContentType(t3->contentHints(), t3->contentPurpose());
|
||||
}
|
||||
|
||||
connect(inputContext, &KWaylandServer::InputMethodContextV1Interface::keysym, waylandServer(), &keysymReceived);
|
||||
connect(inputContext, &KWaylandServer::InputMethodContextV1Interface::commitString, waylandServer(), &commitString);
|
||||
connect(inputContext, &KWaylandServer::InputMethodContextV1Interface::deleteSurroundingText, waylandServer(), &deleteSurroundingText);
|
||||
connect(inputContext, &KWaylandServer::InputMethodContextV1Interface::cursorPosition, waylandServer(), &setCursorPosition);
|
||||
connect(inputContext, &KWaylandServer::InputMethodContextV1Interface::preeditString, this, &InputMethod::setPreeditString);
|
||||
connect(inputContext, &KWaylandServer::InputMethodContextV1Interface::preeditCursor, this, &InputMethod::setPreeditCursor);
|
||||
connect(inputContext, &KWaylandServer::InputMethodContextV1Interface::keysym, waylandServer(), &keysymReceived, Qt::UniqueConnection);
|
||||
connect(inputContext, &KWaylandServer::InputMethodContextV1Interface::commitString, waylandServer(), &commitString, Qt::UniqueConnection);
|
||||
connect(inputContext, &KWaylandServer::InputMethodContextV1Interface::deleteSurroundingText, waylandServer(), &deleteSurroundingText, Qt::UniqueConnection);
|
||||
connect(inputContext, &KWaylandServer::InputMethodContextV1Interface::cursorPosition, waylandServer(), &setCursorPosition, Qt::UniqueConnection);
|
||||
connect(inputContext, &KWaylandServer::InputMethodContextV1Interface::preeditString, this, &InputMethod::setPreeditString, Qt::UniqueConnection);
|
||||
connect(inputContext, &KWaylandServer::InputMethodContextV1Interface::preeditCursor, this, &InputMethod::setPreeditCursor, Qt::UniqueConnection);
|
||||
}
|
||||
|
||||
void InputMethod::updateSni()
|
||||
|
|
|
@ -68,6 +68,7 @@ private:
|
|||
} preedit;
|
||||
|
||||
bool m_enabled = false;
|
||||
bool m_shown = false;
|
||||
KStatusNotifierItem *m_sni = nullptr;
|
||||
QPointer<AbstractClient> m_inputClient;
|
||||
QPointer<AbstractClient> m_trackedClient;
|
||||
|
|
Loading…
Reference in a new issue