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.
|
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 _TEXT_MODEL_H_
|
lbajardsilogic@0
|
17 #define _TEXT_MODEL_H_
|
lbajardsilogic@0
|
18
|
lbajardsilogic@0
|
19 #include "SparseModel.h"
|
lbajardsilogic@0
|
20 #include "base/RealTime.h"
|
lbajardsilogic@0
|
21
|
lbajardsilogic@0
|
22 /**
|
lbajardsilogic@0
|
23 * Text point type for use in a SparseModel. This represents a piece
|
lbajardsilogic@0
|
24 * of text at a given time and y-value in the [0,1) range (indicative
|
lbajardsilogic@0
|
25 * of height on the window). Intended for casual textual annotations.
|
lbajardsilogic@0
|
26 */
|
lbajardsilogic@0
|
27
|
lbajardsilogic@0
|
28 struct TextPoint
|
lbajardsilogic@0
|
29 {
|
lbajardsilogic@0
|
30 public:
|
lbajardsilogic@0
|
31 TextPoint(long _frame) : frame(_frame), height(0.0f) { }
|
lbajardsilogic@0
|
32 TextPoint(long _frame, float _height, QString _label) :
|
lbajardsilogic@0
|
33 frame(_frame), height(_height), label(_label) { }
|
lbajardsilogic@0
|
34
|
lbajardsilogic@0
|
35 int getDimensions() const { return 2; }
|
lbajardsilogic@0
|
36
|
lbajardsilogic@0
|
37 long frame;
|
lbajardsilogic@0
|
38 float height;
|
lbajardsilogic@0
|
39 QString label;
|
lbajardsilogic@0
|
40
|
lbajardsilogic@0
|
41 QString toXmlString(QString indent = "",
|
lbajardsilogic@0
|
42 QString extraAttributes = "") const
|
lbajardsilogic@0
|
43 {
|
lbajardsilogic@0
|
44 return QString("%1<point frame=\"%2\" height=\"%3\" label=\"%4\" %5/>\n")
|
lbajardsilogic@0
|
45 .arg(indent).arg(frame).arg(height).arg(label).arg(extraAttributes);
|
lbajardsilogic@0
|
46 }
|
lbajardsilogic@0
|
47
|
lbajardsilogic@0
|
48 QString toDelimitedDataString(QString delimiter, size_t sampleRate) const
|
lbajardsilogic@0
|
49 {
|
lbajardsilogic@0
|
50 QStringList list;
|
lbajardsilogic@0
|
51 list << RealTime::frame2RealTime(frame, sampleRate).toString().c_str();
|
lbajardsilogic@0
|
52 list << QString("%1").arg(height);
|
lbajardsilogic@0
|
53 list << label;
|
lbajardsilogic@0
|
54 return list.join(delimiter);
|
lbajardsilogic@0
|
55 }
|
lbajardsilogic@0
|
56
|
lbajardsilogic@0
|
57 struct Comparator {
|
lbajardsilogic@0
|
58 bool operator()(const TextPoint &p1,
|
lbajardsilogic@0
|
59 const TextPoint &p2) const {
|
lbajardsilogic@0
|
60 if (p1.frame != p2.frame) return p1.frame < p2.frame;
|
lbajardsilogic@0
|
61 if (p1.height != p2.height) return p1.height < p2.height;
|
lbajardsilogic@0
|
62 return p1.label < p2.label;
|
lbajardsilogic@0
|
63 }
|
lbajardsilogic@0
|
64 };
|
lbajardsilogic@0
|
65
|
lbajardsilogic@0
|
66 struct OrderComparator {
|
lbajardsilogic@0
|
67 bool operator()(const TextPoint &p1,
|
lbajardsilogic@0
|
68 const TextPoint &p2) const {
|
lbajardsilogic@0
|
69 return p1.frame < p2.frame;
|
lbajardsilogic@0
|
70 }
|
lbajardsilogic@0
|
71 };
|
lbajardsilogic@0
|
72 };
|
lbajardsilogic@0
|
73
|
lbajardsilogic@0
|
74
|
lbajardsilogic@0
|
75 // Make this a class rather than a typedef so it can be predeclared.
|
lbajardsilogic@0
|
76
|
lbajardsilogic@0
|
77 class TextModel : public SparseModel<TextPoint>
|
lbajardsilogic@0
|
78 {
|
lbajardsilogic@0
|
79 public:
|
lbajardsilogic@0
|
80 TextModel(size_t sampleRate, size_t resolution, bool notifyOnAdd = true) :
|
lbajardsilogic@0
|
81 SparseModel<TextPoint>(sampleRate, resolution, notifyOnAdd)
|
lbajardsilogic@0
|
82 { }
|
lbajardsilogic@0
|
83
|
lbajardsilogic@0
|
84 virtual QString toXmlString(QString indent = "",
|
lbajardsilogic@0
|
85 QString extraAttributes = "") const
|
lbajardsilogic@0
|
86 {
|
lbajardsilogic@0
|
87 return SparseModel<TextPoint>::toXmlString
|
lbajardsilogic@0
|
88 (indent,
|
lbajardsilogic@0
|
89 QString("%1 subtype=\"text\"")
|
lbajardsilogic@0
|
90 .arg(extraAttributes));
|
lbajardsilogic@0
|
91 }
|
lbajardsilogic@49
|
92
|
lbajardsilogic@49
|
93 virtual void toXml(QTextStream &out,
|
lbajardsilogic@49
|
94 QString indent = "",
|
lbajardsilogic@49
|
95 QString extraAttributes = "") const
|
lbajardsilogic@49
|
96 {
|
lbajardsilogic@49
|
97 SparseModel<TextPoint>::toXml
|
lbajardsilogic@49
|
98 (out,
|
lbajardsilogic@49
|
99 indent,
|
lbajardsilogic@49
|
100 QString("%1 subtype=\"text\"").arg(extraAttributes));
|
lbajardsilogic@49
|
101 }
|
lbajardsilogic@0
|
102 };
|
lbajardsilogic@0
|
103
|
lbajardsilogic@0
|
104
|
lbajardsilogic@0
|
105 #endif
|
lbajardsilogic@0
|
106
|
lbajardsilogic@0
|
107
|
lbajardsilogic@0
|
108
|