annotate widgets/LevelPanWidget.h @ 1301:e8368466fa34

Half-steps for level in level-pan widget
author Chris Cannam
date Thu, 21 Jun 2018 15:36:29 +0100
parents 8ef67917c301
children f3d3fab250ac
rev   line source
Chris@923 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@923 2
Chris@923 3 /*
Chris@923 4 Sonic Visualiser
Chris@923 5 An audio file viewer and annotation editor.
Chris@923 6 Centre for Digital Music, Queen Mary, University of London.
Chris@923 7
Chris@923 8 This program is free software; you can redistribute it and/or
Chris@923 9 modify it under the terms of the GNU General Public License as
Chris@923 10 published by the Free Software Foundation; either version 2 of the
Chris@923 11 License, or (at your option) any later version. See the file
Chris@923 12 COPYING included with this distribution for more information.
Chris@923 13 */
Chris@923 14
Chris@923 15 #ifndef LEVEL_PAN_WIDGET_H
Chris@923 16 #define LEVEL_PAN_WIDGET_H
Chris@923 17
Chris@923 18 #include <QWidget>
Chris@923 19
Chris@923 20 /**
Chris@923 21 * A simple widget for coarse level and pan control.
Chris@923 22 */
Chris@923 23
Chris@923 24 class LevelPanWidget : public QWidget
Chris@923 25 {
Chris@923 26 Q_OBJECT
Chris@923 27
Chris@923 28 public:
Chris@923 29 LevelPanWidget(QWidget *parent = 0);
Chris@923 30 ~LevelPanWidget();
Chris@923 31
Chris@1201 32 /// Return level as a gain value. The basic level range is [0,1] but the
Chris@1201 33 /// gain scale may go up to 4.0
Chris@923 34 float getLevel() const;
Chris@923 35
Chris@923 36 /// Return pan as a value in the range [-1,1]
Chris@923 37 float getPan() const;
Chris@923 38
Chris@923 39 /// Find out whether the widget is editable
Chris@923 40 bool isEditable() const;
Chris@923 41
Chris@940 42 /// Discover whether the level range includes muting or not
Chris@940 43 bool includesMute() const;
Chris@940 44
Chris@929 45 /// Draw a suitably sized copy of the widget's contents to the given device
Chris@929 46 void renderTo(QPaintDevice *, QRectF, bool asIfEditable) const;
Chris@929 47
Chris@929 48 QSize sizeHint() const;
Chris@929 49
Chris@923 50 public slots:
Chris@1201 51 /// Set level. The basic level range is [0,1] but the scale may go
Chris@1201 52 /// higher. The value will be rounded.
Chris@923 53 void setLevel(float);
Chris@923 54
Chris@1201 55 /// Set pan in the range [-1,1]. The value will be rounded
Chris@923 56 void setPan(float);
Chris@923 57
Chris@1177 58 /// Set left and right peak monitoring levels in the range [0,1]
Chris@1177 59 void setMonitoringLevels(float, float);
Chris@1177 60
Chris@923 61 /// Specify whether the widget is editable or read-only (default editable)
Chris@923 62 void setEditable(bool);
Chris@940 63
Chris@940 64 /// Specify whether the level range should include muting or not
Chris@940 65 void setIncludeMute(bool);
Chris@1249 66
Chris@1249 67 /// Reset to default values
Chris@1249 68 void setToDefault();
Chris@923 69
Chris@1200 70 // public so it can be called from LevelPanToolButton (ew)
Chris@1200 71 virtual void wheelEvent(QWheelEvent *ev);
Chris@1200 72
Chris@923 73 signals:
Chris@1177 74 void levelChanged(float); // range [0,1]
Chris@1177 75 void panChanged(float); // range [-1,1]
Chris@923 76
Chris@1180 77 void mouseEntered();
Chris@1180 78 void mouseLeft();
Chris@1180 79
Chris@923 80 protected:
Chris@923 81 virtual void mousePressEvent(QMouseEvent *ev);
Chris@923 82 virtual void mouseMoveEvent(QMouseEvent *ev);
Chris@923 83 virtual void mouseReleaseEvent(QMouseEvent *ev);
Chris@923 84 virtual void paintEvent(QPaintEvent *ev);
Chris@1180 85 virtual void enterEvent(QEvent *);
Chris@1180 86 virtual void leaveEvent(QEvent *);
Chris@923 87
Chris@923 88 void emitLevelChanged();
Chris@923 89 void emitPanChanged();
Chris@1301 90
Chris@1301 91 int m_minNotch;
Chris@1301 92 int m_maxNotch;
Chris@1301 93 int m_notch;
Chris@923 94 int m_pan;
Chris@1177 95 float m_monitorLeft;
Chris@1177 96 float m_monitorRight;
Chris@923 97 bool m_editable;
Chris@1249 98 bool m_editing;
Chris@940 99 bool m_includeMute;
Chris@1301 100 bool m_includeHalfSteps;
Chris@923 101
Chris@1301 102 int clampNotch(int notch) const;
Chris@1177 103
Chris@1301 104 int audioLevelToNotch(float audioLevel) const;
Chris@1301 105 float notchToAudioLevel(int notch) const;
Chris@1301 106
Chris@1301 107 int audioPanToPan(float audioPan) const;
Chris@1301 108 float panToAudioPan(int pan) const;
Chris@1301 109
Chris@1301 110 int coordsToNotch(QRectF rect, QPointF pos) const;
Chris@1301 111 int coordsToPan(QRectF rect, QPointF pos) const;
Chris@1301 112
Chris@1301 113 QColor notchToColour(int notch) const;
Chris@1177 114
Chris@929 115 QSizeF cellSize(QRectF) const;
Chris@1301 116 QPointF cellCentre(QRectF, int row, int col) const;
Chris@929 117 QSizeF cellLightSize(QRectF) const;
Chris@1301 118 QRectF cellLightRect(QRectF, int row, int col) const;
Chris@1301 119 QRectF cellOutlineRect(QRectF, int row, int col) const;
Chris@929 120 double thinLineWidth(QRectF) const;
Chris@923 121 };
Chris@923 122
Chris@923 123 #endif