2a8ab547e1
At the same time the xinput2 integration is split out of X11Cursor and made a standalone part of the platform plugin. XInput integration is nowadays not only used by the cursor position polling, but also for modifier only shortcuts. By splitting it out the modifier shortcuts start to work also when one doesn't have anything requesting a mouse position polling. This also simplifies the conditional builds: xinput integration is only included if we have support for it at compile time without having to have many ifdefs in the cursor implementation. For the inclusion of cursor in the kcmkwin this also removes all the ifdefs. The key events are only requested if we have xinput 2.1. Otherwise we would not get all raw events if the input device gets grabbed. Reviewers: #kwin, #plasma_on_wayland Subscribers: plasma-devel, kwin Tags: #plasma_on_wayland, #kwin Differential Revision: https://phabricator.kde.org/D2473
72 lines
2.1 KiB
C++
72 lines
2.1 KiB
C++
/********************************************************************
|
|
KWin - the KDE window manager
|
|
This file is part of the KDE project.
|
|
|
|
Copyright (C) 2013 Martin Gräßlin <mgraesslin@kde.org>
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*********************************************************************/
|
|
#ifndef KWIN_X11CURSOR_H
|
|
#define KWIN_X11CURSOR_H
|
|
#include "cursor.h"
|
|
|
|
namespace KWin
|
|
{
|
|
|
|
class KWIN_EXPORT X11Cursor : public Cursor
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
X11Cursor(QObject *parent, bool xInputSupport = false);
|
|
virtual ~X11Cursor();
|
|
|
|
void schedulePoll() {
|
|
m_needsPoll = true;
|
|
}
|
|
|
|
protected:
|
|
virtual xcb_cursor_t getX11Cursor(Qt::CursorShape shape);
|
|
xcb_cursor_t getX11Cursor(const QByteArray &name) override;
|
|
virtual void doSetPos();
|
|
virtual void doGetPos();
|
|
virtual void doStartMousePolling();
|
|
virtual void doStopMousePolling();
|
|
virtual void doStartCursorTracking();
|
|
virtual void doStopCursorTracking();
|
|
|
|
private Q_SLOTS:
|
|
/**
|
|
* Because of QTimer's and the impossibility to get events for all mouse
|
|
* movements (at least I haven't figured out how) the position needs
|
|
* to be also refetched after each return to the event loop.
|
|
*/
|
|
void resetTimeStamp();
|
|
void mousePolled();
|
|
void aboutToBlock();
|
|
private:
|
|
xcb_cursor_t createCursor(const QByteArray &name);
|
|
QHash<QByteArray, xcb_cursor_t > m_cursors;
|
|
xcb_timestamp_t m_timeStamp;
|
|
uint16_t m_buttonMask;
|
|
QTimer *m_resetTimeStampTimer;
|
|
QTimer *m_mousePollingTimer;
|
|
bool m_hasXInput;
|
|
bool m_needsPoll;
|
|
friend class Cursor;
|
|
};
|
|
|
|
|
|
}
|
|
|
|
#endif
|