annotate layer/TimeValueLayer.h @ 494:b3140e9e0665

* Some fairly simplistic code to set up layer type properties based on RDF data about feature types (both when running transforms and when importing features from RDF files).
author Chris Cannam
date Thu, 12 Feb 2009 15:26:43 +0000
parents 755243c67f59
children 1341e95eeae9
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@437 120 virtual bool setDisplayExtents(float min, float max);
Chris@437 121
Chris@437 122 virtual int getVerticalZoomSteps(int &defaultStep) const;
Chris@437 123 virtual int getCurrentVerticalZoomStep() const;
Chris@437 124 virtual void setVerticalZoomStep(int);
Chris@437 125 virtual RangeMapper *getNewVerticalZoomRangeMapper() const;
Chris@79 126
Chris@316 127 virtual void toXml(QTextStream &stream, QString indent = "",
Chris@316 128 QString extraAttributes = "") const;
Chris@6 129
Chris@11 130 void setProperties(const QXmlAttributes &attributes);
Chris@11 131
Chris@494 132 virtual ColourSignificance getLayerColourSignificance() const {
Chris@494 133 if (m_plotStyle == PlotSegmentation) {
Chris@494 134 return ColourHasMeaningfulValue;
Chris@494 135 } else {
Chris@494 136 return ColourDistinguishes;
Chris@494 137 }
Chris@494 138 }
Chris@494 139
Chris@0 140 protected:
Chris@101 141 void getScaleExtents(View *, float &min, float &max, bool &log) const;
Chris@44 142 int getYForValue(View *, float value) const;
Chris@44 143 float getValueForY(View *, int y) const;
Chris@101 144 QColor getColourForValue(View *v, float value) const;
Chris@296 145 bool shouldAutoAlign() const;
Chris@68 146
Chris@44 147 SparseTimeValueModel::PointList getLocalPoints(View *v, int) const;
Chris@0 148
Chris@287 149 virtual int getDefaultColourHint(bool dark, bool &impose);
Chris@287 150
Chris@0 151 SparseTimeValueModel *m_model;
Chris@21 152 bool m_editing;
Chris@23 153 SparseTimeValueModel::Point m_originalPoint;
Chris@21 154 SparseTimeValueModel::Point m_editingPoint;
Chris@22 155 SparseTimeValueModel::EditCommand *m_editingCommand;
Chris@197 156 int m_colourMap;
Chris@0 157 PlotStyle m_plotStyle;
Chris@66 158 VerticalScale m_verticalScale;
Chris@376 159
Chris@437 160 mutable float m_scaleMinimum;
Chris@437 161 mutable float m_scaleMaximum;
Chris@437 162
Chris@376 163 void finish(SparseTimeValueModel::EditCommand *command) {
Chris@376 164 Command *c = command->finish();
Chris@376 165 if (c) CommandHistory::getInstance()->addCommand(c, false);
Chris@376 166 }
Chris@0 167 };
Chris@0 168
Chris@0 169 #endif
Chris@0 170