Mercurial > hg > svgui
comparison layer/SliceableLayer.h @ 193:57c2350a8c40
* Add slice layers (so you can display a slice of a colour 3d plot as if it were
a spectrum)
* Make spectrum layer a subclass of slice layer
author | Chris Cannam |
---|---|
date | Fri, 26 Jan 2007 16:59:57 +0000 |
parents | |
children | 05d614f6e46d |
comparison
equal
deleted
inserted
replaced
192:fcc043f75c41 | 193:57c2350a8c40 |
---|---|
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 _SLICEABLE_LAYER_H_ | |
17 #define _SLICEABLE_LAYER_H_ | |
18 | |
19 #include "Layer.h" | |
20 | |
21 /** | |
22 * Base class for layers that can be sliced, that is, that contain | |
23 * models appropriate for use in a SliceLayer. | |
24 */ | |
25 | |
26 class SliceableLayer : public Layer | |
27 { | |
28 Q_OBJECT | |
29 | |
30 public: | |
31 // Get a model that can be sliced, i.e. a | |
32 // DenseThreeDimensionalModel. This may be the layer's usual | |
33 // model, or it may be a model derived from it (e.g. FFTModel in a | |
34 // spectrogram that was constructed from a DenseTimeValueModel). | |
35 // The SliceableLayer retains ownership of the model, and will | |
36 // emit sliceableModelReplaced if it is about to become invalid. | |
37 virtual const Model *getSliceableModel() const = 0; | |
38 | |
39 signals: | |
40 // Emitted when a model that was obtained through | |
41 // getSliceableModel is about to be deleted. If replacement is | |
42 // non-NULL, it may be used instead. | |
43 void sliceableModelReplaced(const Model *modelToBeReplaced, | |
44 const Model *replacement); | |
45 }; | |
46 | |
47 #endif | |
48 | |
49 | |
50 |