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