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:
Eike Ziller
2015-01-22 16:27:26 +01:00
parent 7193f932d1
commit f064dd1b27
7 changed files with 218 additions and 98 deletions

View 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"

View 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

View File

@@ -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 \

View File

@@ -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",

View File

@@ -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)

View File

@@ -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;
}; };

View File

@@ -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"