diff options
Diffstat (limited to 'tests/manual/examples/blurpicker')
18 files changed, 324 insertions, 0 deletions
diff --git a/tests/manual/examples/blurpicker/CMakeLists.txt b/tests/manual/examples/blurpicker/CMakeLists.txt new file mode 100644 index 0000000000..b5579fc9ed --- /dev/null +++ b/tests/manual/examples/blurpicker/CMakeLists.txt @@ -0,0 +1,58 @@ +# Copyright (C) 2022 The Qt Company Ltd. +# SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause + +cmake_minimum_required(VERSION 3.16) +project(blurpicker LANGUAGES CXX) + +if(NOT DEFINED INSTALL_EXAMPLESDIR) + set(INSTALL_EXAMPLESDIR "examples") +endif() + +set(INSTALL_EXAMPLEDIR "${INSTALL_EXAMPLESDIR}/widgets/effects/blurpicker") + +find_package(Qt6 REQUIRED COMPONENTS Core Gui Widgets) + +qt_standard_project_setup() + +qt_add_executable(blurpicker + blureffect.cpp blureffect.h + blurpicker.cpp blurpicker.h + main.cpp +) + +set_target_properties(blurpicker PROPERTIES + WIN32_EXECUTABLE TRUE + MACOSX_BUNDLE TRUE +) + +target_link_libraries(blurpicker PRIVATE + Qt6::Core + Qt6::Gui + Qt6::Widgets +) + +# Resources: +set(blurpicker_resource_files + "images/accessories-calculator.png" + "images/accessories-text-editor.png" + "images/background.jpg" + "images/help-browser.png" + "images/internet-group-chat.png" + "images/internet-mail.png" + "images/internet-web-browser.png" + "images/office-calendar.png" + "images/system-users.png" +) + +qt_add_resources(blurpicker "blurpicker" + PREFIX + "/" + FILES + ${blurpicker_resource_files} +) + +install(TARGETS blurpicker + RUNTIME DESTINATION "${INSTALL_EXAMPLEDIR}" + BUNDLE DESTINATION "${INSTALL_EXAMPLEDIR}" + LIBRARY DESTINATION "${INSTALL_EXAMPLEDIR}" +) diff --git a/tests/manual/examples/blurpicker/blureffect.cpp b/tests/manual/examples/blurpicker/blureffect.cpp new file mode 100644 index 0000000000..2e2b8c8d6b --- /dev/null +++ b/tests/manual/examples/blurpicker/blureffect.cpp @@ -0,0 +1,31 @@ +// Copyright (C) 2016 The Qt Company Ltd. +// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause + +#include "blureffect.h" + +#include <QDebug> + +BlurEffect::BlurEffect(QGraphicsItem *item) + : QGraphicsBlurEffect() + , m_baseLine(200), item(item) +{ +} + +void BlurEffect::adjustForItem() +{ + qreal y = m_baseLine - item->pos().y(); + qreal radius = qBound(qreal(0.0), y / 32, qreal(16.0)); + setBlurRadius(radius); +} + +QRectF BlurEffect::boundingRect() const +{ + const_cast<BlurEffect *>(this)->adjustForItem(); + return QGraphicsBlurEffect::boundingRect(); +} + +void BlurEffect::draw(QPainter *painter) +{ + adjustForItem(); + QGraphicsBlurEffect::draw(painter); +} diff --git a/tests/manual/examples/blurpicker/blureffect.h b/tests/manual/examples/blurpicker/blureffect.h new file mode 100644 index 0000000000..a39261fc5a --- /dev/null +++ b/tests/manual/examples/blurpicker/blureffect.h @@ -0,0 +1,29 @@ +// Copyright (C) 2016 The Qt Company Ltd. +// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause + +#ifndef BLUREFFECT_H +#define BLUREFFECT_H + +#include <QGraphicsEffect> +#include <QGraphicsItem> + +class BlurEffect: public QGraphicsBlurEffect +{ +public: + BlurEffect(QGraphicsItem *item); + + void setBaseLine(qreal y) { m_baseLine = y; } + + QRectF boundingRect() const; + + void draw(QPainter *painter) override; + +private: + void adjustForItem(); + +private: + qreal m_baseLine; + QGraphicsItem *item; +}; + +#endif // BLUREFFECT_H diff --git a/tests/manual/examples/blurpicker/blurpicker.cpp b/tests/manual/examples/blurpicker/blurpicker.cpp new file mode 100644 index 0000000000..00269c8fe3 --- /dev/null +++ b/tests/manual/examples/blurpicker/blurpicker.cpp @@ -0,0 +1,122 @@ +// Copyright (C) 2016 The Qt Company Ltd. +// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause + +#include "blurpicker.h" + +#include <QtWidgets> +#include <QtCore/qmath.h> +#include <qmath.h> +#include "blureffect.h" + +BlurPicker::BlurPicker(QWidget *parent): QGraphicsView(parent), m_index(0.0), m_animation(this, "index") +{ + setBackgroundBrush(QPixmap(":/images/background.jpg")); + setScene(new QGraphicsScene(this)); + + setupScene(); + setIndex(0); + + m_animation.setDuration(400); + m_animation.setEasingCurve(QEasingCurve::InOutSine); + + setRenderHint(QPainter::Antialiasing, true); + setFrameStyle(QFrame::NoFrame); +} + +qreal BlurPicker::index() const +{ + return m_index; +} + +void BlurPicker::setIndex(qreal index) +{ + m_index = index; + + qreal baseline = 0; + const qreal iconAngle = 2 * M_PI / m_icons.count(); + for (int i = 0; i < m_icons.count(); ++i) { + QGraphicsItem *icon = m_icons[i]; + qreal a = (i + m_index) * iconAngle; + qreal xs = 170 * qSin(a); + qreal ys = 100 * qCos(a); + QPointF pos(xs, ys); + pos = QTransform().rotate(-20).map(pos); + pos -= QPointF(40, 40); + icon->setPos(pos); + baseline = qMax(baseline, ys); + static_cast<BlurEffect *>(icon->graphicsEffect())->setBaseLine(baseline); + } + + scene()->update(); +} + +void BlurPicker::setupScene() +{ + scene()->setSceneRect(-200, -120, 400, 240); + + QStringList names; + names << ":/images/accessories-calculator.png"; + names << ":/images/accessories-text-editor.png"; + names << ":/images/help-browser.png"; + names << ":/images/internet-group-chat.png"; + names << ":/images/internet-mail.png"; + names << ":/images/internet-web-browser.png"; + names << ":/images/office-calendar.png"; + names << ":/images/system-users.png"; + + for (int i = 0; i < names.count(); i++) { + QPixmap pixmap(names[i]); + QGraphicsPixmapItem *icon = scene()->addPixmap(pixmap); + icon->setZValue(1); + icon->setGraphicsEffect(new BlurEffect(icon)); + m_icons << icon; + } + + QGraphicsPixmapItem *bg = scene()->addPixmap(QPixmap(":/images/background.jpg")); + bg->setZValue(0); + bg->setPos(-200, -150); +} + +void BlurPicker::keyPressEvent(QKeyEvent *event) +{ + int delta = 0; + switch (event->key()) + { + case Qt::Key_Left: + delta = -1; + break; + case Qt::Key_Right: + delta = 1; + break; + default: + break; + } + if (m_animation.state() == QAbstractAnimation::Stopped && delta) { + m_animation.setEndValue(m_index + delta); + m_animation.start(); + event->accept(); + } +} + +void BlurPicker::resizeEvent(QResizeEvent * /* event */) +{ +} + +void BlurPicker::mousePressEvent(QMouseEvent *event) +{ + int delta = 0; + if (event->position().x() > (width() / 2)) + { + delta = 1; + } + else + { + delta = -1; + } + + if (m_animation.state() == QAbstractAnimation::Stopped && delta) { + m_animation.setEndValue(m_index + delta); + m_animation.start(); + event->accept(); + } +} diff --git a/tests/manual/examples/blurpicker/blurpicker.h b/tests/manual/examples/blurpicker/blurpicker.h new file mode 100644 index 0000000000..6e4ac84e56 --- /dev/null +++ b/tests/manual/examples/blurpicker/blurpicker.h @@ -0,0 +1,38 @@ +// Copyright (C) 2016 The Qt Company Ltd. +// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause + +#ifndef BLURPICKER_H +#define BLURPICKER_H + +#include <QGraphicsEffect> +#include <QGraphicsView> +#include <QPropertyAnimation> + +#include "blureffect.h" + +class BlurPicker: public QGraphicsView +{ + Q_OBJECT + Q_PROPERTY(qreal index READ index WRITE setIndex) + +public: + BlurPicker(QWidget *parent = nullptr); + + qreal index() const; + void setIndex(qreal); + +protected: + void keyPressEvent(QKeyEvent *event) override; + void resizeEvent(QResizeEvent *event) override; + void mousePressEvent(QMouseEvent *event) override; + +private: + void setupScene(); + +private: + qreal m_index; + QList<QGraphicsItem*> m_icons; + QPropertyAnimation m_animation; +}; + +#endif // BLURPICKER_H diff --git a/tests/manual/examples/blurpicker/blurpicker.pro b/tests/manual/examples/blurpicker/blurpicker.pro new file mode 100644 index 0000000000..c570ac3b98 --- /dev/null +++ b/tests/manual/examples/blurpicker/blurpicker.pro @@ -0,0 +1,9 @@ +QT += widgets + +SOURCES += main.cpp blurpicker.cpp blureffect.cpp +HEADERS += blurpicker.h blureffect.h +RESOURCES += blurpicker.qrc + +# install +target.path = $$[QT_INSTALL_EXAMPLES]/widgets/effects/blurpicker +INSTALLS += target diff --git a/tests/manual/examples/blurpicker/blurpicker.qrc b/tests/manual/examples/blurpicker/blurpicker.qrc new file mode 100644 index 0000000000..e88eaca966 --- /dev/null +++ b/tests/manual/examples/blurpicker/blurpicker.qrc @@ -0,0 +1,14 @@ +<RCC> + <qresource prefix="/" > + <file>images/background.jpg</file> + <file>images/accessories-calculator.png</file> + <file>images/accessories-text-editor.png</file> + <file>images/help-browser.png</file> + <file>images/internet-group-chat.png</file> + <file>images/internet-mail.png</file> + <file>images/internet-web-browser.png</file> + <file>images/office-calendar.png</file> + <file>images/system-users.png</file> + </qresource> +</RCC> + diff --git a/tests/manual/examples/blurpicker/images/README.txt b/tests/manual/examples/blurpicker/images/README.txt new file mode 100644 index 0000000000..0927e177d2 --- /dev/null +++ b/tests/manual/examples/blurpicker/images/README.txt @@ -0,0 +1,5 @@ +The background is taken from a public domain photo at: +http://www.photos8.com/view/computer_board2-800x600.html + +All other icons are from the Tango Desktop project: +http://tango.freedesktop.org/Tango_Desktop_Project diff --git a/tests/manual/examples/blurpicker/images/accessories-calculator.png b/tests/manual/examples/blurpicker/images/accessories-calculator.png Binary files differnew file mode 100644 index 0000000000..4e7661f65c --- /dev/null +++ b/tests/manual/examples/blurpicker/images/accessories-calculator.png diff --git a/tests/manual/examples/blurpicker/images/accessories-text-editor.png b/tests/manual/examples/blurpicker/images/accessories-text-editor.png Binary files differnew file mode 100644 index 0000000000..33bef0bc17 --- /dev/null +++ b/tests/manual/examples/blurpicker/images/accessories-text-editor.png diff --git a/tests/manual/examples/blurpicker/images/background.jpg b/tests/manual/examples/blurpicker/images/background.jpg Binary files differnew file mode 100644 index 0000000000..e75b38899d --- /dev/null +++ b/tests/manual/examples/blurpicker/images/background.jpg diff --git a/tests/manual/examples/blurpicker/images/help-browser.png b/tests/manual/examples/blurpicker/images/help-browser.png Binary files differnew file mode 100644 index 0000000000..8ef4fae91b --- /dev/null +++ b/tests/manual/examples/blurpicker/images/help-browser.png diff --git a/tests/manual/examples/blurpicker/images/internet-group-chat.png b/tests/manual/examples/blurpicker/images/internet-group-chat.png Binary files differnew file mode 100644 index 0000000000..dd92d93947 --- /dev/null +++ b/tests/manual/examples/blurpicker/images/internet-group-chat.png diff --git a/tests/manual/examples/blurpicker/images/internet-mail.png b/tests/manual/examples/blurpicker/images/internet-mail.png Binary files differnew file mode 100644 index 0000000000..7e6b93be83 --- /dev/null +++ b/tests/manual/examples/blurpicker/images/internet-mail.png diff --git a/tests/manual/examples/blurpicker/images/internet-web-browser.png b/tests/manual/examples/blurpicker/images/internet-web-browser.png Binary files differnew file mode 100644 index 0000000000..a979a92b4f --- /dev/null +++ b/tests/manual/examples/blurpicker/images/internet-web-browser.png diff --git a/tests/manual/examples/blurpicker/images/office-calendar.png b/tests/manual/examples/blurpicker/images/office-calendar.png Binary files differnew file mode 100644 index 0000000000..e09590682b --- /dev/null +++ b/tests/manual/examples/blurpicker/images/office-calendar.png diff --git a/tests/manual/examples/blurpicker/images/system-users.png b/tests/manual/examples/blurpicker/images/system-users.png Binary files differnew file mode 100644 index 0000000000..a7f630a5bd --- /dev/null +++ b/tests/manual/examples/blurpicker/images/system-users.png diff --git a/tests/manual/examples/blurpicker/main.cpp b/tests/manual/examples/blurpicker/main.cpp new file mode 100644 index 0000000000..4d5bf158c9 --- /dev/null +++ b/tests/manual/examples/blurpicker/main.cpp @@ -0,0 +1,18 @@ +// Copyright (C) 2016 The Qt Company Ltd. +// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause + +#include "blurpicker.h" +#include <QApplication> + +int main(int argc, char **argv) +{ + QApplication app(argc, argv); + + BlurPicker blurPicker; + blurPicker.setWindowTitle(QT_TRANSLATE_NOOP(QGraphicsView, "Application Picker")); + + blurPicker.setFixedSize(400, 300); + blurPicker.show(); + + return app.exec(); +} |