2013-04-03 10:19:27 +00:00
|
|
|
/********************************************************************
|
|
|
|
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_SCREENS_H
|
|
|
|
#define KWIN_SCREENS_H
|
|
|
|
|
|
|
|
// KWin includes
|
|
|
|
#include <kwinglobals.h>
|
|
|
|
// KDE includes
|
2014-03-17 15:24:10 +00:00
|
|
|
#include <KConfig>
|
2014-03-18 13:37:01 +00:00
|
|
|
#include <KSharedConfig>
|
2013-04-03 10:19:27 +00:00
|
|
|
// Qt includes
|
|
|
|
#include <QObject>
|
|
|
|
#include <QRect>
|
2013-04-21 18:18:18 +00:00
|
|
|
#include <QTimer>
|
2015-11-20 15:11:35 +00:00
|
|
|
#include <QVector>
|
2013-04-03 10:19:27 +00:00
|
|
|
|
|
|
|
namespace KWin
|
|
|
|
{
|
2015-03-05 13:07:20 +00:00
|
|
|
class AbstractClient;
|
2016-04-07 07:18:10 +00:00
|
|
|
class Platform;
|
2013-04-03 10:19:27 +00:00
|
|
|
|
2015-05-05 15:58:09 +00:00
|
|
|
class KWIN_EXPORT Screens : public QObject
|
2013-04-03 10:19:27 +00:00
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
Q_PROPERTY(int count READ count WRITE setCount NOTIFY countChanged)
|
2013-12-11 10:13:47 +00:00
|
|
|
Q_PROPERTY(int current READ current WRITE setCurrent NOTIFY currentChanged)
|
2013-04-03 10:19:27 +00:00
|
|
|
Q_PROPERTY(bool currentFollowsMouse READ isCurrentFollowsMouse WRITE setCurrentFollowsMouse)
|
|
|
|
|
|
|
|
public:
|
|
|
|
virtual ~Screens();
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
**/
|
|
|
|
void setConfig(KSharedConfig::Ptr config);
|
|
|
|
int count() const;
|
|
|
|
int current() const;
|
|
|
|
void setCurrent(int current);
|
|
|
|
/**
|
|
|
|
* Called e.g. when a user clicks on a window, set current screen to be the screen
|
|
|
|
* where the click occurred
|
|
|
|
*/
|
|
|
|
void setCurrent(const QPoint &pos);
|
|
|
|
/**
|
|
|
|
* Check whether a client moved completely out of what's considered the current screen,
|
|
|
|
* if yes, set a new active screen.
|
|
|
|
*/
|
2015-03-05 13:07:20 +00:00
|
|
|
void setCurrent(const AbstractClient *c);
|
2013-04-03 10:19:27 +00:00
|
|
|
bool isCurrentFollowsMouse() const;
|
|
|
|
void setCurrentFollowsMouse(bool follows);
|
|
|
|
virtual QRect geometry(int screen) const = 0;
|
2014-02-27 08:55:45 +00:00
|
|
|
/**
|
|
|
|
* The bounding geometry of all screens combined. Overlapping areas
|
|
|
|
* are not counted multiple times.
|
|
|
|
* @see geometryChanged()
|
|
|
|
**/
|
|
|
|
QRect geometry() const;
|
2015-05-09 10:22:31 +00:00
|
|
|
/**
|
|
|
|
* The output name of the screen (usually eg. LVDS-1, VGA-0 or DVI-I-1 etc.)
|
|
|
|
*/
|
|
|
|
virtual QString name(int screen) const;
|
2015-05-08 20:57:13 +00:00
|
|
|
/**
|
|
|
|
* @returns current refreshrate of the @p screen.
|
|
|
|
**/
|
|
|
|
virtual float refreshRate(int screen) const;
|
2014-02-27 08:55:45 +00:00
|
|
|
/**
|
|
|
|
* @returns size of the @p screen.
|
|
|
|
*
|
|
|
|
* To get the size of all screens combined use size().
|
|
|
|
* @see size()
|
|
|
|
**/
|
|
|
|
virtual QSize size(int screen) const = 0;
|
2016-10-25 23:36:02 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* The output scale for this display, for use by high DPI displays
|
|
|
|
*/
|
|
|
|
virtual qreal scale(int screen) const;
|
2014-02-27 08:55:45 +00:00
|
|
|
/**
|
|
|
|
* The bounding size of all screens combined. Overlapping areas
|
|
|
|
* are not counted multiple times.
|
|
|
|
*
|
|
|
|
* @see geometry()
|
|
|
|
* @see sizeChanged()
|
|
|
|
**/
|
|
|
|
QSize size() const;
|
2013-04-03 10:19:27 +00:00
|
|
|
virtual int number(const QPoint &pos) const = 0;
|
|
|
|
|
2013-07-31 10:55:00 +00:00
|
|
|
inline bool isChanging() { return m_changedTimer->isActive(); }
|
|
|
|
|
2013-09-23 21:04:17 +00:00
|
|
|
int intersecting(const QRect &r) const;
|
|
|
|
|
2016-06-08 10:46:02 +00:00
|
|
|
/**
|
|
|
|
* The virtual bounding size of all screens combined.
|
|
|
|
* The default implementation returns the same as @link{size} and that is the
|
|
|
|
* method which should be preferred.
|
|
|
|
*
|
|
|
|
* This method is only for cases where the platform specific implementation needs
|
|
|
|
* to support different virtual sizes like on X11 with XRandR panning.
|
|
|
|
*
|
|
|
|
* @see size
|
|
|
|
**/
|
|
|
|
virtual QSize displaySize() const;
|
|
|
|
|
2013-04-03 10:19:27 +00:00
|
|
|
public Q_SLOTS:
|
|
|
|
void reconfigure();
|
|
|
|
|
|
|
|
Q_SIGNALS:
|
|
|
|
void countChanged(int previousCount, int newCount);
|
|
|
|
/**
|
|
|
|
* Emitted whenever the screens are changed either count or geometry.
|
|
|
|
**/
|
|
|
|
void changed();
|
2013-12-11 10:13:47 +00:00
|
|
|
void currentChanged();
|
2014-02-27 08:55:45 +00:00
|
|
|
/**
|
|
|
|
* Emitted when the geometry of all screens combined changes.
|
|
|
|
* Not emitted when the geometry of an individual screen changes.
|
|
|
|
* @see geometry()
|
|
|
|
**/
|
|
|
|
void geometryChanged();
|
|
|
|
/**
|
|
|
|
* Emitted when the size of all screens combined changes.
|
|
|
|
* Not emitted when the size of an individual screen changes.
|
|
|
|
* @see size()
|
|
|
|
**/
|
|
|
|
void sizeChanged();
|
2013-04-03 10:19:27 +00:00
|
|
|
|
|
|
|
protected Q_SLOTS:
|
|
|
|
void setCount(int count);
|
|
|
|
void startChangedTimer();
|
2013-04-21 18:18:18 +00:00
|
|
|
virtual void updateCount() = 0;
|
2013-04-03 10:19:27 +00:00
|
|
|
|
2014-02-27 08:55:45 +00:00
|
|
|
protected:
|
|
|
|
/**
|
|
|
|
* Called once the singleton instance has been created.
|
|
|
|
* Any initialization code should go into this method. Overriding classes have to call
|
|
|
|
* the base implementation first.
|
|
|
|
**/
|
|
|
|
virtual void init();
|
|
|
|
|
|
|
|
private Q_SLOTS:
|
|
|
|
void updateSize();
|
|
|
|
|
2013-04-03 10:19:27 +00:00
|
|
|
private:
|
|
|
|
int m_count;
|
|
|
|
int m_current;
|
|
|
|
bool m_currentFollowsMouse;
|
2013-07-31 10:55:00 +00:00
|
|
|
QTimer *m_changedTimer;
|
2013-04-03 10:19:27 +00:00
|
|
|
KSharedConfig::Ptr m_config;
|
2014-02-27 08:55:45 +00:00
|
|
|
QSize m_boundingSize;
|
2013-04-03 10:19:27 +00:00
|
|
|
|
|
|
|
KWIN_SINGLETON(Screens)
|
|
|
|
};
|
|
|
|
|
2015-11-17 09:32:06 +00:00
|
|
|
/**
|
|
|
|
* @brief A base implementation for backends with just a (nested) window
|
|
|
|
**/
|
|
|
|
class KWIN_EXPORT BasicScreens : public Screens
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
public:
|
2016-04-07 07:18:10 +00:00
|
|
|
BasicScreens(Platform *backend, QObject *parent = nullptr);
|
2015-11-17 09:32:06 +00:00
|
|
|
virtual ~BasicScreens();
|
|
|
|
|
|
|
|
void init() override;
|
|
|
|
QRect geometry(int screen) const override;
|
|
|
|
int number(const QPoint &pos) const override;
|
|
|
|
QSize size(int screen) const override;
|
2016-10-25 23:36:02 +00:00
|
|
|
qreal scale(int screen) const override;
|
2015-11-17 09:32:06 +00:00
|
|
|
void updateCount() override;
|
|
|
|
|
|
|
|
private:
|
2016-04-07 07:18:10 +00:00
|
|
|
Platform *m_backend;
|
2015-11-20 15:11:35 +00:00
|
|
|
QVector<QRect> m_geometries;
|
2016-10-25 23:36:02 +00:00
|
|
|
QVector<qreal> m_scales;
|
2015-11-17 09:32:06 +00:00
|
|
|
};
|
|
|
|
|
2013-04-03 10:19:27 +00:00
|
|
|
inline
|
|
|
|
void Screens::setConfig(KSharedConfig::Ptr config)
|
|
|
|
{
|
|
|
|
m_config = config;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline
|
|
|
|
int Screens::count() const
|
|
|
|
{
|
|
|
|
return m_count;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline
|
|
|
|
bool Screens::isCurrentFollowsMouse() const
|
|
|
|
{
|
|
|
|
return m_currentFollowsMouse;
|
|
|
|
}
|
|
|
|
|
2013-04-21 18:18:18 +00:00
|
|
|
inline
|
|
|
|
void Screens::startChangedTimer()
|
|
|
|
{
|
|
|
|
m_changedTimer->start();
|
|
|
|
}
|
|
|
|
|
2014-02-27 08:55:45 +00:00
|
|
|
inline
|
|
|
|
QSize Screens::size() const
|
|
|
|
{
|
|
|
|
return m_boundingSize;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline
|
|
|
|
QRect Screens::geometry() const
|
|
|
|
{
|
|
|
|
return QRect(QPoint(0,0), size());
|
|
|
|
}
|
|
|
|
|
2013-04-03 10:19:27 +00:00
|
|
|
inline
|
|
|
|
Screens *screens()
|
|
|
|
{
|
|
|
|
return Screens::self();
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // KWIN_SCREENS_H
|