You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
163 lines
4.4 KiB
163 lines
4.4 KiB
/* |
|
KWin - the KDE window manager |
|
This file is part of the KDE project. |
|
|
|
SPDX-FileCopyrightText: 2015 Martin Gräßlin <mgraesslin@kde.org> |
|
|
|
SPDX-License-Identifier: GPL-2.0-or-later |
|
*/ |
|
#include "dpmsinputeventfilter.h" |
|
#include "core/output.h" |
|
#include "core/outputbackend.h" |
|
#include "core/session.h" |
|
#include "input_event.h" |
|
#include "main.h" |
|
#include "utils/keys.h" |
|
#include "wayland/seat.h" |
|
#include "wayland_server.h" |
|
#include "workspace.h" |
|
|
|
#include <QGuiApplication> |
|
#include <QKeyEvent> |
|
|
|
namespace KWin |
|
{ |
|
|
|
DpmsInputEventFilter::DpmsInputEventFilter() |
|
: InputEventFilter(InputFilterOrder::Dpms) |
|
{ |
|
KSharedConfig::Ptr kwinSettings = kwinApp()->config(); |
|
m_enableDoubleTap = kwinSettings->group(QStringLiteral("Wayland")).readEntry<bool>("DoubleTapWakeup", true); |
|
if (Session *session = kwinApp()->outputBackend()->session()) { |
|
connect(session, &Session::awoke, this, &DpmsInputEventFilter::notify); |
|
} |
|
} |
|
|
|
DpmsInputEventFilter::~DpmsInputEventFilter() |
|
{ |
|
} |
|
|
|
bool DpmsInputEventFilter::pointerEvent(MouseEvent *event, quint32 nativeButton) |
|
{ |
|
if (!event->isWarp()) { |
|
// The intention is to wake the screen on user interactions |
|
// warp events aren't user interactions, so ignore them. |
|
notify(); |
|
} |
|
return true; |
|
} |
|
|
|
bool DpmsInputEventFilter::wheelEvent(WheelEvent *event) |
|
{ |
|
notify(); |
|
return true; |
|
} |
|
|
|
bool DpmsInputEventFilter::keyEvent(KeyEvent *event) |
|
{ |
|
if (isMediaKey(event->key())) { |
|
// don't wake up the screens for media or volume keys |
|
return false; |
|
} |
|
if (event->type() == QKeyEvent::KeyPress) { |
|
notify(); |
|
} else if (event->type() == QKeyEvent::KeyRelease) { |
|
return false; |
|
} |
|
return true; |
|
} |
|
|
|
bool DpmsInputEventFilter::touchDown(qint32 id, const QPointF &pos, std::chrono::microseconds time) |
|
{ |
|
if (m_enableDoubleTap) { |
|
if (m_touchPoints.isEmpty()) { |
|
if (!m_doubleTapTimer.isValid()) { |
|
// this is the first tap |
|
m_doubleTapTimer.start(); |
|
} else { |
|
if (m_doubleTapTimer.elapsed() < qApp->doubleClickInterval()) { |
|
m_secondTap = true; |
|
} else { |
|
// took too long. Let's consider it a new click |
|
m_doubleTapTimer.restart(); |
|
} |
|
} |
|
} else { |
|
// not a double tap |
|
m_doubleTapTimer.invalidate(); |
|
m_secondTap = false; |
|
} |
|
m_touchPoints << id; |
|
} |
|
return true; |
|
} |
|
|
|
bool DpmsInputEventFilter::touchUp(qint32 id, std::chrono::microseconds time) |
|
{ |
|
if (m_enableDoubleTap) { |
|
m_touchPoints.removeAll(id); |
|
if (m_touchPoints.isEmpty() && m_doubleTapTimer.isValid() && m_secondTap) { |
|
if (m_doubleTapTimer.elapsed() < qApp->doubleClickInterval()) { |
|
waylandServer()->seat()->setTimestamp(std::chrono::duration_cast<std::chrono::milliseconds>(time)); |
|
notify(); |
|
} |
|
m_doubleTapTimer.invalidate(); |
|
m_secondTap = false; |
|
} |
|
} |
|
return true; |
|
} |
|
|
|
bool DpmsInputEventFilter::touchMotion(qint32 id, const QPointF &pos, std::chrono::microseconds time) |
|
{ |
|
// ignore the event |
|
return true; |
|
} |
|
|
|
bool DpmsInputEventFilter::tabletToolEvent(TabletEvent *event) |
|
{ |
|
if (event->type() == QEvent::TabletPress) { |
|
// Only wake when the tool is actually pressed down not just hovered over the tablet |
|
notify(); |
|
} |
|
return true; |
|
} |
|
|
|
bool DpmsInputEventFilter::tabletToolButtonEvent(uint button, bool pressed, const TabletToolId &tabletToolId, std::chrono::microseconds time) |
|
{ |
|
if (pressed) { |
|
notify(); |
|
} |
|
return true; |
|
} |
|
|
|
bool DpmsInputEventFilter::tabletPadButtonEvent(uint button, bool pressed, const TabletPadId &tabletPadId, std::chrono::microseconds time) |
|
{ |
|
if (pressed) { |
|
notify(); |
|
} |
|
return true; |
|
} |
|
|
|
bool DpmsInputEventFilter::tabletPadStripEvent(int number, int position, bool isFinger, const TabletPadId &tabletPadId, std::chrono::microseconds time) |
|
{ |
|
notify(); |
|
return true; |
|
} |
|
|
|
bool DpmsInputEventFilter::tabletPadRingEvent(int number, int position, bool isFinger, const TabletPadId &tabletPadId, std::chrono::microseconds time) |
|
{ |
|
notify(); |
|
return true; |
|
} |
|
|
|
void DpmsInputEventFilter::notify() |
|
{ |
|
const QList<Output *> outputs = workspace()->outputs(); |
|
for (Output *output : outputs) { |
|
output->setDpmsMode(Output::DpmsMode::On); |
|
} |
|
} |
|
|
|
} |
|
#include "moc_dpmsinputeventfilter.cpp"
|
|
|