diff --git a/CMakeLists.txt b/CMakeLists.txt index a176c2f237..a3b0862c6c 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -410,6 +410,7 @@ set(kwin_KDEINIT_SRCS killwindow.cpp geometrytip.cpp screens.cpp + outputscreens.cpp shadow.cpp sm.cpp group.cpp diff --git a/outputscreens.cpp b/outputscreens.cpp new file mode 100644 index 0000000000..d6dd84ae3e --- /dev/null +++ b/outputscreens.cpp @@ -0,0 +1,132 @@ +/******************************************************************** + KWin - the KDE window manager + This file is part of the KDE project. + +Copyright 2018 Roman Gilg + +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 . +*********************************************************************/ +#include "outputscreens.h" +#include "platform.h" +#include "abstract_output.h" + +namespace KWin +{ + +OutputScreens::OutputScreens(Platform *platform, QObject *parent) + : Screens(parent), + m_platform(platform) +{ +} + +OutputScreens::~OutputScreens() = default; + +void OutputScreens::init() +{ + updateCount(); + KWin::Screens::init(); + emit changed(); +} + +QString OutputScreens::name(int screen) const +{ + const auto enOuts = m_platform->enabledOutputs(); + if (screen >= enOuts.size()) { + return Screens::name(screen); + } + return enOuts.at(screen)->name(); +} + +bool OutputScreens::isInternal(int screen) const +{ + const auto enOuts = m_platform->enabledOutputs(); + if (screen >= enOuts.size()) { + return false; + } + return enOuts.at(screen)->isInternal(); +} + +QRect OutputScreens::geometry(int screen) const +{ + const auto enOuts = m_platform->enabledOutputs(); + if (screen >= enOuts.size()) { + return QRect(); + } + return enOuts.at(screen)->geometry(); +} + +QSize OutputScreens::size(int screen) const +{ + const auto enOuts = m_platform->enabledOutputs(); + if (screen >= enOuts.size()) { + return QSize(); + } + return enOuts.at(screen)->geometry().size(); +} + +qreal OutputScreens::scale(int screen) const +{ + const auto enOuts = m_platform->enabledOutputs(); + if (screen >= enOuts.size()) { + return 1; + } + return enOuts.at(screen)->scale(); +} + +QSizeF OutputScreens::physicalSize(int screen) const +{ + const auto enOuts = m_platform->enabledOutputs(); + if (screen >= enOuts.size()) { + return Screens::physicalSize(screen); + } + return enOuts.at(screen)->physicalSize(); +} + +Qt::ScreenOrientation OutputScreens::orientation(int screen) const +{ + const auto enOuts = m_platform->enabledOutputs(); + if (screen >= enOuts.size()) { + return Qt::PrimaryOrientation; + } + return enOuts.at(screen)->orientation(); +} + +void OutputScreens::updateCount() +{ + setCount(m_platform->enabledOutputs().size()); +} + +int OutputScreens::number(const QPoint &pos) const +{ + int bestScreen = 0; + int minDistance = INT_MAX; + const auto enOuts = m_platform->enabledOutputs(); + for (int i = 0; i < enOuts.size(); ++i) { + const QRect &geo = enOuts.at(i)->geometry(); + if (geo.contains(pos)) { + return i; + } + int distance = QPoint(geo.topLeft() - pos).manhattanLength(); + distance = qMin(distance, QPoint(geo.topRight() - pos).manhattanLength()); + distance = qMin(distance, QPoint(geo.bottomRight() - pos).manhattanLength()); + distance = qMin(distance, QPoint(geo.bottomLeft() - pos).manhattanLength()); + if (distance < minDistance) { + minDistance = distance; + bestScreen = i; + } + } + return bestScreen; +} + +} // namespace diff --git a/outputscreens.h b/outputscreens.h new file mode 100644 index 0000000000..4d31acb264 --- /dev/null +++ b/outputscreens.h @@ -0,0 +1,55 @@ +/******************************************************************** + KWin - the KDE window manager + This file is part of the KDE project. + +Copyright 2018 Roman Gilg + +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 . +*********************************************************************/ +#ifndef KWIN_OUTPUTSCREENS_H +#define KWIN_OUTPUTSCREENS_H + +#include "screens.h" + +namespace KWin +{ + +/** + * @brief Implementation for backends with Outputs + **/ +class KWIN_EXPORT OutputScreens : public Screens +{ + Q_OBJECT +public: + OutputScreens(Platform *platform, QObject *parent = nullptr); + virtual ~OutputScreens(); + + void init() override; + QString name(int screen) const override; + bool isInternal(int screen) const; + QSizeF physicalSize(int screen) const; + QRect geometry(int screen) const override; + QSize size(int screen) const override; + qreal scale(int screen) const override; + Qt::ScreenOrientation orientation(int screen) const; + void updateCount() override; + int number(const QPoint &pos) const override; + +protected: + Platform *m_platform; +}; + +} + +#endif // KWIN_OUTPUTSCREENS_H diff --git a/plugins/platforms/drm/screens_drm.cpp b/plugins/platforms/drm/screens_drm.cpp index 418fab2a83..2fa1f51860 100644 --- a/plugins/platforms/drm/screens_drm.cpp +++ b/plugins/platforms/drm/screens_drm.cpp @@ -25,7 +25,7 @@ namespace KWin { DrmScreens::DrmScreens(DrmBackend *backend, QObject *parent) - : Screens(parent) + : OutputScreens(backend, parent) , m_backend(backend) { connect(backend, &DrmBackend::screensQueried, this, &DrmScreens::updateCount); @@ -34,120 +34,22 @@ DrmScreens::DrmScreens(DrmBackend *backend, QObject *parent) DrmScreens::~DrmScreens() = default; -void DrmScreens::init() -{ - updateCount(); - KWin::Screens::init(); - emit changed(); -} - -QRect DrmScreens::geometry(int screen) const -{ - const auto outputs = m_backend->enabledOutputs(); - if (screen >= outputs.size()) { - return QRect(); - } - return outputs.at(screen)->geometry(); -} - -qreal DrmScreens::scale(int screen) const -{ - const auto outputs = m_backend->enabledOutputs(); - if (screen >= outputs.size()) { - return 1; - } - return outputs.at(screen)->scale(); -} - -QSize DrmScreens::size(int screen) const -{ - const auto outputs = m_backend->enabledOutputs(); - if (screen >= outputs.size()) { - return QSize(); - } - return outputs.at(screen)->geometry().size(); -} - -void DrmScreens::updateCount() -{ - setCount(m_backend->drmEnabledOutputs().size()); -} - -int DrmScreens::number(const QPoint &pos) const -{ - int bestScreen = 0; - int minDistance = INT_MAX; - const auto outputs = m_backend->drmEnabledOutputs(); - for (int i = 0; i < outputs.size(); ++i) { - auto o = outputs.at(i); - const QRect &geo = o->geometry(); - if (geo.contains(pos)) { - return i; - } - int distance = QPoint(geo.topLeft() - pos).manhattanLength(); - distance = qMin(distance, QPoint(geo.topRight() - pos).manhattanLength()); - distance = qMin(distance, QPoint(geo.bottomRight() - pos).manhattanLength()); - distance = qMin(distance, QPoint(geo.bottomLeft() - pos).manhattanLength()); - if (distance < minDistance) { - minDistance = distance; - bestScreen = i; - } - } - return bestScreen; -} - -QString DrmScreens::name(int screen) const -{ - const auto outputs = m_backend->drmEnabledOutputs(); - if (screen >= outputs.size()) { - return Screens::name(screen); - } - return outputs.at(screen)->name(); -} - float DrmScreens::refreshRate(int screen) const { - const auto outputs = m_backend->drmEnabledOutputs(); - if (screen >= outputs.size()) { + const auto enOuts = m_backend->drmEnabledOutputs(); + if (screen >= enOuts.size()) { return Screens::refreshRate(screen); } - return outputs.at(screen)->currentRefreshRate() / 1000.0f; -} - -QSizeF DrmScreens::physicalSize(int screen) const -{ - const auto outputs = m_backend->drmEnabledOutputs(); - if (screen >= outputs.size()) { - return Screens::physicalSize(screen); - } - return outputs.at(screen)->physicalSize(); -} - -bool DrmScreens::isInternal(int screen) const -{ - const auto outputs = m_backend->drmEnabledOutputs(); - if (screen >= outputs.size()) { - return false; - } - return outputs.at(screen)->isInternal(); + return enOuts.at(screen)->currentRefreshRate() / 1000.0f; } bool DrmScreens::supportsTransformations(int screen) const { - const auto outputs = m_backend->drmEnabledOutputs(); - if (screen >= outputs.size()) { + const auto enOuts = m_backend->drmEnabledOutputs(); + if (screen >= enOuts.size()) { return false; } - return outputs.at(screen)->supportsTransformations(); -} - -Qt::ScreenOrientation DrmScreens::orientation(int screen) const -{ - const auto outputs = m_backend->drmOutputs(); - if (screen >= outputs.size()) { - return Qt::PrimaryOrientation; - } - return outputs.at(screen)->orientation(); + return enOuts.at(screen)->supportsTransformations(); } } diff --git a/plugins/platforms/drm/screens_drm.h b/plugins/platforms/drm/screens_drm.h index b3bf7e3a6e..208b242e26 100644 --- a/plugins/platforms/drm/screens_drm.h +++ b/plugins/platforms/drm/screens_drm.h @@ -19,33 +19,22 @@ along with this program. If not, see . *********************************************************************/ #ifndef KWIN_SCREENS_DRM_H #define KWIN_SCREENS_DRM_H -#include "screens.h" +#include "outputscreens.h" namespace KWin { class DrmBackend; -class DrmScreens : public Screens +class DrmScreens : public OutputScreens { Q_OBJECT public: DrmScreens(DrmBackend *backend, QObject *parent = nullptr); virtual ~DrmScreens(); - void init() override; - QRect geometry(int screen) const override; - int number(const QPoint &pos) const override; - qreal scale(int screen) const override; - QSize size(int screen) const override; - void updateCount() override; - QString name(int screen) const override; + float refreshRate(int screen) const override; - - QSizeF physicalSize(int screen) const override; - bool isInternal(int screen) const override; bool supportsTransformations(int screen) const override; - Qt::ScreenOrientation orientation(int screen) const override; -private: DrmBackend *m_backend; };