forked from qt-creator/qt-creator
Extract a fading indicator widget into utils
That can show either a pixmap, or some text. Used for the wrap indicator when searching, and for the 'presentation mode' of action manager. Change-Id: I4d603fb5750d7539c50de7ef8fd6c8545293d5b9 Reviewed-by: Tobias Hunger <tobias.hunger@theqtcompany.com>
This commit is contained in:
146
src/libs/utils/fadingindicator.cpp
Normal file
146
src/libs/utils/fadingindicator.cpp
Normal file
@@ -0,0 +1,146 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
**
|
||||||
|
** Copyright (C) 2015 The Qt Company Ltd.
|
||||||
|
** Contact: http://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 http://www.qt.io/terms-conditions. For further information
|
||||||
|
** use the contact form at http://www.qt.io/contact-us.
|
||||||
|
**
|
||||||
|
** GNU Lesser General Public License Usage
|
||||||
|
** Alternatively, this file may be used under the terms of the GNU Lesser
|
||||||
|
** General Public License version 2.1 or version 3 as published by the Free
|
||||||
|
** Software Foundation and appearing in the file LICENSE.LGPLv21 and
|
||||||
|
** LICENSE.LGPLv3 included in the packaging of this file. Please review the
|
||||||
|
** following information to ensure the GNU Lesser General Public License
|
||||||
|
** requirements will be met: https://www.gnu.org/licenses/lgpl.html and
|
||||||
|
** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
|
||||||
|
**
|
||||||
|
** In addition, as a special exception, The Qt Company gives you certain additional
|
||||||
|
** rights. These rights are described in The Qt Company LGPL Exception
|
||||||
|
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
|
||||||
|
**
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include "fadingindicator.h"
|
||||||
|
|
||||||
|
#include "stylehelper.h"
|
||||||
|
|
||||||
|
#include <QGraphicsOpacityEffect>
|
||||||
|
#include <QHBoxLayout>
|
||||||
|
#include <QLabel>
|
||||||
|
#include <QPainter>
|
||||||
|
#include <QPixmap>
|
||||||
|
#include <QPropertyAnimation>
|
||||||
|
#include <QTimer>
|
||||||
|
|
||||||
|
namespace Utils {
|
||||||
|
namespace Internal {
|
||||||
|
|
||||||
|
class FadingIndicatorPrivate : public QWidget
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
FadingIndicatorPrivate(QWidget *parent = 0)
|
||||||
|
: QWidget(parent)
|
||||||
|
{
|
||||||
|
m_effect = new QGraphicsOpacityEffect(this);
|
||||||
|
setGraphicsEffect(m_effect);
|
||||||
|
m_effect->setOpacity(1.);
|
||||||
|
|
||||||
|
m_label = new QLabel;
|
||||||
|
QFont font = m_label->font();
|
||||||
|
font.setPixelSize(45);
|
||||||
|
m_label->setFont(font);
|
||||||
|
QPalette pal = palette();
|
||||||
|
pal.setColor(QPalette::Foreground, pal.color(QPalette::Background));
|
||||||
|
m_label->setPalette(pal);
|
||||||
|
auto layout = new QHBoxLayout;
|
||||||
|
setLayout(layout);
|
||||||
|
layout->addWidget(m_label);
|
||||||
|
}
|
||||||
|
|
||||||
|
void setText(const QString &text)
|
||||||
|
{
|
||||||
|
m_pixmap = QPixmap();
|
||||||
|
m_label->setText(text);
|
||||||
|
adjustSize();
|
||||||
|
if (QWidget *parent = parentWidget())
|
||||||
|
move(parent->rect().center() - rect().center());
|
||||||
|
}
|
||||||
|
|
||||||
|
void setPixmap(const QString &uri)
|
||||||
|
{
|
||||||
|
m_label->hide();
|
||||||
|
m_pixmap.load(Utils::StyleHelper::dpiSpecificImageFile(uri));
|
||||||
|
resize(m_pixmap.size() / m_pixmap.devicePixelRatio());
|
||||||
|
if (QWidget *parent = parentWidget())
|
||||||
|
move(parent->rect().center() - rect().center());
|
||||||
|
}
|
||||||
|
|
||||||
|
void run(int ms)
|
||||||
|
{
|
||||||
|
show();
|
||||||
|
raise();
|
||||||
|
QTimer::singleShot(ms, this, SLOT(runInternal()));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
void paintEvent(QPaintEvent *)
|
||||||
|
{
|
||||||
|
QPainter p(this);
|
||||||
|
p.setRenderHint(QPainter::Antialiasing);
|
||||||
|
if (!m_pixmap.isNull()) {
|
||||||
|
p.drawPixmap(rect(), m_pixmap);
|
||||||
|
} else {
|
||||||
|
p.setBrush(palette().color(QPalette::Foreground));
|
||||||
|
p.setPen(Qt::NoPen);
|
||||||
|
p.drawRoundedRect(rect(), 15, 15);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private slots:
|
||||||
|
void runInternal()
|
||||||
|
{
|
||||||
|
QPropertyAnimation *anim = new QPropertyAnimation(m_effect, "opacity", this);
|
||||||
|
anim->setDuration(200);
|
||||||
|
anim->setEndValue(0.);
|
||||||
|
connect(anim, SIGNAL(finished()), this, SLOT(deleteLater()));
|
||||||
|
anim->start(QAbstractAnimation::DeleteWhenStopped);
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
QGraphicsOpacityEffect *m_effect;
|
||||||
|
QLabel *m_label;
|
||||||
|
QPixmap m_pixmap;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // Internal
|
||||||
|
|
||||||
|
namespace FadingIndicator {
|
||||||
|
|
||||||
|
void showText(QWidget *parent, const QString &text)
|
||||||
|
{
|
||||||
|
auto indicator = new Internal::FadingIndicatorPrivate(parent);
|
||||||
|
indicator->setText(text);
|
||||||
|
indicator->run(1000); // deletes itself
|
||||||
|
}
|
||||||
|
|
||||||
|
void showPixmap(QWidget *parent, const QString &pixmap)
|
||||||
|
{
|
||||||
|
auto indicator = new Internal::FadingIndicatorPrivate(parent);
|
||||||
|
indicator->setPixmap(pixmap);
|
||||||
|
indicator->run(300); // deletes itself
|
||||||
|
}
|
||||||
|
|
||||||
|
} // FadingIndicator
|
||||||
|
} // Utils
|
||||||
|
|
||||||
|
#include "fadingindicator.moc"
|
50
src/libs/utils/fadingindicator.h
Normal file
50
src/libs/utils/fadingindicator.h
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
**
|
||||||
|
** Copyright (C) 2015 The Qt Company Ltd.
|
||||||
|
** Contact: http://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 http://www.qt.io/terms-conditions. For further information
|
||||||
|
** use the contact form at http://www.qt.io/contact-us.
|
||||||
|
**
|
||||||
|
** GNU Lesser General Public License Usage
|
||||||
|
** Alternatively, this file may be used under the terms of the GNU Lesser
|
||||||
|
** General Public License version 2.1 or version 3 as published by the Free
|
||||||
|
** Software Foundation and appearing in the file LICENSE.LGPLv21 and
|
||||||
|
** LICENSE.LGPLv3 included in the packaging of this file. Please review the
|
||||||
|
** following information to ensure the GNU Lesser General Public License
|
||||||
|
** requirements will be met: https://www.gnu.org/licenses/lgpl.html and
|
||||||
|
** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
|
||||||
|
**
|
||||||
|
** In addition, as a special exception, The Qt Company gives you certain additional
|
||||||
|
** rights. These rights are described in The Qt Company LGPL Exception
|
||||||
|
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
|
||||||
|
**
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FADINGINDICATOR_H
|
||||||
|
#define FADINGINDICATOR_H
|
||||||
|
|
||||||
|
#include "utils_global.h"
|
||||||
|
|
||||||
|
#include <QString>
|
||||||
|
#include <QWidget>
|
||||||
|
|
||||||
|
namespace Utils {
|
||||||
|
namespace FadingIndicator {
|
||||||
|
|
||||||
|
QTCREATOR_UTILS_EXPORT void showText(QWidget *parent, const QString &text);
|
||||||
|
QTCREATOR_UTILS_EXPORT void showPixmap(QWidget *parent, const QString &pixmap);
|
||||||
|
|
||||||
|
} // FadingIndicator
|
||||||
|
} // Utils
|
||||||
|
|
||||||
|
#endif // FADINGINDICATOR_H
|
||||||
|
|
@@ -92,7 +92,8 @@ SOURCES += $$PWD/environment.cpp \
|
|||||||
$$PWD/proxycredentialsdialog.cpp \
|
$$PWD/proxycredentialsdialog.cpp \
|
||||||
$$PWD/macroexpander.cpp \
|
$$PWD/macroexpander.cpp \
|
||||||
$$PWD/theme/theme.cpp \
|
$$PWD/theme/theme.cpp \
|
||||||
$$PWD/progressindicator.cpp
|
$$PWD/progressindicator.cpp \
|
||||||
|
$$PWD/fadingindicator.cpp
|
||||||
|
|
||||||
win32:SOURCES += $$PWD/consoleprocess_win.cpp
|
win32:SOURCES += $$PWD/consoleprocess_win.cpp
|
||||||
else:SOURCES += $$PWD/consoleprocess_unix.cpp
|
else:SOURCES += $$PWD/consoleprocess_unix.cpp
|
||||||
@@ -190,7 +191,8 @@ HEADERS += \
|
|||||||
$$PWD/macroexpander.h \
|
$$PWD/macroexpander.h \
|
||||||
$$PWD/theme/theme.h \
|
$$PWD/theme/theme.h \
|
||||||
$$PWD/theme/theme_p.h \
|
$$PWD/theme/theme_p.h \
|
||||||
$$PWD/progressindicator.h
|
$$PWD/progressindicator.h \
|
||||||
|
$$PWD/fadingindicator.h
|
||||||
|
|
||||||
FORMS += $$PWD/filewizardpage.ui \
|
FORMS += $$PWD/filewizardpage.ui \
|
||||||
$$PWD/projectintropage.ui \
|
$$PWD/projectintropage.ui \
|
||||||
|
@@ -72,6 +72,8 @@ QtcLibrary {
|
|||||||
"environmentmodel.h",
|
"environmentmodel.h",
|
||||||
"execmenu.cpp",
|
"execmenu.cpp",
|
||||||
"execmenu.h",
|
"execmenu.h",
|
||||||
|
"fadingindicator.cpp",
|
||||||
|
"fadingindicator.h",
|
||||||
"faketooltip.cpp",
|
"faketooltip.cpp",
|
||||||
"faketooltip.h",
|
"faketooltip.h",
|
||||||
"fancylineedit.cpp",
|
"fancylineedit.cpp",
|
||||||
|
@@ -35,13 +35,13 @@
|
|||||||
|
|
||||||
#include <coreplugin/icore.h>
|
#include <coreplugin/icore.h>
|
||||||
#include <coreplugin/id.h>
|
#include <coreplugin/id.h>
|
||||||
|
#include <utils/fadingindicator.h>
|
||||||
#include <utils/qtcassert.h>
|
#include <utils/qtcassert.h>
|
||||||
|
|
||||||
#include <QAction>
|
#include <QAction>
|
||||||
#include <QApplication>
|
#include <QApplication>
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
#include <QDesktopWidget>
|
#include <QDesktopWidget>
|
||||||
#include <QLabel>
|
|
||||||
#include <QMenu>
|
#include <QMenu>
|
||||||
#include <QMenuBar>
|
#include <QMenuBar>
|
||||||
#include <QSettings>
|
#include <QSettings>
|
||||||
@@ -354,26 +354,12 @@ void ActionManager::setPresentationModeEnabled(bool enabled)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// The label for the shortcuts:
|
d->m_presentationModeEnabled = enabled;
|
||||||
if (!d->m_presentationLabel) {
|
|
||||||
d->m_presentationLabel = new QLabel(0, Qt::ToolTip | Qt::WindowStaysOnTopHint);
|
|
||||||
QFont font = d->m_presentationLabel->font();
|
|
||||||
font.setPixelSize(45);
|
|
||||||
d->m_presentationLabel->setFont(font);
|
|
||||||
d->m_presentationLabel->setAlignment(Qt::AlignCenter);
|
|
||||||
d->m_presentationLabel->setMargin(5);
|
|
||||||
|
|
||||||
connect(&d->m_presentationLabelTimer, SIGNAL(timeout()), d->m_presentationLabel, SLOT(hide()));
|
|
||||||
} else {
|
|
||||||
d->m_presentationLabelTimer.stop();
|
|
||||||
delete d->m_presentationLabel;
|
|
||||||
d->m_presentationLabel = 0;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ActionManager::isPresentationModeEnabled()
|
bool ActionManager::isPresentationModeEnabled()
|
||||||
{
|
{
|
||||||
return d->m_presentationLabel;
|
return d->m_presentationModeEnabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ActionManager::initialize(QObject *parent)
|
void ActionManager::initialize(QObject *parent)
|
||||||
@@ -399,9 +385,8 @@ void ActionManager::setContext(const Context &context)
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
ActionManagerPrivate::ActionManagerPrivate()
|
ActionManagerPrivate::ActionManagerPrivate()
|
||||||
: m_presentationLabel(0)
|
: m_presentationModeEnabled(false)
|
||||||
{
|
{
|
||||||
m_presentationLabelTimer.setInterval(1000);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ActionManagerPrivate::~ActionManagerPrivate()
|
ActionManagerPrivate::~ActionManagerPrivate()
|
||||||
@@ -459,25 +444,18 @@ void ActionManagerPrivate::showShortcutPopup(const QString &shortcut)
|
|||||||
if (shortcut.isEmpty() || !ActionManager::isPresentationModeEnabled())
|
if (shortcut.isEmpty() || !ActionManager::isPresentationModeEnabled())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
m_presentationLabel->setText(shortcut);
|
|
||||||
m_presentationLabel->adjustSize();
|
|
||||||
|
|
||||||
QWidget *window = QApplication::activeWindow();
|
QWidget *window = QApplication::activeWindow();
|
||||||
if (!window && !QApplication::topLevelWidgets().isEmpty())
|
if (!window) {
|
||||||
window = QApplication::topLevelWidgets().first();
|
if (!QApplication::topLevelWidgets().isEmpty()) {
|
||||||
QPoint center;
|
window = QApplication::topLevelWidgets().first();
|
||||||
if (window) {
|
} else {
|
||||||
center = window->mapToGlobal(window->rect().center());
|
QTC_ASSERT(QApplication::desktop(), return);
|
||||||
} else {
|
window = QApplication::desktop()->screen();
|
||||||
QTC_ASSERT(QApplication::desktop(), return);
|
QTC_ASSERT(window, return);
|
||||||
center = QApplication::desktop()->screenGeometry().center();
|
}
|
||||||
}
|
}
|
||||||
QPoint p = center - m_presentationLabel->rect().center();
|
|
||||||
m_presentationLabel->move(p);
|
|
||||||
|
|
||||||
m_presentationLabel->show();
|
Utils::FadingIndicator::showText(window, shortcut);
|
||||||
m_presentationLabel->raise();
|
|
||||||
m_presentationLabelTimer.start();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Action *ActionManagerPrivate::overridableAction(Id id)
|
Action *ActionManagerPrivate::overridableAction(Id id)
|
||||||
|
@@ -89,6 +89,7 @@ public:
|
|||||||
|
|
||||||
Context m_context;
|
Context m_context;
|
||||||
|
|
||||||
|
bool m_presentationModeEnabled;
|
||||||
QLabel *m_presentationLabel;
|
QLabel *m_presentationLabel;
|
||||||
QTimer m_presentationLabelTimer;
|
QTimer m_presentationLabelTimer;
|
||||||
};
|
};
|
||||||
|
@@ -30,64 +30,7 @@
|
|||||||
|
|
||||||
#include "ifindsupport.h"
|
#include "ifindsupport.h"
|
||||||
|
|
||||||
#include <QTimer>
|
#include <utils/fadingindicator.h>
|
||||||
#include <QPropertyAnimation>
|
|
||||||
#include <QWidget>
|
|
||||||
#include <QPaintEvent>
|
|
||||||
#include <QPainter>
|
|
||||||
|
|
||||||
namespace Core {
|
|
||||||
namespace Internal {
|
|
||||||
|
|
||||||
class WrapIndicator : public QWidget
|
|
||||||
{
|
|
||||||
Q_OBJECT
|
|
||||||
Q_PROPERTY(qreal opacity READ opacity WRITE setOpacity USER true)
|
|
||||||
|
|
||||||
public:
|
|
||||||
WrapIndicator(QWidget *parent = 0)
|
|
||||||
: QWidget(parent),
|
|
||||||
m_opacity(1.0)
|
|
||||||
{
|
|
||||||
if (parent)
|
|
||||||
setGeometry(QRect(parent->rect().center() - QPoint(25, 25),
|
|
||||||
parent->rect().center() + QPoint(25, 25)));
|
|
||||||
}
|
|
||||||
|
|
||||||
qreal opacity() const { return m_opacity; }
|
|
||||||
void setOpacity(qreal value) { m_opacity = value; update(); }
|
|
||||||
|
|
||||||
void run()
|
|
||||||
{
|
|
||||||
show();
|
|
||||||
QTimer::singleShot(300, this, SLOT(runInternal()));
|
|
||||||
}
|
|
||||||
|
|
||||||
protected:
|
|
||||||
void paintEvent(QPaintEvent *)
|
|
||||||
{
|
|
||||||
static QPixmap foreground(QLatin1String(":/find/images/wrapindicator.png"));
|
|
||||||
QPainter p(this);
|
|
||||||
p.setOpacity(m_opacity);
|
|
||||||
p.drawPixmap(rect(), foreground);
|
|
||||||
}
|
|
||||||
|
|
||||||
private slots:
|
|
||||||
void runInternal()
|
|
||||||
{
|
|
||||||
QPropertyAnimation *anim = new QPropertyAnimation(this, "opacity", this);
|
|
||||||
anim->setDuration(200);
|
|
||||||
anim->setEndValue(0.);
|
|
||||||
connect(anim, SIGNAL(finished()), this, SLOT(deleteLater()));
|
|
||||||
anim->start(QAbstractAnimation::DeleteWhenStopped);
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
qreal m_opacity;
|
|
||||||
};
|
|
||||||
|
|
||||||
} // Internal
|
|
||||||
} // Find
|
|
||||||
|
|
||||||
using namespace Core;
|
using namespace Core;
|
||||||
|
|
||||||
@@ -116,7 +59,5 @@ int IFindSupport::replaceAll(const QString &before, const QString &after, FindFl
|
|||||||
|
|
||||||
void IFindSupport::showWrapIndicator(QWidget *parent)
|
void IFindSupport::showWrapIndicator(QWidget *parent)
|
||||||
{
|
{
|
||||||
(new Internal::WrapIndicator(parent))->run();
|
Utils::FadingIndicator::showPixmap(parent, QLatin1String(":/find/images/wrapindicator.png"));
|
||||||
}
|
}
|
||||||
|
|
||||||
#include "ifindsupport.moc"
|
|
||||||
|
Reference in New Issue
Block a user