2007-11-27 19:40:25 +00:00
|
|
|
/********************************************************************
|
2007-04-29 17:35:43 +00:00
|
|
|
KWin - the KDE window manager
|
|
|
|
This file is part of the KDE project.
|
|
|
|
|
|
|
|
Copyright (C) 2006 Lubos Lunak <l.lunak@kde.org>
|
|
|
|
|
2007-11-27 19:40:25 +00:00
|
|
|
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/>.
|
|
|
|
*********************************************************************/
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
#ifndef KWIN_LIB_KWINGLOBALS_H
|
|
|
|
#define KWIN_LIB_KWINGLOBALS_H
|
|
|
|
|
2015-02-19 08:59:21 +00:00
|
|
|
#include <QCoreApplication>
|
2016-10-17 14:12:21 +00:00
|
|
|
#include <QImage>
|
|
|
|
#include <QPoint>
|
2015-02-19 08:59:21 +00:00
|
|
|
#include <QVariant>
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2013-12-06 07:37:16 +00:00
|
|
|
#include <kwin_export.h>
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2013-02-26 07:14:17 +00:00
|
|
|
#include <xcb/xcb.h>
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2007-12-17 14:14:53 +00:00
|
|
|
#include <kwinconfig.h>
|
|
|
|
|
2013-07-22 14:15:42 +00:00
|
|
|
#define KWIN_QT5_PORTING 0
|
2008-01-16 18:13:24 +00:00
|
|
|
|
2007-04-29 17:35:43 +00:00
|
|
|
namespace KWin
|
|
|
|
{
|
2019-11-01 17:14:55 +00:00
|
|
|
KWIN_EXPORT Q_NAMESPACE
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2011-01-30 14:34:42 +00:00
|
|
|
enum CompositingType {
|
2007-04-29 17:35:43 +00:00
|
|
|
NoCompositing = 0,
|
2012-09-20 09:33:32 +00:00
|
|
|
/**
|
|
|
|
* Used as a flag whether OpenGL based compositing is used.
|
|
|
|
* The flag is or-ed to the enum values of the specific OpenGL types.
|
2014-02-25 10:02:32 +00:00
|
|
|
* The actual Compositors use the or @c OpenGL2Compositing
|
2012-09-20 09:33:32 +00:00
|
|
|
* flags. If you need to know whether OpenGL is used, either and the flag or
|
|
|
|
* use EffectsHandler::isOpenGLCompositing().
|
2019-07-29 18:58:33 +00:00
|
|
|
*/
|
2012-09-20 09:33:32 +00:00
|
|
|
OpenGLCompositing = 1,
|
|
|
|
XRenderCompositing = 1<<1,
|
2013-06-21 08:03:31 +00:00
|
|
|
QPainterCompositing = 1<< 2,
|
2012-09-20 09:33:32 +00:00
|
|
|
OpenGL2Compositing = 1<<3 | OpenGLCompositing
|
2007-04-29 17:35:43 +00:00
|
|
|
};
|
|
|
|
|
2012-09-29 11:19:35 +00:00
|
|
|
enum OpenGLPlatformInterface {
|
|
|
|
NoOpenGLPlatformInterface = 0,
|
|
|
|
GlxPlatformInterface,
|
|
|
|
EglPlatformInterface
|
|
|
|
};
|
|
|
|
|
2011-01-30 14:34:42 +00:00
|
|
|
enum clientAreaOption {
|
2007-04-29 17:35:43 +00:00
|
|
|
PlacementArea, // geometry where a window will be initially placed after being mapped
|
|
|
|
MovementArea, // ??? window movement snapping area? ignore struts
|
|
|
|
MaximizeArea, // geometry to which a window will be maximized
|
|
|
|
MaximizeFullArea, // like MaximizeArea, but ignore struts - used e.g. for topmenu
|
|
|
|
FullScreenArea, // area for fullscreen windows
|
|
|
|
// these below don't depend on xinerama settings
|
|
|
|
WorkArea, // whole workarea (all screens together)
|
|
|
|
FullArea, // whole area (all screens together), ignore struts
|
|
|
|
ScreenArea // one whole screen, ignore struts
|
|
|
|
};
|
|
|
|
|
2011-01-30 14:34:42 +00:00
|
|
|
enum ElectricBorder {
|
2007-04-29 17:35:43 +00:00
|
|
|
ElectricTop,
|
|
|
|
ElectricTopRight,
|
|
|
|
ElectricRight,
|
|
|
|
ElectricBottomRight,
|
|
|
|
ElectricBottom,
|
|
|
|
ElectricBottomLeft,
|
|
|
|
ElectricLeft,
|
|
|
|
ElectricTopLeft,
|
|
|
|
ELECTRIC_COUNT,
|
|
|
|
ElectricNone
|
|
|
|
};
|
|
|
|
|
2009-02-28 08:33:16 +00:00
|
|
|
// TODO: Hardcoding is bad, need to add some way of registering global actions to these.
|
|
|
|
// When designing the new system we must keep in mind that we have conditional actions
|
|
|
|
// such as "only when moving windows" desktop switching that the current global action
|
|
|
|
// system doesn't support.
|
2011-01-30 14:34:42 +00:00
|
|
|
enum ElectricBorderAction {
|
2009-02-28 08:33:16 +00:00
|
|
|
ElectricActionNone, // No special action, not set, desktop switch or an effect
|
2009-06-28 20:32:50 +00:00
|
|
|
ElectricActionShowDesktop, // Show desktop or restore
|
2010-03-10 22:25:20 +00:00
|
|
|
ElectricActionLockScreen, // Lock screen
|
2016-04-07 19:07:41 +00:00
|
|
|
ElectricActionKRunner, // Open KRunner
|
|
|
|
ElectricActionActivityManager, // Activity Manager
|
2016-08-10 13:07:54 +00:00
|
|
|
ElectricActionApplicationLauncher, // Application Launcher
|
2009-02-28 08:33:16 +00:00
|
|
|
ELECTRIC_ACTION_COUNT
|
|
|
|
};
|
|
|
|
|
2007-04-29 17:35:43 +00:00
|
|
|
// DesktopMode and WindowsMode are based on the order in which the desktop
|
|
|
|
// or window were viewed.
|
|
|
|
// DesktopListMode lists them in the order created.
|
2011-01-30 14:34:42 +00:00
|
|
|
enum TabBoxMode {
|
2012-04-25 20:57:48 +00:00
|
|
|
TabBoxDesktopMode, // Focus chain of desktops
|
|
|
|
TabBoxDesktopListMode, // Static desktop order
|
|
|
|
TabBoxWindowsMode, // Primary window switching mode
|
|
|
|
TabBoxWindowsAlternativeMode, // Secondary window switching mode
|
|
|
|
TabBoxCurrentAppWindowsMode, // Same as primary window switching mode but only for windows of current application
|
2012-06-06 22:38:13 +00:00
|
|
|
TabBoxCurrentAppWindowsAlternativeMode // Same as secondary switching mode but only for windows of current application
|
2009-09-13 11:36:45 +00:00
|
|
|
};
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2011-04-25 15:04:04 +00:00
|
|
|
enum KWinOption {
|
2013-01-30 12:36:37 +00:00
|
|
|
CloseButtonCorner,
|
|
|
|
SwitchDesktopOnScreenEdge,
|
|
|
|
SwitchDesktopOnScreenEdgeMovingWindows
|
2011-04-25 15:04:04 +00:00
|
|
|
};
|
|
|
|
|
2013-07-15 09:26:56 +00:00
|
|
|
/**
|
|
|
|
* @brief The direction in which a pointer axis is moved.
|
2019-07-29 18:58:33 +00:00
|
|
|
*/
|
2013-07-15 09:26:56 +00:00
|
|
|
enum PointerAxisDirection {
|
|
|
|
PointerAxisUp,
|
|
|
|
PointerAxisDown,
|
|
|
|
PointerAxisLeft,
|
|
|
|
PointerAxisRight
|
|
|
|
};
|
|
|
|
|
2017-03-18 10:00:30 +00:00
|
|
|
/**
|
|
|
|
* @brief Directions for swipe gestures
|
|
|
|
* @since 5.10
|
2019-07-29 18:58:33 +00:00
|
|
|
*/
|
2017-03-18 10:00:30 +00:00
|
|
|
enum class SwipeDirection {
|
|
|
|
Invalid,
|
|
|
|
Down,
|
|
|
|
Left,
|
|
|
|
Up,
|
|
|
|
Right
|
|
|
|
};
|
|
|
|
|
2019-10-31 16:16:53 +00:00
|
|
|
/**
|
|
|
|
* Represents the state of the session running outside kwin
|
|
|
|
* Under Plasma this is managed by ksmserver
|
|
|
|
*/
|
|
|
|
enum class SessionState {
|
|
|
|
Normal,
|
|
|
|
Saving,
|
|
|
|
Quitting
|
|
|
|
};
|
2019-11-01 17:14:55 +00:00
|
|
|
Q_ENUM_NS(SessionState)
|
2019-10-31 16:16:53 +00:00
|
|
|
|
2012-03-26 15:14:04 +00:00
|
|
|
inline
|
|
|
|
KWIN_EXPORT xcb_connection_t *connection()
|
|
|
|
{
|
2014-01-08 10:43:02 +00:00
|
|
|
static xcb_connection_t *s_con = nullptr;
|
2013-02-14 07:39:56 +00:00
|
|
|
if (!s_con) {
|
2015-02-18 10:19:04 +00:00
|
|
|
s_con = reinterpret_cast<xcb_connection_t*>(qApp->property("x11Connection").value<void*>());
|
2013-02-14 07:39:56 +00:00
|
|
|
}
|
2016-05-09 14:01:49 +00:00
|
|
|
Q_ASSERT(qApp);
|
2013-02-14 07:39:56 +00:00
|
|
|
return s_con;
|
2012-03-26 15:14:04 +00:00
|
|
|
}
|
|
|
|
|
2007-04-29 17:35:43 +00:00
|
|
|
inline
|
2013-02-26 07:14:17 +00:00
|
|
|
KWIN_EXPORT xcb_window_t rootWindow()
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2013-08-02 06:31:53 +00:00
|
|
|
static xcb_window_t s_rootWindow = XCB_WINDOW_NONE;
|
|
|
|
if (s_rootWindow == XCB_WINDOW_NONE) {
|
2015-02-18 07:31:53 +00:00
|
|
|
s_rootWindow = qApp->property("x11RootWindow").value<quint32>();
|
2013-08-02 06:31:53 +00:00
|
|
|
}
|
|
|
|
return s_rootWindow;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline
|
2013-02-26 07:14:17 +00:00
|
|
|
KWIN_EXPORT xcb_timestamp_t xTime()
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2015-02-19 08:59:21 +00:00
|
|
|
return qApp->property("x11Time").value<xcb_timestamp_t>();
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2013-02-26 07:14:17 +00:00
|
|
|
inline
|
|
|
|
KWIN_EXPORT xcb_screen_t *defaultScreen()
|
|
|
|
{
|
2014-01-08 10:43:02 +00:00
|
|
|
static xcb_screen_t *s_screen = nullptr;
|
2013-02-26 07:14:17 +00:00
|
|
|
if (s_screen) {
|
|
|
|
return s_screen;
|
|
|
|
}
|
2015-02-18 10:52:51 +00:00
|
|
|
int screen = qApp->property("x11ScreenNumber").toInt();
|
2013-02-26 07:14:17 +00:00
|
|
|
for (xcb_screen_iterator_t it = xcb_setup_roots_iterator(xcb_get_setup(connection()));
|
|
|
|
it.rem;
|
|
|
|
--screen, xcb_screen_next(&it)) {
|
|
|
|
if (screen == 0) {
|
|
|
|
s_screen = it.data;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return s_screen;
|
|
|
|
}
|
|
|
|
|
2007-04-29 17:35:43 +00:00
|
|
|
inline
|
2017-09-01 19:37:42 +00:00
|
|
|
KWIN_DEPRECATED_EXPORT int displayWidth()
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2013-02-26 07:14:17 +00:00
|
|
|
xcb_screen_t *screen = defaultScreen();
|
|
|
|
return screen ? screen->width_in_pixels : 0;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline
|
2017-09-01 19:37:42 +00:00
|
|
|
KWIN_DEPRECATED_EXPORT int displayHeight()
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2013-02-26 07:14:17 +00:00
|
|
|
xcb_screen_t *screen = defaultScreen();
|
|
|
|
return screen ? screen->height_in_pixels : 0;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2016-10-17 14:12:21 +00:00
|
|
|
/**
|
|
|
|
* Short wrapper for a cursor image provided by the Platform.
|
|
|
|
* @since 5.9
|
2019-07-29 18:58:33 +00:00
|
|
|
*/
|
2016-10-17 14:12:21 +00:00
|
|
|
class PlatformCursorImage {
|
|
|
|
public:
|
|
|
|
explicit PlatformCursorImage()
|
|
|
|
: m_image()
|
|
|
|
, m_hotSpot()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
explicit PlatformCursorImage(const QImage &image, const QPoint &hotSpot)
|
|
|
|
: m_image(image)
|
|
|
|
, m_hotSpot(hotSpot)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
virtual ~PlatformCursorImage() = default;
|
|
|
|
|
2020-05-18 19:37:41 +00:00
|
|
|
bool isNull() const {
|
|
|
|
return m_image.isNull();
|
|
|
|
}
|
2016-10-17 14:12:21 +00:00
|
|
|
QImage image() const {
|
|
|
|
return m_image;
|
|
|
|
}
|
|
|
|
QPoint hotSpot() const {
|
|
|
|
return m_hotSpot;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
QImage m_image;
|
|
|
|
QPoint m_hotSpot;
|
|
|
|
};
|
|
|
|
|
2007-04-29 17:35:43 +00:00
|
|
|
} // namespace
|
|
|
|
|
2013-04-05 07:41:25 +00:00
|
|
|
#define KWIN_SINGLETON_VARIABLE(ClassName, variableName) \
|
|
|
|
public: \
|
2014-01-08 10:43:02 +00:00
|
|
|
static ClassName *create(QObject *parent = nullptr);\
|
2013-04-05 07:41:25 +00:00
|
|
|
static ClassName *self() { return variableName; }\
|
|
|
|
protected: \
|
2014-01-08 10:43:02 +00:00
|
|
|
explicit ClassName(QObject *parent = nullptr); \
|
2013-04-05 07:41:25 +00:00
|
|
|
private: \
|
|
|
|
static ClassName *variableName;
|
|
|
|
|
|
|
|
#define KWIN_SINGLETON(ClassName) KWIN_SINGLETON_VARIABLE(ClassName, s_self)
|
|
|
|
|
|
|
|
#define KWIN_SINGLETON_FACTORY_VARIABLE_FACTORED(ClassName, FactoredClassName, variableName) \
|
2014-01-08 10:43:02 +00:00
|
|
|
ClassName *ClassName::variableName = nullptr; \
|
2013-04-05 07:41:25 +00:00
|
|
|
ClassName *ClassName::create(QObject *parent) \
|
|
|
|
{ \
|
|
|
|
Q_ASSERT(!variableName); \
|
|
|
|
variableName = new FactoredClassName(parent); \
|
|
|
|
return variableName; \
|
|
|
|
}
|
|
|
|
#define KWIN_SINGLETON_FACTORY_VARIABLE(ClassName, variableName) KWIN_SINGLETON_FACTORY_VARIABLE_FACTORED(ClassName, ClassName, variableName)
|
|
|
|
#define KWIN_SINGLETON_FACTORY_FACTORED(ClassName, FactoredClassName) KWIN_SINGLETON_FACTORY_VARIABLE_FACTORED(ClassName, FactoredClassName, s_self)
|
|
|
|
#define KWIN_SINGLETON_FACTORY(ClassName) KWIN_SINGLETON_FACTORY_VARIABLE(ClassName, s_self)
|
|
|
|
|
2007-04-29 17:35:43 +00:00
|
|
|
#endif
|