annotate layer/TimeValueLayer.h @ 432:8b2b497d302c

* Fix race condition in FFTFileCache when reading from the same FFT model from multiple threads (e.g. when applying more than one plugin at once)
author Chris Cannam
date Wed, 15 Oct 2008 12:08:02 +0000
parents e1a9e478b7f2
children 755243c67f59
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@287 19 #include "SingleColourLayer.h"
Chris@128 20 #include "data/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@287 28 class TimeValueLayer : public SingleColourLayer
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@335 50 virtual void eraseStart(View *v, QMouseEvent *);
Chris@335 51 virtual void eraseDrag(View *v, QMouseEvent *);
Chris@335 52 virtual void eraseEnd(View *v, QMouseEvent *);
Chris@335 53
Chris@44 54 virtual void editStart(View *v, QMouseEvent *);
Chris@44 55 virtual void editDrag(View *v, QMouseEvent *);
Chris@44 56 virtual void editEnd(View *v, QMouseEvent *);
Chris@21 57
Chris@255 58 virtual bool editOpen(View *v, QMouseEvent *);
Chris@70 59
Chris@43 60 virtual void moveSelection(Selection s, size_t newStartFrame);
Chris@43 61 virtual void resizeSelection(Selection s, Selection newSize);
Chris@76 62 virtual void deleteSelection(Selection s);
Chris@76 63
Chris@359 64 virtual void copy(View *v, Selection s, Clipboard &to);
Chris@359 65 virtual bool paste(View *v, const Clipboard &from, int frameOffset,
Chris@125 66 bool interactive);
Chris@43 67
Chris@0 68 virtual const Model *getModel() const { return m_model; }
Chris@0 69 void setModel(SparseTimeValueModel *model);
Chris@0 70
Chris@0 71 virtual PropertyList getProperties() const;
Chris@87 72 virtual QString getPropertyLabel(const PropertyName &) const;
Chris@0 73 virtual PropertyType getPropertyType(const PropertyName &) const;
Chris@198 74 virtual QString getPropertyGroupName(const PropertyName &) const;
Chris@0 75 virtual int getPropertyRangeAndValue(const PropertyName &,
Chris@216 76 int *min, int *max, int *deflt) const;
Chris@0 77 virtual QString getPropertyValueLabel(const PropertyName &,
Chris@0 78 int value) const;
Chris@0 79 virtual void setProperty(const PropertyName &, int value);
Chris@0 80
Chris@197 81 void setFillColourMap(int);
Chris@197 82 int getFillColourMap() const { return m_colourMap; }
Chris@197 83
Chris@26 84 enum PlotStyle {
Chris@26 85 PlotPoints,
Chris@26 86 PlotStems,
Chris@26 87 PlotConnectedPoints,
Chris@26 88 PlotLines,
Chris@26 89 PlotCurve,
Chris@26 90 PlotSegmentation
Chris@26 91 };
Chris@0 92
Chris@0 93 void setPlotStyle(PlotStyle style);
Chris@0 94 PlotStyle getPlotStyle() const { return m_plotStyle; }
Chris@0 95
Chris@66 96 enum VerticalScale {
Chris@101 97 AutoAlignScale,
Chris@66 98 LinearScale,
Chris@66 99 LogScale,
Chris@101 100 PlusMinusOneScale
Chris@66 101 };
Chris@66 102
Chris@66 103 void setVerticalScale(VerticalScale scale);
Chris@66 104 VerticalScale getVerticalScale() const { return m_verticalScale; }
Chris@66 105
Chris@44 106 virtual bool isLayerScrollable(const View *v) const;
Chris@0 107
Chris@23 108 virtual bool isLayerEditable() const { return true; }
Chris@23 109
Chris@169 110 virtual int getCompletion(View *) const { return m_model->getCompletion(); }
Chris@0 111
Chris@79 112 virtual bool needsTextLabelHeight() const {
Chris@81 113 return m_plotStyle == PlotSegmentation && m_model->hasTextLabels();
Chris@79 114 }
Chris@79 115
Chris@101 116 virtual bool getValueExtents(float &min, float &max,
Chris@101 117 bool &logarithmic, QString &unit) const;
Chris@101 118
Chris@101 119 virtual bool getDisplayExtents(float &min, float &max) const;
Chris@79 120
Chris@316 121 virtual void toXml(QTextStream &stream, QString indent = "",
Chris@316 122 QString extraAttributes = "") const;
Chris@6 123
Chris@11 124 void setProperties(const QXmlAttributes &attributes);
Chris@11 125
Chris@0 126 protected:
Chris@101 127 void getScaleExtents(View *, float &min, float &max, bool &log) const;
Chris@44 128 int getYForValue(View *, float value) const;
Chris@44 129 float getValueForY(View *, int y) const;
Chris@101 130 QColor getColourForValue(View *v, float value) const;
Chris@296 131 bool shouldAutoAlign() const;
Chris@68 132
Chris@44 133 SparseTimeValueModel::PointList getLocalPoints(View *v, int) const;
Chris@0 134
Chris@287 135 virtual int getDefaultColourHint(bool dark, bool &impose);
Chris@287 136
Chris@0 137 SparseTimeValueModel *m_model;
Chris@21 138 bool m_editing;
Chris@23 139 SparseTimeValueModel::Point m_originalPoint;
Chris@21 140 SparseTimeValueModel::Point m_editingPoint;
Chris@22 141 SparseTimeValueModel::EditCommand *m_editingCommand;
Chris@197 142 int m_colourMap;
Chris@0 143 PlotStyle m_plotStyle;
Chris@66 144 VerticalScale m_verticalScale;
Chris@376 145
Chris@376 146 void finish(SparseTimeValueModel::EditCommand *command) {
Chris@376 147 Command *c = command->finish();
Chris@376 148 if (c) CommandHistory::getInstance()->addCommand(c, false);
Chris@376 149 }
Chris@0 150 };
Chris@0 151
Chris@0 152 #endif
Chris@0 153