annotate layer/TimeValueLayer.h @ 114:991de8783cf5

* Add fuzzy-adapter class to pick out subset data from FFT data server, instead of having separate methods in data server class. Update spectrogram to use it. * Give spectrogram layer one fft adapter per view, in case the views need different zero-padding levels. * Reduce ridiculous memory consumption of MatrixFile for tall matrices. Still very much work in progress here.
author Chris Cannam
date Fri, 30 Jun 2006 11:26:10 +0000
parents 0f36cdf407a6
children 999ae0f7d10c
rev   line source
Chris@58 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@0 2
Chris@0 3 /*
Chris@59 4 Sonic Visualiser
Chris@59 5 An audio file viewer and annotation editor.
Chris@59 6 Centre for Digital Music, Queen Mary, University of London.
Chris@59 7 This file copyright 2006 Chris Cannam.
Chris@0 8
Chris@59 9 This program is free software; you can redistribute it and/or
Chris@59 10 modify it under the terms of the GNU General Public License as
Chris@59 11 published by the Free Software Foundation; either version 2 of the
Chris@59 12 License, or (at your option) any later version. See the file
Chris@59 13 COPYING included with this distribution for more information.
Chris@0 14 */
Chris@0 15
Chris@30 16 #ifndef _TIME_VALUE_LAYER_H_
Chris@30 17 #define _TIME_VALUE_LAYER_H_
Chris@0 18
Chris@0 19 #include "base/Layer.h"
Chris@0 20 #include "model/SparseTimeValueModel.h"
Chris@0 21
Chris@0 22 #include <QObject>
Chris@0 23 #include <QColor>
Chris@0 24
Chris@0 25 class View;
Chris@0 26 class QPainter;
Chris@0 27
Chris@0 28 class TimeValueLayer : public Layer
Chris@0 29 {
Chris@0 30 Q_OBJECT
Chris@0 31
Chris@0 32 public:
Chris@44 33 TimeValueLayer();
Chris@0 34
Chris@44 35 virtual void paint(View *v, QPainter &paint, QRect rect) const;
Chris@0 36
Chris@44 37 virtual int getVerticalScaleWidth(View *v, QPainter &) const;
Chris@44 38 virtual void paintVerticalScale(View *v, QPainter &paint, QRect rect) const;
Chris@42 39
Chris@44 40 virtual QString getFeatureDescription(View *v, QPoint &) const;
Chris@0 41
Chris@44 42 virtual bool snapToFeatureFrame(View *v, int &frame,
Chris@28 43 size_t &resolution,
Chris@28 44 SnapType snap) const;
Chris@13 45
Chris@44 46 virtual void drawStart(View *v, QMouseEvent *);
Chris@44 47 virtual void drawDrag(View *v, QMouseEvent *);
Chris@44 48 virtual void drawEnd(View *v, QMouseEvent *);
Chris@21 49
Chris@44 50 virtual void editStart(View *v, QMouseEvent *);
Chris@44 51 virtual void editDrag(View *v, QMouseEvent *);
Chris@44 52 virtual void editEnd(View *v, QMouseEvent *);
Chris@21 53
Chris@70 54 virtual void editOpen(View *v, QMouseEvent *);
Chris@70 55
Chris@43 56 virtual void moveSelection(Selection s, size_t newStartFrame);
Chris@43 57 virtual void resizeSelection(Selection s, Selection newSize);
Chris@76 58 virtual void deleteSelection(Selection s);
Chris@76 59
Chris@76 60 virtual void copy(Selection s, Clipboard &to);
Chris@76 61 virtual void paste(const Clipboard &from, int frameOffset);
Chris@43 62
Chris@0 63 virtual const Model *getModel() const { return m_model; }
Chris@0 64 void setModel(SparseTimeValueModel *model);
Chris@0 65
Chris@0 66 virtual PropertyList getProperties() const;
Chris@87 67 virtual QString getPropertyLabel(const PropertyName &) const;
Chris@0 68 virtual PropertyType getPropertyType(const PropertyName &) const;
Chris@0 69 virtual int getPropertyRangeAndValue(const PropertyName &,
Chris@0 70 int *min, int *max) const;
Chris@0 71 virtual QString getPropertyValueLabel(const PropertyName &,
Chris@0 72 int value) const;
Chris@0 73 virtual void setProperty(const PropertyName &, int value);
Chris@0 74
Chris@0 75 void setBaseColour(QColor);
Chris@0 76 QColor getBaseColour() const { return m_colour; }
Chris@0 77
Chris@26 78 enum PlotStyle {
Chris@26 79 PlotPoints,
Chris@26 80 PlotStems,
Chris@26 81 PlotConnectedPoints,
Chris@26 82 PlotLines,
Chris@26 83 PlotCurve,
Chris@26 84 PlotSegmentation
Chris@26 85 };
Chris@0 86
Chris@0 87 void setPlotStyle(PlotStyle style);
Chris@0 88 PlotStyle getPlotStyle() const { return m_plotStyle; }
Chris@0 89
Chris@66 90 enum VerticalScale {
Chris@101 91 AutoAlignScale,
Chris@66 92 LinearScale,
Chris@66 93 LogScale,
Chris@101 94 PlusMinusOneScale
Chris@66 95 };
Chris@66 96
Chris@66 97 void setVerticalScale(VerticalScale scale);
Chris@66 98 VerticalScale getVerticalScale() const { return m_verticalScale; }
Chris@66 99
Chris@44 100 virtual bool isLayerScrollable(const View *v) const;
Chris@0 101
Chris@23 102 virtual bool isLayerEditable() const { return true; }
Chris@23 103
Chris@0 104 virtual int getCompletion() const { return m_model->getCompletion(); }
Chris@0 105
Chris@79 106 virtual bool needsTextLabelHeight() const {
Chris@81 107 return m_plotStyle == PlotSegmentation && m_model->hasTextLabels();
Chris@79 108 }
Chris@79 109
Chris@101 110 virtual bool getValueExtents(float &min, float &max,
Chris@101 111 bool &logarithmic, QString &unit) const;
Chris@101 112
Chris@101 113 virtual bool getDisplayExtents(float &min, float &max) const;
Chris@79 114
Chris@6 115 virtual QString toXmlString(QString indent = "",
Chris@6 116 QString extraAttributes = "") const;
Chris@6 117
Chris@11 118 void setProperties(const QXmlAttributes &attributes);
Chris@11 119
Chris@0 120 protected:
Chris@101 121 void getScaleExtents(View *, float &min, float &max, bool &log) const;
Chris@44 122 int getYForValue(View *, float value) const;
Chris@44 123 float getValueForY(View *, int y) const;
Chris@101 124 QColor getColourForValue(View *v, float value) const;
Chris@68 125
Chris@44 126 SparseTimeValueModel::PointList getLocalPoints(View *v, int) const;
Chris@0 127
Chris@0 128 SparseTimeValueModel *m_model;
Chris@21 129 bool m_editing;
Chris@23 130 SparseTimeValueModel::Point m_originalPoint;
Chris@21 131 SparseTimeValueModel::Point m_editingPoint;
Chris@22 132 SparseTimeValueModel::EditCommand *m_editingCommand;
Chris@0 133 QColor m_colour;
Chris@0 134 PlotStyle m_plotStyle;
Chris@66 135 VerticalScale m_verticalScale;
Chris@0 136 };
Chris@0 137
Chris@0 138 #endif
Chris@0 139