Mercurial > hg > svgui
changeset 1249:8ef67917c301
Ctrl-click, and middle-button click, on level-pan widget reset to default (not implemented yet for level-pan tool button though)
author | Chris Cannam |
---|---|
date | Tue, 28 Feb 2017 14:20:56 +0000 (2017-02-28) |
parents | fc40742bb911 |
children | c49a48fcc364 |
files | widgets/LevelPanToolButton.cpp widgets/LevelPanWidget.cpp widgets/LevelPanWidget.h |
diffstat | 3 files changed, 27 insertions(+), 8 deletions(-) [+] |
line wrap: on
line diff
--- a/widgets/LevelPanToolButton.cpp Tue Feb 28 14:07:47 2017 +0000 +++ b/widgets/LevelPanToolButton.cpp Tue Feb 28 14:20:56 2017 +0000 @@ -152,8 +152,6 @@ void LevelPanToolButton::selfClicked() { - cerr << "selfClicked" << endl; - if (m_muted) { m_muted = false; m_lpw->setLevel(m_savedLevel);
--- a/widgets/LevelPanWidget.cpp Tue Feb 28 14:07:47 2017 +0000 +++ b/widgets/LevelPanWidget.cpp Tue Feb 28 14:20:56 2017 +0000 @@ -40,6 +40,7 @@ m_monitorLeft(-1), m_monitorRight(-1), m_editable(true), + m_editing(false), m_includeMute(true) { setToolTip(tr("Drag vertically to adjust level, horizontally to adjust pan")); @@ -51,6 +52,13 @@ { } +void +LevelPanWidget::setToDefault() +{ + setLevel(1.0); + setPan(0.0); +} + QSize LevelPanWidget::sizeHint() const { @@ -211,13 +219,28 @@ void LevelPanWidget::mousePressEvent(QMouseEvent *e) { + if (e->button() == Qt::MidButton || + ((e->button() == Qt::LeftButton) && + (e->modifiers() & Qt::ControlModifier))) { + setToDefault(); + } else if (e->button() == Qt::LeftButton) { + m_editing = true; + mouseMoveEvent(e); + } +} + +void +LevelPanWidget::mouseReleaseEvent(QMouseEvent *e) +{ mouseMoveEvent(e); + m_editing = false; } void LevelPanWidget::mouseMoveEvent(QMouseEvent *e) { if (!m_editable) return; + if (!m_editing) return; int level, pan; toCell(rect(), e->pos(), level, pan); @@ -236,12 +259,6 @@ } void -LevelPanWidget::mouseReleaseEvent(QMouseEvent *e) -{ - mouseMoveEvent(e); -} - -void LevelPanWidget::wheelEvent(QWheelEvent *e) { if (e->modifiers() & Qt::ControlModifier) {
--- a/widgets/LevelPanWidget.h Tue Feb 28 14:07:47 2017 +0000 +++ b/widgets/LevelPanWidget.h Tue Feb 28 14:20:56 2017 +0000 @@ -63,6 +63,9 @@ /// Specify whether the level range should include muting or not void setIncludeMute(bool); + + /// Reset to default values + void setToDefault(); // public so it can be called from LevelPanToolButton (ew) virtual void wheelEvent(QWheelEvent *ev); @@ -90,6 +93,7 @@ float m_monitorLeft; float m_monitorRight; bool m_editable; + bool m_editing; bool m_includeMute; static int audioLevelToLevel(float audioLevel, bool withMute);