62c4d449f5
For most actions where the compositor needs to perform an action (e.g. scheduling another repaint) signals were already emitted. So it's easier to just connect the signals to the Compositor which in turn makes the code much more readable. All signals are connected from the Workspace when either the Compositor gets constructed or a Toplevel gets created.
185 lines
5.7 KiB
C++
185 lines
5.7 KiB
C++
/********************************************************************
|
|
KWin - the KDE window manager
|
|
This file is part of the KDE project.
|
|
|
|
Copyright (C) 2011 Arthur Arlt <a.arlt@stud.uni-heidelberg.de>
|
|
Copyright (C) 2012 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_COMPOSITE_H
|
|
#define KWIN_COMPOSITE_H
|
|
|
|
#include <QtCore/QObject>
|
|
#include <QtCore/QTimer>
|
|
#include <QRegion>
|
|
|
|
class KSelectionOwner;
|
|
|
|
namespace KWin {
|
|
|
|
class Client;
|
|
class Scene;
|
|
|
|
class Compositor : public QObject {
|
|
Q_OBJECT
|
|
public:
|
|
Compositor(QObject *workspace);
|
|
~Compositor();
|
|
// when adding repaints caused by a window, you probably want to use
|
|
// either Toplevel::addRepaint() or Toplevel::addWorkspaceRepaint()
|
|
void addRepaint(const QRect& r);
|
|
void addRepaint(const QRegion& r);
|
|
void addRepaint(int x, int y, int w, int h);
|
|
/**
|
|
* Called from the D-Bus interface. Does the same as slotToggleCompositing with the
|
|
* addition to show a notification on how to revert the compositing state.
|
|
**/
|
|
void toggleCompositing();
|
|
// Mouse polling
|
|
void startMousePolling();
|
|
void stopMousePolling();
|
|
/**
|
|
* Whether the Compositor is active. That is a Scene is present and the Compositor is
|
|
* not shutting down itself.
|
|
**/
|
|
bool isActive();
|
|
int xrrRefreshRate() const {
|
|
return m_xrrRefreshRate;
|
|
}
|
|
void setCompositeResetTimer(int msecs);
|
|
// returns the _estimated_ delay to the next screen update
|
|
// good for having a rough idea to calculate transformations, bad to rely on.
|
|
// might happen few ms earlier, might be an entire frame to short. This is NOT deterministic.
|
|
int nextFrameDelay() const {
|
|
return m_nextFrameDelay;
|
|
}
|
|
bool hasScene() const {
|
|
return m_scene != NULL;
|
|
}
|
|
|
|
/**
|
|
* Checks whether @p w is the Scene's overlay window.
|
|
**/
|
|
bool checkForOverlayWindow(WId w) const;
|
|
/**
|
|
* @returns The Scene's Overlay X Window.
|
|
**/
|
|
WId overlayWindow() const;
|
|
/**
|
|
* @returns Whether the Scene's Overlay X Window is visible.
|
|
**/
|
|
bool isOverlayWindowVisible() const;
|
|
/**
|
|
* Set's the Scene's Overlay X Window visibility to @p visible.
|
|
**/
|
|
void setOverlayWindowVisibility(bool visible);
|
|
|
|
Scene *scene() {
|
|
return m_scene;
|
|
}
|
|
|
|
public Q_SLOTS:
|
|
void addRepaintFull();
|
|
/**
|
|
* Actual slot to perform the toggling compositing.
|
|
* That is if the Compositor is suspended it will be resumed and if the Compositor is active
|
|
* it will be suspended.
|
|
* Invoked primarily by the keybinding.
|
|
* TODO: make private slot
|
|
**/
|
|
void slotToggleCompositing();
|
|
/**
|
|
* Re-initializes the Compositor completely.
|
|
* Connected to the D-Bus signal org.kde.KWin /KWin reinitCompositing
|
|
**/
|
|
void slotReinitialize();
|
|
/**
|
|
* Schedules a new repaint if no repaint is currently scheduled.
|
|
**/
|
|
void scheduleRepaint();
|
|
void checkUnredirect();
|
|
void checkUnredirect(bool force);
|
|
void updateCompositeBlocking();
|
|
void updateCompositeBlocking(KWin::Client* c);
|
|
|
|
Q_SIGNALS:
|
|
void compositingToggled(bool active);
|
|
|
|
protected:
|
|
void timerEvent(QTimerEvent *te);
|
|
|
|
private Q_SLOTS:
|
|
void setup();
|
|
/**
|
|
* Called from setupCompositing() when the CompositingPrefs are ready.
|
|
**/
|
|
void slotCompositingOptionsInitialized();
|
|
void finish();
|
|
/**
|
|
* Restarts the Compositor if running.
|
|
* That is the Compositor will be stopped and started again.
|
|
**/
|
|
void restart();
|
|
void fallbackToXRenderCompositing();
|
|
void performCompositing();
|
|
void performMousePoll();
|
|
void delayedCheckUnredirect();
|
|
void slotConfigChanged();
|
|
|
|
private:
|
|
/**
|
|
* Suspends or Resumes the Compositor.
|
|
* That is stops the Scene in case of @p suspend and restores otherwise.
|
|
* @param suspend If @c true suspends the Compositor, if @c false starts the Compositor.
|
|
* TODO: split in two methods: suspend and resume
|
|
**/
|
|
void suspendResume(bool suspend = true);
|
|
void setCompositeTimer();
|
|
bool windowRepaintsPending() const;
|
|
|
|
/**
|
|
* Restarts the Window Manager in case that the Qt's GraphicsSystem need to be changed
|
|
* for the chosen Compositing backend.
|
|
* @param reason The reason why the Window Manager is being restarted, this is logged
|
|
**/
|
|
void restartKWin(const QString &reason);
|
|
|
|
/**
|
|
* Whether the Compositor is currently suspended.
|
|
**/
|
|
bool m_suspended;
|
|
/**
|
|
* Whether the Compositor is currently blocked by at least one Client requesting full resources.
|
|
**/
|
|
bool m_blocked;
|
|
QBasicTimer compositeTimer;
|
|
KSelectionOwner* cm_selection;
|
|
uint vBlankInterval, fpsInterval;
|
|
int m_xrrRefreshRate;
|
|
QElapsedTimer nextPaintReference;
|
|
QTimer mousePollingTimer;
|
|
QRegion repaints_region;
|
|
|
|
QTimer unredirectTimer;
|
|
bool forceUnredirectCheck;
|
|
QTimer compositeResetTimer; // for compressing composite resets
|
|
bool m_finishing; // finish() sets this variable while shutting down
|
|
int m_timeSinceLastVBlank, m_nextFrameDelay;
|
|
Scene *m_scene;
|
|
};
|
|
}
|
|
|
|
# endif // KWIN_COMPOSITE_H
|