annotate widgets/LevelPanWidget.h @ 1097:92ac1fce7102 spectrogram-minor-refactor

Introduce peak frequency rendering (basics of)
author Chris Cannam
date Mon, 11 Jul 2016 16:03:39 +0100
parents 77110abca8a1
children 916b62baf7ac
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@923 32 /// Return level as a gain value in the range [0,1]
Chris@923 33 float getLevel() const;
Chris@923 34
Chris@923 35 /// Return pan as a value in the range [-1,1]
Chris@923 36 float getPan() const;
Chris@923 37
Chris@923 38 /// Find out whether the widget is editable
Chris@923 39 bool isEditable() const;
Chris@923 40
Chris@940 41 /// Discover whether the level range includes muting or not
Chris@940 42 bool includesMute() const;
Chris@940 43
Chris@929 44 /// Draw a suitably sized copy of the widget's contents to the given device
Chris@929 45 void renderTo(QPaintDevice *, QRectF, bool asIfEditable) const;
Chris@929 46
Chris@929 47 QSize sizeHint() const;
Chris@929 48
Chris@923 49 public slots:
Chris@923 50 /// Set level in the range [0,1] -- will be rounded
Chris@923 51 void setLevel(float);
Chris@923 52
Chris@923 53 /// Set pan in the range [-1,1] -- will be rounded
Chris@923 54 void setPan(float);
Chris@923 55
Chris@923 56 /// Specify whether the widget is editable or read-only (default editable)
Chris@923 57 void setEditable(bool);
Chris@940 58
Chris@940 59 /// Specify whether the level range should include muting or not
Chris@940 60 void setIncludeMute(bool);
Chris@923 61
Chris@923 62 signals:
Chris@923 63 void levelChanged(float);
Chris@923 64 void panChanged(float);
Chris@923 65
Chris@923 66 protected:
Chris@923 67 virtual void mousePressEvent(QMouseEvent *ev);
Chris@923 68 virtual void mouseMoveEvent(QMouseEvent *ev);
Chris@923 69 virtual void mouseReleaseEvent(QMouseEvent *ev);
Chris@923 70 virtual void wheelEvent(QWheelEvent *ev);
Chris@923 71 virtual void paintEvent(QPaintEvent *ev);
Chris@923 72
Chris@923 73 void emitLevelChanged();
Chris@923 74 void emitPanChanged();
Chris@923 75
Chris@923 76 int m_level;
Chris@923 77 int m_pan;
Chris@923 78 bool m_editable;
Chris@940 79 bool m_includeMute;
Chris@923 80
Chris@929 81 QSizeF cellSize(QRectF) const;
Chris@929 82 QPointF cellCentre(QRectF, int level, int pan) const;
Chris@929 83 QSizeF cellLightSize(QRectF) const;
Chris@929 84 QRectF cellLightRect(QRectF, int level, int pan) const;
Chris@929 85 double thinLineWidth(QRectF) const;
Chris@929 86 void toCell(QRectF, QPointF loc, int &level, int &pan) const;
Chris@923 87 };
Chris@923 88
Chris@923 89 #endif