annotate data/model/EditableDenseThreeDimensionalModel.h @ 282:d9319859a4cf tip

(none)
author benoitrigolleau
date Fri, 31 Oct 2008 11:00:24 +0000
parents fc9323a41f5a
children
rev   line source
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