forked from qt-creator/qt-creator
Factor an overlay widget out of progress indicator
The principle of having a widget on top of all other children of the same parent, for the purpose of painting an overlay, is generic. Change-Id: I6d3ee89cc51354988fedcc40340bb45a065db607 Reviewed-by: David Schulz <david.schulz@qt.io>
This commit is contained in:
@@ -96,6 +96,7 @@ add_qtc_library(Utils
|
|||||||
osspecificaspects.h
|
osspecificaspects.h
|
||||||
outputformat.h
|
outputformat.h
|
||||||
outputformatter.cpp outputformatter.h
|
outputformatter.cpp outputformatter.h
|
||||||
|
overlaywidget.cpp overlaywidget.h
|
||||||
overridecursor.cpp overridecursor.h
|
overridecursor.cpp overridecursor.h
|
||||||
parameteraction.cpp parameteraction.h
|
parameteraction.cpp parameteraction.h
|
||||||
pathchooser.cpp pathchooser.h
|
pathchooser.cpp pathchooser.h
|
||||||
|
76
src/libs/utils/overlaywidget.cpp
Normal file
76
src/libs/utils/overlaywidget.cpp
Normal file
@@ -0,0 +1,76 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
**
|
||||||
|
** Copyright (C) 2020 The Qt Company Ltd.
|
||||||
|
** Contact: https://www.qt.io/licensing/
|
||||||
|
**
|
||||||
|
** This file is part of Qt Creator.
|
||||||
|
**
|
||||||
|
** Commercial License Usage
|
||||||
|
** Licensees holding valid commercial Qt licenses may use this file in
|
||||||
|
** accordance with the commercial license agreement provided with the
|
||||||
|
** Software or, alternatively, in accordance with the terms contained in
|
||||||
|
** a written agreement between you and The Qt Company. For licensing terms
|
||||||
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
||||||
|
** information use the contact form at https://www.qt.io/contact-us.
|
||||||
|
**
|
||||||
|
** GNU General Public License Usage
|
||||||
|
** Alternatively, this file may be used under the terms of the GNU
|
||||||
|
** General Public License version 3 as published by the Free Software
|
||||||
|
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
||||||
|
** included in the packaging of this file. Please review the following
|
||||||
|
** information to ensure the GNU General Public License requirements will
|
||||||
|
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
||||||
|
**
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include "overlaywidget.h"
|
||||||
|
|
||||||
|
#include "qtcassert.h"
|
||||||
|
|
||||||
|
#include <QEvent>
|
||||||
|
#include <QPainter>
|
||||||
|
|
||||||
|
Utils::OverlayWidget::OverlayWidget(QWidget *parent)
|
||||||
|
{
|
||||||
|
setAttribute(Qt::WA_TransparentForMouseEvents);
|
||||||
|
if (parent)
|
||||||
|
attachToWidget(parent);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Utils::OverlayWidget::setPaintFunction(const Utils::OverlayWidget::PaintFunction &paint)
|
||||||
|
{
|
||||||
|
m_paint = paint;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Utils::OverlayWidget::eventFilter(QObject *obj, QEvent *ev)
|
||||||
|
{
|
||||||
|
if (obj == parent() && ev->type() == QEvent::Resize)
|
||||||
|
resizeToParent();
|
||||||
|
return QWidget::eventFilter(obj, ev);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Utils::OverlayWidget::paintEvent(QPaintEvent *ev)
|
||||||
|
{
|
||||||
|
if (m_paint) {
|
||||||
|
QPainter p(this);
|
||||||
|
m_paint(this, p, ev);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Utils::OverlayWidget::attachToWidget(QWidget *parent)
|
||||||
|
{
|
||||||
|
if (parentWidget())
|
||||||
|
parentWidget()->removeEventFilter(this);
|
||||||
|
setParent(parent);
|
||||||
|
if (parent) {
|
||||||
|
parent->installEventFilter(this);
|
||||||
|
resizeToParent();
|
||||||
|
raise();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Utils::OverlayWidget::resizeToParent()
|
||||||
|
{
|
||||||
|
QTC_ASSERT(parentWidget(), return );
|
||||||
|
setGeometry(QRect(QPoint(0, 0), parentWidget()->size()));
|
||||||
|
}
|
55
src/libs/utils/overlaywidget.h
Normal file
55
src/libs/utils/overlaywidget.h
Normal file
@@ -0,0 +1,55 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
**
|
||||||
|
** Copyright (C) 2020 The Qt Company Ltd.
|
||||||
|
** Contact: https://www.qt.io/licensing/
|
||||||
|
**
|
||||||
|
** This file is part of Qt Creator.
|
||||||
|
**
|
||||||
|
** Commercial License Usage
|
||||||
|
** Licensees holding valid commercial Qt licenses may use this file in
|
||||||
|
** accordance with the commercial license agreement provided with the
|
||||||
|
** Software or, alternatively, in accordance with the terms contained in
|
||||||
|
** a written agreement between you and The Qt Company. For licensing terms
|
||||||
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
||||||
|
** information use the contact form at https://www.qt.io/contact-us.
|
||||||
|
**
|
||||||
|
** GNU General Public License Usage
|
||||||
|
** Alternatively, this file may be used under the terms of the GNU
|
||||||
|
** General Public License version 3 as published by the Free Software
|
||||||
|
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
||||||
|
** included in the packaging of this file. Please review the following
|
||||||
|
** information to ensure the GNU General Public License requirements will
|
||||||
|
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
||||||
|
**
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "utils_global.h"
|
||||||
|
|
||||||
|
#include <QWidget>
|
||||||
|
|
||||||
|
namespace Utils {
|
||||||
|
|
||||||
|
class QTCREATOR_UTILS_EXPORT OverlayWidget : public QWidget
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
using PaintFunction = std::function<void(QWidget *, QPainter &, QPaintEvent *)>;
|
||||||
|
|
||||||
|
explicit OverlayWidget(QWidget *parent = nullptr);
|
||||||
|
|
||||||
|
void attachToWidget(QWidget *parent);
|
||||||
|
void setPaintFunction(const PaintFunction &paint);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
bool eventFilter(QObject *obj, QEvent *ev) override;
|
||||||
|
void paintEvent(QPaintEvent *ev) override;
|
||||||
|
|
||||||
|
private:
|
||||||
|
void resizeToParent();
|
||||||
|
|
||||||
|
PaintFunction m_paint;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace Utils
|
@@ -220,9 +220,11 @@ void ProgressIndicatorPainter::nextAnimationStep()
|
|||||||
\sa setIndicatorSize
|
\sa setIndicatorSize
|
||||||
*/
|
*/
|
||||||
ProgressIndicator::ProgressIndicator(ProgressIndicatorSize size, QWidget *parent)
|
ProgressIndicator::ProgressIndicator(ProgressIndicatorSize size, QWidget *parent)
|
||||||
: QWidget(parent), m_paint(size)
|
: OverlayWidget(parent)
|
||||||
|
, m_paint(size)
|
||||||
{
|
{
|
||||||
setAttribute(Qt::WA_TransparentForMouseEvents);
|
setPaintFunction(
|
||||||
|
[this](QWidget *w, QPainter &p, QPaintEvent *) { m_paint.paint(p, w->rect()); });
|
||||||
m_paint.setUpdateCallback([this]() { update(); });
|
m_paint.setUpdateCallback([this]() { update(); });
|
||||||
updateGeometry();
|
updateGeometry();
|
||||||
}
|
}
|
||||||
@@ -248,29 +250,6 @@ QSize ProgressIndicator::sizeHint() const
|
|||||||
return m_paint.size();
|
return m_paint.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
|
||||||
Makes the indicator a child of \a parent, automatically centering on it,
|
|
||||||
and adapting to size changes.
|
|
||||||
*/
|
|
||||||
void ProgressIndicator::attachToWidget(QWidget *parent)
|
|
||||||
{
|
|
||||||
if (parentWidget())
|
|
||||||
parentWidget()->removeEventFilter(this);
|
|
||||||
setParent(parent);
|
|
||||||
parent->installEventFilter(this);
|
|
||||||
resizeToParent();
|
|
||||||
raise();
|
|
||||||
}
|
|
||||||
|
|
||||||
/*!
|
|
||||||
\internal
|
|
||||||
*/
|
|
||||||
void ProgressIndicator::paintEvent(QPaintEvent *)
|
|
||||||
{
|
|
||||||
QPainter p(this);
|
|
||||||
m_paint.paint(p, rect());
|
|
||||||
}
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\internal
|
\internal
|
||||||
*/
|
*/
|
||||||
@@ -287,24 +266,4 @@ void ProgressIndicator::hideEvent(QHideEvent *)
|
|||||||
m_paint.stopAnimation();
|
m_paint.stopAnimation();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
|
||||||
\internal
|
|
||||||
*/
|
|
||||||
bool ProgressIndicator::eventFilter(QObject *obj, QEvent *ev)
|
|
||||||
{
|
|
||||||
if (obj == parent() && ev->type() == QEvent::Resize) {
|
|
||||||
resizeToParent();
|
|
||||||
}
|
|
||||||
return QWidget::eventFilter(obj, ev);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*!
|
|
||||||
\internal
|
|
||||||
*/
|
|
||||||
void ProgressIndicator::resizeToParent()
|
|
||||||
{
|
|
||||||
QTC_ASSERT(parentWidget(), return);
|
|
||||||
setGeometry(QRect(QPoint(0, 0), parentWidget()->size()));
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace Utils
|
} // namespace Utils
|
||||||
|
@@ -25,6 +25,7 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include "overlaywidget.h"
|
||||||
#include "utils_global.h"
|
#include "utils_global.h"
|
||||||
|
|
||||||
#include <QTimer>
|
#include <QTimer>
|
||||||
@@ -76,7 +77,7 @@ private:
|
|||||||
UpdateCallback m_callback;
|
UpdateCallback m_callback;
|
||||||
};
|
};
|
||||||
|
|
||||||
class QTCREATOR_UTILS_EXPORT ProgressIndicator : public QWidget
|
class QTCREATOR_UTILS_EXPORT ProgressIndicator : public OverlayWidget
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
@@ -86,17 +87,11 @@ public:
|
|||||||
|
|
||||||
QSize sizeHint() const final;
|
QSize sizeHint() const final;
|
||||||
|
|
||||||
void attachToWidget(QWidget *parent);
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void paintEvent(QPaintEvent *) final;
|
|
||||||
void showEvent(QShowEvent *) final;
|
void showEvent(QShowEvent *) final;
|
||||||
void hideEvent(QHideEvent *) final;
|
void hideEvent(QHideEvent *) final;
|
||||||
bool eventFilter(QObject *obj, QEvent *ev) final;
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void resizeToParent();
|
|
||||||
|
|
||||||
ProgressIndicatorPainter m_paint;
|
ProgressIndicatorPainter m_paint;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@@ -132,7 +132,8 @@ SOURCES += \
|
|||||||
$$PWD/jsontreeitem.cpp \
|
$$PWD/jsontreeitem.cpp \
|
||||||
$$PWD/namevaluevalidator.cpp \
|
$$PWD/namevaluevalidator.cpp \
|
||||||
$$PWD/camelcasecursor.cpp \
|
$$PWD/camelcasecursor.cpp \
|
||||||
$$PWD/infolabel.cpp
|
$$PWD/infolabel.cpp \
|
||||||
|
$$PWD/overlaywidget.cpp
|
||||||
|
|
||||||
HEADERS += \
|
HEADERS += \
|
||||||
$$PWD/environmentfwd.h \
|
$$PWD/environmentfwd.h \
|
||||||
@@ -279,7 +280,8 @@ HEADERS += \
|
|||||||
$$PWD/listmodel.h \
|
$$PWD/listmodel.h \
|
||||||
$$PWD/namevaluevalidator.h \
|
$$PWD/namevaluevalidator.h \
|
||||||
$$PWD/camelcasecursor.h \
|
$$PWD/camelcasecursor.h \
|
||||||
$$PWD/infolabel.h
|
$$PWD/infolabel.h \
|
||||||
|
$$PWD/overlaywidget.h
|
||||||
|
|
||||||
FORMS += $$PWD/filewizardpage.ui \
|
FORMS += $$PWD/filewizardpage.ui \
|
||||||
$$PWD/projectintropage.ui \
|
$$PWD/projectintropage.ui \
|
||||||
|
@@ -176,6 +176,8 @@ Project {
|
|||||||
"outputformat.h",
|
"outputformat.h",
|
||||||
"outputformatter.cpp",
|
"outputformatter.cpp",
|
||||||
"outputformatter.h",
|
"outputformatter.h",
|
||||||
|
"overlaywidget.cpp",
|
||||||
|
"overlaywidget.h",
|
||||||
"overridecursor.cpp",
|
"overridecursor.cpp",
|
||||||
"overridecursor.h",
|
"overridecursor.h",
|
||||||
"parameteraction.cpp",
|
"parameteraction.cpp",
|
||||||
|
Reference in New Issue
Block a user