lbajardsilogic@0
|
1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
|
lbajardsilogic@0
|
2
|
lbajardsilogic@0
|
3 /*
|
lbajardsilogic@0
|
4 Sonic Visualiser
|
lbajardsilogic@0
|
5 An audio file viewer and annotation editor.
|
lbajardsilogic@0
|
6 Centre for Digital Music, Queen Mary, University of London.
|
lbajardsilogic@0
|
7 This file copyright 2006 Chris Cannam and QMUL.
|
lbajardsilogic@0
|
8
|
lbajardsilogic@0
|
9 This program is free software; you can redistribute it and/or
|
lbajardsilogic@0
|
10 modify it under the terms of the GNU General Public License as
|
lbajardsilogic@0
|
11 published by the Free Software Foundation; either version 2 of the
|
lbajardsilogic@0
|
12 License, or (at your option) any later version. See the file
|
lbajardsilogic@0
|
13 COPYING included with this distribution for more information.
|
lbajardsilogic@0
|
14 */
|
lbajardsilogic@0
|
15
|
lbajardsilogic@0
|
16 #ifndef _EDITABLE_DENSE_THREE_DIMENSIONAL_MODEL_H_
|
lbajardsilogic@0
|
17 #define _EDITABLE_DENSE_THREE_DIMENSIONAL_MODEL_H_
|
lbajardsilogic@0
|
18
|
lbajardsilogic@0
|
19 #include "DenseThreeDimensionalModel.h"
|
lbajardsilogic@0
|
20
|
lbajardsilogic@0
|
21 class EditableDenseThreeDimensionalModel : public DenseThreeDimensionalModel
|
lbajardsilogic@0
|
22 {
|
lbajardsilogic@0
|
23 Q_OBJECT
|
lbajardsilogic@0
|
24
|
lbajardsilogic@0
|
25 public:
|
lbajardsilogic@0
|
26 EditableDenseThreeDimensionalModel(size_t sampleRate,
|
lbajardsilogic@0
|
27 size_t resolution,
|
lbajardsilogic@0
|
28 size_t yBinCount,
|
lbajardsilogic@0
|
29 bool notifyOnAdd = true);
|
lbajardsilogic@0
|
30
|
lbajardsilogic@0
|
31 virtual bool isOK() const;
|
lbajardsilogic@0
|
32
|
lbajardsilogic@0
|
33 virtual size_t getSampleRate() const;
|
lbajardsilogic@0
|
34 virtual size_t getStartFrame() const;
|
lbajardsilogic@0
|
35 virtual size_t getEndFrame() const;
|
lbajardsilogic@0
|
36
|
lbajardsilogic@0
|
37 virtual Model *clone() const;
|
lbajardsilogic@0
|
38
|
lbajardsilogic@0
|
39
|
lbajardsilogic@0
|
40 /**
|
lbajardsilogic@0
|
41 * Return the number of sample frames covered by each set of bins.
|
lbajardsilogic@0
|
42 */
|
lbajardsilogic@0
|
43 virtual size_t getResolution() const;
|
lbajardsilogic@0
|
44
|
lbajardsilogic@0
|
45 /**
|
lbajardsilogic@0
|
46 * Set the number of sample frames covered by each set of bins.
|
lbajardsilogic@0
|
47 */
|
lbajardsilogic@0
|
48 virtual void setResolution(size_t sz);
|
lbajardsilogic@0
|
49
|
lbajardsilogic@0
|
50 /**
|
lbajardsilogic@0
|
51 * Return the number of columns.
|
lbajardsilogic@0
|
52 */
|
lbajardsilogic@0
|
53 virtual size_t getWidth() const;
|
lbajardsilogic@0
|
54
|
lbajardsilogic@0
|
55 /**
|
lbajardsilogic@0
|
56 * Return the number of bins in each set of bins.
|
lbajardsilogic@0
|
57 */
|
lbajardsilogic@0
|
58 virtual size_t getHeight() const;
|
lbajardsilogic@0
|
59
|
lbajardsilogic@0
|
60 /**
|
lbajardsilogic@0
|
61 * Set the number of bins in each set of bins.
|
lbajardsilogic@0
|
62 */
|
lbajardsilogic@0
|
63 virtual void setHeight(size_t sz);
|
lbajardsilogic@0
|
64
|
lbajardsilogic@0
|
65 /**
|
lbajardsilogic@0
|
66 * Return the minimum value of the value in each bin.
|
lbajardsilogic@0
|
67 */
|
lbajardsilogic@0
|
68 virtual float getMinimumLevel() const;
|
lbajardsilogic@0
|
69
|
lbajardsilogic@0
|
70 /**
|
lbajardsilogic@0
|
71 * Set the minimum value of the value in a bin.
|
lbajardsilogic@0
|
72 */
|
lbajardsilogic@0
|
73 virtual void setMinimumLevel(float sz);
|
lbajardsilogic@0
|
74
|
lbajardsilogic@0
|
75 /**
|
lbajardsilogic@0
|
76 * Return the maximum value of the value in each bin.
|
lbajardsilogic@0
|
77 */
|
lbajardsilogic@0
|
78 virtual float getMaximumLevel() const;
|
lbajardsilogic@0
|
79
|
lbajardsilogic@0
|
80 /**
|
lbajardsilogic@0
|
81 * Set the maximum value of the value in a bin.
|
lbajardsilogic@0
|
82 */
|
lbajardsilogic@0
|
83 virtual void setMaximumLevel(float sz);
|
lbajardsilogic@0
|
84
|
lbajardsilogic@0
|
85 /**
|
lbajardsilogic@0
|
86 * Return true if there are data available for the given column.
|
lbajardsilogic@0
|
87 */
|
lbajardsilogic@0
|
88 virtual bool isColumnAvailable(size_t x) const { return x < getWidth(); }
|
lbajardsilogic@0
|
89
|
lbajardsilogic@0
|
90 /**
|
lbajardsilogic@0
|
91 * Get the set of bin values at the given column.
|
lbajardsilogic@0
|
92 */
|
lbajardsilogic@0
|
93 virtual void getColumn(size_t x, Column &) const;
|
lbajardsilogic@0
|
94
|
lbajardsilogic@0
|
95 /**
|
lbajardsilogic@0
|
96 * Get a single value, from the n'th bin of the given column.
|
lbajardsilogic@0
|
97 */
|
lbajardsilogic@0
|
98 virtual float getValueAt(size_t x, size_t n) const;
|
lbajardsilogic@0
|
99
|
lbajardsilogic@0
|
100 /**
|
lbajardsilogic@0
|
101 * Set the entire set of bin values at the given column.
|
lbajardsilogic@0
|
102 */
|
lbajardsilogic@0
|
103 virtual void setColumn(size_t x, const Column &values);
|
lbajardsilogic@0
|
104
|
lbajardsilogic@0
|
105 virtual QString getBinName(size_t n) const;
|
lbajardsilogic@0
|
106 virtual void setBinName(size_t n, QString);
|
lbajardsilogic@0
|
107 virtual void setBinNames(std::vector<QString> names);
|
lbajardsilogic@0
|
108
|
lbajardsilogic@0
|
109 virtual void setCompletion(int completion);
|
lbajardsilogic@0
|
110 virtual int getCompletion() const { return m_completion; }
|
lbajardsilogic@0
|
111
|
lbajardsilogic@0
|
112 virtual void toXml(QTextStream &out,
|
lbajardsilogic@0
|
113 QString indent = "",
|
lbajardsilogic@0
|
114 QString extraAttributes = "") const;
|
lbajardsilogic@0
|
115
|
lbajardsilogic@0
|
116 virtual QString toXmlString(QString indent = "",
|
lbajardsilogic@0
|
117 QString extraAttributes = "") const;
|
lbajardsilogic@0
|
118
|
lbajardsilogic@0
|
119 protected:
|
lbajardsilogic@0
|
120 typedef std::vector<Column> ValueMatrix;
|
lbajardsilogic@0
|
121 ValueMatrix m_data;
|
lbajardsilogic@0
|
122
|
lbajardsilogic@0
|
123 std::vector<QString> m_binNames;
|
lbajardsilogic@0
|
124
|
lbajardsilogic@0
|
125 size_t m_sampleRate;
|
lbajardsilogic@0
|
126 size_t m_resolution;
|
lbajardsilogic@0
|
127 size_t m_yBinCount;
|
lbajardsilogic@0
|
128 float m_minimum;
|
lbajardsilogic@0
|
129 float m_maximum;
|
lbajardsilogic@0
|
130 bool m_haveExtents;
|
lbajardsilogic@0
|
131 bool m_notifyOnAdd;
|
lbajardsilogic@0
|
132 long m_sinceLastNotifyMin;
|
lbajardsilogic@0
|
133 long m_sinceLastNotifyMax;
|
lbajardsilogic@0
|
134 int m_completion;
|
lbajardsilogic@0
|
135
|
lbajardsilogic@0
|
136 mutable QMutex m_mutex;
|
lbajardsilogic@0
|
137 };
|
lbajardsilogic@0
|
138
|
lbajardsilogic@0
|
139 #endif
|