Mercurial > hg > svcore
comparison data/model/AggregateWaveModel.h @ 297:c022976d18e8
* Merge from sv-match-alignment branch (excluding alignment-specific document).
- add aggregate wave model (not yet complete enough to be added as a true
model in a layer, but there's potential)
- add play solo mode
- add alignment model -- unused in plain SV
- fix two plugin leaks
- add m3u playlist support (opens all files at once, potentially hazardous)
- fix retrieval of pre-encoded URLs
- add ability to resample audio files on import, so as to match rates with
other files previously loaded; add preference for same
- add preliminary support in transform code for range and rate of transform
input
- reorganise preferences dialog, move dark-background option to preferences,
add option for temporary directory location
author | Chris Cannam |
---|---|
date | Fri, 28 Sep 2007 13:56:38 +0000 |
parents | |
children | 5877d68815c7 |
comparison
equal
deleted
inserted
replaced
296:2b6c99b607f1 | 297:c022976d18e8 |
---|---|
1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ | |
2 | |
3 /* | |
4 Sonic Visualiser | |
5 An audio file viewer and annotation editor. | |
6 Centre for Digital Music, Queen Mary, University of London. | |
7 This file copyright 2007 QMUL. | |
8 | |
9 This program is free software; you can redistribute it and/or | |
10 modify it under the terms of the GNU General Public License as | |
11 published by the Free Software Foundation; either version 2 of the | |
12 License, or (at your option) any later version. See the file | |
13 COPYING included with this distribution for more information. | |
14 */ | |
15 | |
16 #ifndef _AGGREGATE_WAVE_MODEL_H_ | |
17 #define _AGGREGATE_WAVE_MODEL_H_ | |
18 | |
19 #include "RangeSummarisableTimeValueModel.h" | |
20 #include "PowerOfSqrtTwoZoomConstraint.h" | |
21 | |
22 #include <vector> | |
23 | |
24 class AggregateWaveModel : public RangeSummarisableTimeValueModel | |
25 { | |
26 Q_OBJECT | |
27 | |
28 public: | |
29 struct ModelChannelSpec | |
30 { | |
31 ModelChannelSpec(RangeSummarisableTimeValueModel *m, int c) : | |
32 model(m), channel(c) { } | |
33 RangeSummarisableTimeValueModel *model; | |
34 int channel; | |
35 }; | |
36 | |
37 typedef std::vector<ModelChannelSpec> ChannelSpecList; | |
38 | |
39 AggregateWaveModel(ChannelSpecList channelSpecs); | |
40 ~AggregateWaveModel(); | |
41 | |
42 bool isOK() const; | |
43 bool isReady(int *) const; | |
44 | |
45 size_t getComponentCount() const; | |
46 ModelChannelSpec getComponent(size_t c) const; | |
47 | |
48 const ZoomConstraint *getZoomConstraint() const { return &m_zoomConstraint; } | |
49 | |
50 size_t getFrameCount() const; | |
51 size_t getChannelCount() const; | |
52 size_t getSampleRate() const; | |
53 | |
54 virtual Model *clone() const; | |
55 | |
56 float getValueMinimum() const { return -1.0f; } | |
57 float getValueMaximum() const { return 1.0f; } | |
58 | |
59 virtual size_t getStartFrame() const { return 0; } | |
60 virtual size_t getEndFrame() const { return getFrameCount(); } | |
61 | |
62 virtual size_t getValues(int channel, size_t start, size_t end, | |
63 float *buffer) const; | |
64 | |
65 virtual size_t getValues(int channel, size_t start, size_t end, | |
66 double *buffer) const; | |
67 | |
68 virtual void getRanges(size_t channel, size_t start, size_t end, | |
69 RangeBlock &ranges, | |
70 size_t &blockSize) const; | |
71 | |
72 virtual Range getRange(size_t channel, size_t start, size_t end) const; | |
73 | |
74 virtual void toXml(QTextStream &out, | |
75 QString indent = "", | |
76 QString extraAttributes = "") const; | |
77 | |
78 signals: | |
79 void modelChanged(); | |
80 void modelChanged(size_t, size_t); | |
81 void completionChanged(); | |
82 | |
83 protected slots: | |
84 void componentModelChanged(); | |
85 void componentModelChanged(size_t, size_t); | |
86 void componentModelCompletionChanged(); | |
87 | |
88 protected: | |
89 ChannelSpecList m_components; | |
90 static PowerOfSqrtTwoZoomConstraint m_zoomConstraint; | |
91 }; | |
92 | |
93 #endif | |
94 |