2021-02-04 09:07:20 +00:00
|
|
|
/*
|
|
|
|
SPDX-FileCopyrightText: 2021 Vlad Zahorodnii <vlad.zahorodnii@kde.org>
|
|
|
|
|
|
|
|
SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "item.h"
|
|
|
|
|
|
|
|
namespace KDecoration2
|
|
|
|
{
|
|
|
|
class Decoration;
|
|
|
|
}
|
|
|
|
|
|
|
|
namespace KWin
|
|
|
|
{
|
2022-04-22 17:39:12 +00:00
|
|
|
class Window;
|
2021-04-26 16:38:40 +00:00
|
|
|
class DecorationItem;
|
2021-08-12 09:07:38 +00:00
|
|
|
class Deleted;
|
2022-04-22 17:45:19 +00:00
|
|
|
class InternalWindow;
|
2021-08-12 09:07:38 +00:00
|
|
|
class Shadow;
|
|
|
|
class ShadowItem;
|
|
|
|
class SurfaceItem;
|
2021-02-04 09:07:20 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The WindowItem class represents a window in the scene.
|
|
|
|
*
|
|
|
|
* A WindowItem is made of a surface with client contents and optionally a server-side frame
|
|
|
|
* and a drop-shadow.
|
|
|
|
*/
|
|
|
|
class KWIN_EXPORT WindowItem : public Item
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
2022-04-27 09:22:23 +00:00
|
|
|
enum {
|
|
|
|
PAINT_DISABLED_BY_HIDDEN = 1 << 0,
|
|
|
|
PAINT_DISABLED_BY_DELETE = 1 << 1,
|
|
|
|
PAINT_DISABLED_BY_DESKTOP = 1 << 2,
|
|
|
|
PAINT_DISABLED_BY_MINIMIZE = 1 << 3,
|
|
|
|
PAINT_DISABLED_BY_ACTIVITY = 1 << 5
|
|
|
|
};
|
|
|
|
|
2022-05-09 15:47:12 +00:00
|
|
|
~WindowItem() override;
|
|
|
|
|
2021-02-04 09:07:20 +00:00
|
|
|
SurfaceItem *surfaceItem() const;
|
|
|
|
DecorationItem *decorationItem() const;
|
|
|
|
ShadowItem *shadowItem() const;
|
2022-04-22 17:39:12 +00:00
|
|
|
Window *window() const;
|
2021-02-04 09:07:20 +00:00
|
|
|
|
2022-04-27 09:22:23 +00:00
|
|
|
void refVisible(int reason);
|
|
|
|
void unrefVisible(int reason);
|
|
|
|
|
2021-02-04 09:07:20 +00:00
|
|
|
protected:
|
2022-04-22 17:39:12 +00:00
|
|
|
explicit WindowItem(Window *window, Item *parent = nullptr);
|
2021-02-04 09:07:20 +00:00
|
|
|
void updateSurfaceItem(SurfaceItem *surfaceItem);
|
|
|
|
|
|
|
|
private Q_SLOTS:
|
2022-04-22 17:39:12 +00:00
|
|
|
void handleWindowClosed(Window *original, Deleted *deleted);
|
2021-02-04 09:07:20 +00:00
|
|
|
void updateDecorationItem();
|
2021-09-03 10:24:17 +00:00
|
|
|
void updateShadowItem();
|
2021-02-04 09:07:20 +00:00
|
|
|
void updateSurfacePosition();
|
2021-05-26 09:27:27 +00:00
|
|
|
void updateSurfaceVisibility();
|
2022-05-09 15:47:12 +00:00
|
|
|
void updatePosition();
|
2022-05-05 12:56:36 +00:00
|
|
|
void updateOpacity();
|
2021-02-04 09:07:20 +00:00
|
|
|
|
|
|
|
private:
|
2022-04-27 09:22:23 +00:00
|
|
|
bool computeVisibility() const;
|
|
|
|
void updateVisibility();
|
|
|
|
|
2022-04-22 17:39:12 +00:00
|
|
|
Window *m_window;
|
2021-02-04 09:07:20 +00:00
|
|
|
QScopedPointer<SurfaceItem> m_surfaceItem;
|
|
|
|
QScopedPointer<DecorationItem> m_decorationItem;
|
|
|
|
QScopedPointer<ShadowItem> m_shadowItem;
|
2022-04-27 09:22:23 +00:00
|
|
|
int m_forceVisibleByHiddenCount = 0;
|
|
|
|
int m_forceVisibleByDeleteCount = 0;
|
|
|
|
int m_forceVisibleByDesktopCount = 0;
|
|
|
|
int m_forceVisibleByMinimizeCount = 0;
|
|
|
|
int m_forceVisibleByActivityCount = 0;
|
2021-02-04 09:07:20 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The WindowItemX11 class represents an X11 window (both on X11 and Wayland sessions).
|
|
|
|
*
|
|
|
|
* Note that Xwayland windows and Wayland surfaces are associated asynchronously. This means
|
|
|
|
* that the surfaceItem() function can return @c null until the window is fully initialized.
|
|
|
|
*/
|
|
|
|
class KWIN_EXPORT WindowItemX11 : public WindowItem
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
2022-04-22 17:39:12 +00:00
|
|
|
explicit WindowItemX11(Window *window, Item *parent = nullptr);
|
2021-02-04 09:07:20 +00:00
|
|
|
|
|
|
|
private Q_SLOTS:
|
|
|
|
void initialize();
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The WindowItemWayland class represents a Wayland window.
|
|
|
|
*/
|
|
|
|
class KWIN_EXPORT WindowItemWayland : public WindowItem
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
2022-04-22 17:39:12 +00:00
|
|
|
explicit WindowItemWayland(Window *window, Item *parent = nullptr);
|
2021-02-04 09:07:20 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The WindowItemInternal class represents a window created by the compositor, for
|
|
|
|
* example, the task switcher, etc.
|
|
|
|
*/
|
|
|
|
class KWIN_EXPORT WindowItemInternal : public WindowItem
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
2022-04-22 17:45:19 +00:00
|
|
|
explicit WindowItemInternal(InternalWindow *window, Item *parent = nullptr);
|
2021-02-04 09:07:20 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace KWin
|