forked from qt-creator/qt-creator
Convert the CurveEditorDialog to a view-plugin
Continuously send frame-changed signals when dragging the playhead Fix timescale painting Paint playhead behind the valuescale Task-number: QDS-2551 Change-Id: Ia8d3952b4401500a4c6d31ff9f5742ff44b2c092 Reviewed-by: Thomas Hartmann <thomas.hartmann@qt.io>
This commit is contained in:
@@ -62,6 +62,11 @@ CurveEditor::CurveEditor(CurveEditorModel *model, QWidget *parent)
|
||||
&GraphicsView::updateSelection);
|
||||
}
|
||||
|
||||
bool CurveEditor::dragging() const
|
||||
{
|
||||
return m_view->dragging();
|
||||
}
|
||||
|
||||
void CurveEditor::zoomX(double zoom)
|
||||
{
|
||||
m_view->setZoomX(zoom);
|
||||
@@ -82,18 +87,21 @@ QToolBar *CurveEditor::createToolBar(CurveEditorModel *model)
|
||||
auto *bar = new QToolBar;
|
||||
bar->setFloatable(false);
|
||||
|
||||
QAction *tangentLinearAction = bar->addAction(QIcon(":/curveeditor/images/tangetToolsLinearIcon.png"), "Linear");
|
||||
QAction *tangentStepAction = bar->addAction(QIcon(":/curveeditor/images/tangetToolsStepIcon.png"), "Step");
|
||||
QAction *tangentSplineAction = bar->addAction(QIcon(":/curveeditor/images/tangetToolsSplineIcon.png"), "Spline");
|
||||
QAction *tangentDefaultAction = bar->addAction("Set Default");
|
||||
QAction *tangentUnifyAction = bar->addAction("Unify");
|
||||
QAction *tangentLinearAction = bar->addAction(
|
||||
QIcon(":/curveeditor/images/tangetToolsLinearIcon.png"), "Linear");
|
||||
QAction *tangentStepAction = bar->addAction(QIcon(
|
||||
":/curveeditor/images/tangetToolsStepIcon.png"),
|
||||
"Step");
|
||||
QAction *tangentSplineAction = bar->addAction(
|
||||
QIcon(":/curveeditor/images/tangetToolsSplineIcon.png"), "Spline");
|
||||
|
||||
QAction *tangentDefaultAction = bar->addAction(tr("Set Default"));
|
||||
QAction *tangentUnifyAction = bar->addAction(tr("Unify"));
|
||||
|
||||
auto setLinearInterpolation = [this]() {
|
||||
m_view->setInterpolation(Keyframe::Interpolation::Linear);
|
||||
};
|
||||
auto setStepInterpolation = [this]() {
|
||||
m_view->setInterpolation(Keyframe::Interpolation::Step);
|
||||
};
|
||||
auto setStepInterpolation = [this]() { m_view->setInterpolation(Keyframe::Interpolation::Step); };
|
||||
auto setSplineInterpolation = [this]() {
|
||||
m_view->setInterpolation(Keyframe::Interpolation::Bezier);
|
||||
};
|
||||
@@ -118,7 +126,7 @@ QToolBar *CurveEditor::createToolBar(CurveEditorModel *model)
|
||||
startSpin->setValue(model->minimumTime());
|
||||
|
||||
auto updateStartFrame = [this, model](int frame) {
|
||||
model->setMinimumTime(frame, false);
|
||||
model->setMinimumTime(frame);
|
||||
m_view->viewport()->update();
|
||||
};
|
||||
connect(startSpin, QOverload<int>::of(&QSpinBox::valueChanged), updateStartFrame);
|
||||
@@ -127,16 +135,16 @@ QToolBar *CurveEditor::createToolBar(CurveEditorModel *model)
|
||||
endSpin->setValue(model->maximumTime());
|
||||
|
||||
auto updateEndFrame = [this, model](int frame) {
|
||||
model->setMaximumTime(frame, false);
|
||||
model->setMaximumTime(frame);
|
||||
m_view->viewport()->update();
|
||||
};
|
||||
connect(endSpin, QOverload<int>::of(&QSpinBox::valueChanged), updateEndFrame);
|
||||
|
||||
auto setStartSlot = [startSpin](int frame) { startSpin->setValue(frame); };
|
||||
connect(model, &CurveEditorModel::updateStartFrame, setStartSlot);
|
||||
connect(model, &CurveEditorModel::commitStartFrame, setStartSlot);
|
||||
|
||||
auto setEndSlot = [endSpin](int frame) { endSpin->setValue(frame); };
|
||||
connect(model, &CurveEditorModel::updateEndFrame, setEndSlot);
|
||||
connect(model, &CurveEditorModel::commitEndFrame, setEndSlot);
|
||||
|
||||
durationBox->addWidget(new QLabel(tr("Start Frame")));
|
||||
durationBox->addWidget(startSpin);
|
||||
@@ -152,10 +160,14 @@ QToolBar *CurveEditor::createToolBar(CurveEditorModel *model)
|
||||
cfspin->setMaximum(std::numeric_limits<int>::max());
|
||||
|
||||
auto intSignal = static_cast<void (QSpinBox::*)(int)>(&QSpinBox::valueChanged);
|
||||
connect(cfspin, intSignal, [this](int val) { m_view->setCurrentFrame(val, false); });
|
||||
connect(m_view, &GraphicsView::notifyFrameChanged, [cfspin](int val) {
|
||||
QSignalBlocker blocker(cfspin);
|
||||
cfspin->setValue(val);
|
||||
connect(cfspin, intSignal, [this, model](int val) { model->commitCurrentFrame(val); });
|
||||
connect(m_view, &GraphicsView::currentFrameChanged, [cfspin](int val, bool notify) {
|
||||
if (notify) {
|
||||
cfspin->setValue(val);
|
||||
} else {
|
||||
const QSignalBlocker blocker(cfspin);
|
||||
cfspin->setValue(val);
|
||||
}
|
||||
});
|
||||
|
||||
auto *positionBox = new QHBoxLayout;
|
||||
|
||||
Reference in New Issue
Block a user