Don't establish text input connections every time focused surface changes
Currently, whenever the focused text input surface changes, the virtual keyboard will create a bunch of excessive connections. This is leftover after the old design.
This commit is contained in:
parent
9479c0d6b4
commit
22cf80c466
2 changed files with 17 additions and 38 deletions
|
@ -100,7 +100,16 @@ void VirtualKeyboard::init()
|
||||||
if (waylandServer()) {
|
if (waylandServer()) {
|
||||||
waylandServer()->display()->createTextInputManagerV2();
|
waylandServer()->display()->createTextInputManagerV2();
|
||||||
connect(workspace(), &Workspace::clientAdded, this, &VirtualKeyboard::clientAdded);
|
connect(workspace(), &Workspace::clientAdded, this, &VirtualKeyboard::clientAdded);
|
||||||
connect(waylandServer()->seat(), &SeatInterface::focusedTextInputSurfaceChanged, this, &VirtualKeyboard::focusedTextInputChanged);
|
connect(waylandServer()->seat(), &SeatInterface::focusedTextInputSurfaceChanged, this, &VirtualKeyboard::handleFocusedSurfaceChanged);
|
||||||
|
|
||||||
|
TextInputV2Interface *textInputV2 = waylandServer()->seat()->textInputV2();
|
||||||
|
connect(textInputV2, &TextInputV2Interface::requestShowInputPanel, this, &VirtualKeyboard::show);
|
||||||
|
connect(textInputV2, &TextInputV2Interface::requestHideInputPanel, this, &VirtualKeyboard::hide);
|
||||||
|
connect(textInputV2, &TextInputV2Interface::surroundingTextChanged, this, &VirtualKeyboard::surroundingTextChanged);
|
||||||
|
connect(textInputV2, &TextInputV2Interface::contentTypeChanged, this, &VirtualKeyboard::contentTypeChanged);
|
||||||
|
connect(textInputV2, &TextInputV2Interface::requestReset, this, &VirtualKeyboard::requestReset);
|
||||||
|
connect(textInputV2, &TextInputV2Interface::enabledChanged, this, &VirtualKeyboard::textInputInterfaceEnabledChanged);
|
||||||
|
connect(textInputV2, &TextInputV2Interface::stateCommitted, this, &VirtualKeyboard::stateCommitted);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -143,42 +152,20 @@ void VirtualKeyboard::clientAdded(AbstractClient* client)
|
||||||
connect(m_inputClient, &AbstractClient::frameGeometryChanged, this, refreshFrame);
|
connect(m_inputClient, &AbstractClient::frameGeometryChanged, this, refreshFrame);
|
||||||
}
|
}
|
||||||
|
|
||||||
void VirtualKeyboard::focusedTextInputChanged()
|
void VirtualKeyboard::handleFocusedSurfaceChanged()
|
||||||
{
|
{
|
||||||
disconnect(m_waylandShowConnection);
|
SurfaceInterface *focusedSurface = waylandServer()->seat()->focusedTextInputSurface();
|
||||||
disconnect(m_waylandHideConnection);
|
if (focusedSurface) {
|
||||||
disconnect(m_waylandHintsConnection);
|
AbstractClient *focusedClient = waylandServer()->findClient(focusedSurface);
|
||||||
disconnect(m_waylandSurroundingTextConnection);
|
|
||||||
disconnect(m_waylandResetConnection);
|
|
||||||
disconnect(m_waylandEnabledConnection);
|
|
||||||
disconnect(m_waylandStateCommittedConnection);
|
|
||||||
if (auto t = waylandServer()->seat()->textInputV2()) {
|
|
||||||
// connections from textinput_interface
|
|
||||||
m_waylandShowConnection = connect(t, &TextInputV2Interface::requestShowInputPanel, this, &VirtualKeyboard::show);
|
|
||||||
m_waylandHideConnection = connect(t, &TextInputV2Interface::requestHideInputPanel, this, &VirtualKeyboard::hide);
|
|
||||||
m_waylandSurroundingTextConnection = connect(t, &TextInputV2Interface::surroundingTextChanged, this, &VirtualKeyboard::surroundingTextChanged);
|
|
||||||
m_waylandHintsConnection = connect(t, &TextInputV2Interface::contentTypeChanged, this, &VirtualKeyboard::contentTypeChanged);
|
|
||||||
m_waylandResetConnection = connect(t, &TextInputV2Interface::requestReset, this, &VirtualKeyboard::requestReset);
|
|
||||||
m_waylandEnabledConnection = connect(t, &TextInputV2Interface::enabledChanged, this, &VirtualKeyboard::textInputInterfaceEnabledChanged);
|
|
||||||
m_waylandStateCommittedConnection = connect(t, &TextInputV2Interface::stateCommitted, this, &VirtualKeyboard::stateCommitted);
|
|
||||||
|
|
||||||
auto newClient = waylandServer()->findClient(waylandServer()->seat()->focusedTextInputSurface());
|
|
||||||
// Reset the old client virtual keybaord geom if necessary
|
// Reset the old client virtual keybaord geom if necessary
|
||||||
// Old and new clients could be the same if focus moves between subsurfaces
|
// Old and new clients could be the same if focus moves between subsurfaces
|
||||||
if (newClient != m_trackedClient) {
|
if (m_trackedClient != focusedClient) {
|
||||||
if (m_trackedClient) {
|
if (m_trackedClient) {
|
||||||
m_trackedClient->setVirtualKeyboardGeometry(QRect());
|
m_trackedClient->setVirtualKeyboardGeometry(QRect());
|
||||||
}
|
}
|
||||||
m_trackedClient = newClient;
|
m_trackedClient = focusedClient;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
m_waylandShowConnection = QMetaObject::Connection();
|
|
||||||
m_waylandHideConnection = QMetaObject::Connection();
|
|
||||||
m_waylandHintsConnection = QMetaObject::Connection();
|
|
||||||
m_waylandSurroundingTextConnection = QMetaObject::Connection();
|
|
||||||
m_waylandResetConnection = QMetaObject::Connection();
|
|
||||||
m_waylandEnabledConnection = QMetaObject::Connection();
|
|
||||||
m_waylandStateCommittedConnection = QMetaObject::Connection();
|
|
||||||
waylandServer()->inputMethod()->sendDeactivate();
|
waylandServer()->inputMethod()->sendDeactivate();
|
||||||
}
|
}
|
||||||
updateInputPanelState();
|
updateInputPanelState();
|
||||||
|
|
|
@ -41,7 +41,7 @@ private Q_SLOTS:
|
||||||
void clientAdded(AbstractClient* client);
|
void clientAdded(AbstractClient* client);
|
||||||
|
|
||||||
// textinput interface slots
|
// textinput interface slots
|
||||||
void focusedTextInputChanged();
|
void handleFocusedSurfaceChanged();
|
||||||
void surroundingTextChanged();
|
void surroundingTextChanged();
|
||||||
void contentTypeChanged();
|
void contentTypeChanged();
|
||||||
void requestReset();
|
void requestReset();
|
||||||
|
@ -61,14 +61,6 @@ private:
|
||||||
// If a surface loses focus immediately after being resized by the keyboard, don't react to it to avoid resize loops
|
// If a surface loses focus immediately after being resized by the keyboard, don't react to it to avoid resize loops
|
||||||
QTimer *m_floodTimer;
|
QTimer *m_floodTimer;
|
||||||
|
|
||||||
QMetaObject::Connection m_waylandShowConnection;
|
|
||||||
QMetaObject::Connection m_waylandHideConnection;
|
|
||||||
QMetaObject::Connection m_waylandHintsConnection;
|
|
||||||
QMetaObject::Connection m_waylandSurroundingTextConnection;
|
|
||||||
QMetaObject::Connection m_waylandResetConnection;
|
|
||||||
QMetaObject::Connection m_waylandEnabledConnection;
|
|
||||||
QMetaObject::Connection m_waylandStateCommittedConnection;
|
|
||||||
|
|
||||||
KWIN_SINGLETON(VirtualKeyboard)
|
KWIN_SINGLETON(VirtualKeyboard)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue