/**************************************************************************** ** ** Copyright (C) 2018 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 "timelinecontrols.h" #include "timelinepropertyitem.h" #include #include #include #include #include #include #include #include namespace QmlDesigner { TimelineControl *createTimelineControl(const TypeName &name) { if (name == "real" || name == "double" || name == "float") return new FloatControl; if (name == "QColor" || name == "color") return new ColorControl; return nullptr; } FloatControl::FloatControl() : QDoubleSpinBox(nullptr) { setValue(0.0); setButtonSymbols(QAbstractSpinBox::NoButtons); setFrame(false); #if QT_VERSION >= QT_VERSION_CHECK(5, 12, 0) setStepType(QAbstractSpinBox::AdaptiveDecimalStepType); #endif setMinimum(std::numeric_limits::lowest()); setMaximum(std::numeric_limits::max()); QColor bg = Theme::instance()->qmlDesignerBackgroundColorDarkAlternate(); auto p = palette(); p.setColor(QPalette::Base, bg.darker(110)); setPalette(p); m_timer.setInterval(100); m_timer.setSingleShot(true); auto startTimer = [this]( ) { m_timer.start(); }; auto deferredSlot = [this]( ) { emit controlValueChanged(QVariant(this->value())); }; QObject::connect(this, &QDoubleSpinBox::editingFinished, &m_timer, startTimer); QObject::connect(&m_timer, &QTimer::timeout, deferredSlot); } FloatControl::~FloatControl() = default; QWidget *FloatControl::widget() { return this; } void FloatControl::connect(TimelinePropertyItem *item) { QObject::connect(this, &FloatControl::controlValueChanged, item, &TimelinePropertyItem::changePropertyValue); } QVariant FloatControl::controlValue() const { return QVariant(value()); } void FloatControl::setControlValue(const QVariant &value) { if (value.userType() != QMetaType::Float && value.userType() != QMetaType::Double) return; QSignalBlocker blocker(this); setValue(value.toDouble()); } void FloatControl::setSize(int width, int height) { setFixedWidth(width); setFixedHeight(height); } ColorControl::ColorControl() : QWidget(nullptr) , m_color(Qt::black) { setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Fixed); setFixedHeight(20); } ColorControl::ColorControl(const QColor &color, QWidget *parent) : QWidget(parent) , m_color(color) { setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Fixed); setFixedHeight(20); } ColorControl::~ColorControl() = default; QWidget *ColorControl::widget() { return this; } void ColorControl::connect(TimelinePropertyItem *item) { QObject::connect(this, &ColorControl::controlValueChanged, item, &TimelinePropertyItem::changePropertyValue); } QVariant ColorControl::controlValue() const { return QVariant(value()); } void ColorControl::setControlValue(const QVariant &value) { if (value.userType() != QMetaType::QColor) return; m_color = qvariant_cast(value); } void ColorControl::setSize(int width, int height) { setFixedWidth(width); setFixedHeight(height); } QColor ColorControl::value() const { return m_color; } bool ColorControl::event(QEvent *event) { if (event->type() == QEvent::ToolTip) { if (auto helpEvent = static_cast(event)) { QToolTip::showText(helpEvent->globalPos(), m_color.name()); return true; } } return QWidget::event(event); } void ColorControl::paintEvent(QPaintEvent *event) { QPainter painter(this); painter.fillRect(event->rect(), m_color); } void ColorControl::mouseReleaseEvent(QMouseEvent *event) { QColor color = QColorDialog::getColor(m_color, Core::ICore::dialogParent()); event->accept(); if (color != m_color) { m_color = color; update(); emit valueChanged(); emit controlValueChanged(QVariant(m_color)); } } void ColorControl::mousePressEvent(QMouseEvent *event) { // Needed to make the mouseRelease Event work if this // widget is embedded inside a QGraphicsProxyWidget. QWidget::mousePressEvent(event); event->accept(); } } // End namespace QmlDesigner.