diff widgets/Thumbwheel.cpp @ 1586:bbc3f537564c

Add context menu to Thumbwheel
author Chris Cannam
date Fri, 27 Mar 2020 11:04:56 +0000
parents d39db4673676
children 27ea5d61b402
line wrap: on
line diff
--- a/widgets/Thumbwheel.cpp	Fri Mar 27 11:04:48 2020 +0000
+++ b/widgets/Thumbwheel.cpp	Fri Mar 27 11:04:56 2020 +0000
@@ -24,6 +24,9 @@
 #include <QInputDialog>
 #include <QPainter>
 #include <QPainterPath>
+#include <QMenu>
+
+#include "MenuTitle.h"
 
 #include <cmath>
 #include <iostream>
@@ -46,13 +49,51 @@
     m_atDefault(true),
     m_clickRotation(m_rotation),
     m_showTooltip(true),
+    m_provideContextMenu(true),
+    m_lastContextMenu(nullptr),
     m_rangeMapper(nullptr)
 {
+    setContextMenuPolicy(Qt::CustomContextMenu);
+    connect(this, SIGNAL(customContextMenuRequested(const QPoint &)),
+            this, SLOT(contextMenuRequested(const QPoint &)));
 }
 
 Thumbwheel::~Thumbwheel()
 {
     delete m_rangeMapper;
+    delete m_lastContextMenu;
+}
+
+void
+Thumbwheel::contextMenuRequested(const QPoint &pos)
+{
+    if (!m_provideContextMenu) {
+        return;
+    }
+    
+    if (m_lastContextMenu) {
+        delete m_lastContextMenu;
+    }
+    
+    QMenu *m = new QMenu;
+
+    if (m_title == "") {
+        MenuTitle::addTitle(m, tr("Thumbwheel"));
+    } else {        
+        MenuTitle::addTitle(m, m_title);
+    }
+
+    m->addAction(tr("&Edit..."),
+                 [=]() {
+                     edit();
+                 });
+    m->addAction(tr("&Reset to Default"),
+                 [=]() {
+                     resetToDefault();
+                 });
+
+    m->popup(mapToGlobal(pos));
+    m_lastContextMenu = m;
 }
 
 void
@@ -183,7 +224,11 @@
 
     m_rotation = float(m_value - m_min) / float(m_max - m_min);
     m_cache = QImage();
-    if (isVisible()) update();
+
+    if (isVisible()) {
+        update();
+        updateTitle();
+    }
 }
 
 void
@@ -223,17 +268,30 @@
         }
     }
 
+    updateTitle();
+}
+
+void
+Thumbwheel::updateTitle()
+{    
+    QString name = objectName();
+    QString unit = "";
+    QString text;
+    double mappedValue = getMappedValue();
+
+    if (m_rangeMapper) unit = m_rangeMapper->getUnit();
+    if (name != "") {
+        text = tr("%1: %2%3").arg(name).arg(mappedValue).arg(unit);
+    } else {
+        text = tr("%2%3").arg(mappedValue).arg(unit);
+    }
+
+    m_title = text;
+
     if (m_showTooltip) {
-        QString name = objectName();
-        QString unit = "";
-        QString text;
-        if (m_rangeMapper) unit = m_rangeMapper->getUnit();
-        if (name != "") {
-            text = tr("%1: %2%3").arg(name).arg(m_mappedValue).arg(unit);
-        } else {
-            text = tr("%2%3").arg(m_mappedValue).arg(unit);
-        }
         setToolTip(text);
+    } else {
+        setToolTip("");
     }
 }
 
@@ -323,6 +381,12 @@
         return;
     }
 
+    edit();
+}
+
+void
+Thumbwheel::edit()
+{
     bool ok = false;
 
     if (m_rangeMapper) {