diff --git a/src/widget/tool/screenshotgrabber.cpp b/src/widget/tool/screenshotgrabber.cpp index 3122264a0..e75b19d71 100644 --- a/src/widget/tool/screenshotgrabber.cpp +++ b/src/widget/tool/screenshotgrabber.cpp @@ -38,6 +38,7 @@ ScreenshotGrabber::ScreenshotGrabber(QObject* parent) : QObject(parent) , scene(0) + , mQToxVisible(true) { window = new QGraphicsView (scene); // Top-level widget window->setAttribute(Qt::WA_DeleteOnClose); @@ -208,6 +209,29 @@ QPixmap ScreenshotGrabber::grabScreen() rec.height()); } +void ScreenshotGrabber::hideVisibleWindows() +{ + foreach(QWidget* w, qApp->topLevelWidgets()) { + if (w != window && w->isVisible()) { + mHiddenWindows << w; + w->setVisible(false); + } + } + + mQToxVisible = false; +} + +void ScreenshotGrabber::restoreHiddenWindows() +{ + foreach(QWidget* w, mHiddenWindows) { + if (w) + w->setVisible(true); + } + + mHiddenWindows.clear(); + mQToxVisible = true; +} + void ScreenshotGrabber::beginRectChooser(QGraphicsSceneMouseEvent* event) { QPointF pos = event->scenePos(); diff --git a/src/widget/tool/screenshotgrabber.h b/src/widget/tool/screenshotgrabber.h index 2e5a5b310..33b7d7d08 100644 --- a/src/widget/tool/screenshotgrabber.h +++ b/src/widget/tool/screenshotgrabber.h @@ -21,6 +21,7 @@ #define SCREENSHOTGRABBER_H #include +#include class QGraphicsSceneMouseEvent; class QGraphicsPixmapItem; @@ -70,8 +71,12 @@ private: QPixmap grabScreen(); + void hideVisibleWindows(); + void restoreHiddenWindows(); + void beginRectChooser(QGraphicsSceneMouseEvent* event); +private: QPixmap screenGrab; QGraphicsScene* scene; QGraphicsView* window; @@ -80,6 +85,9 @@ private: ScreenGrabberChooserRectItem* chooserRect; ToolBoxGraphicsItem* helperToolbox; QGraphicsTextItem* helperTooltip; + + bool mQToxVisible; + QVector< QPointer > mHiddenWindows; };