-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlineplot.h
190 lines (150 loc) · 6.94 KB
/
lineplot.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
#ifndef LINEPLOT_H
#define LINEPLOT_H
#include <memory>
#include <set>
#include <vector>
#include <QQuickFramebufferObject>
#include <armadillo>
// From CUBu
#include "gdrawing.h"
#include "colorscale.h"
#include "scale.h"
// (private) Implementation of QQuickFramebufferObject::Renderer
class LinePlotRenderer;
class LinePlot
: public QQuickFramebufferObject
{
Q_OBJECT
// Main bundling
Q_PROPERTY(int iterations READ iterations WRITE setIterations NOTIFY iterationsChanged)
Q_PROPERTY(float kernelSize READ kernelSize WRITE setKernelSize NOTIFY kernelSizeChanged)
Q_PROPERTY(float smoothingFactor READ smoothingFactor WRITE setSmoothingFactor NOTIFY smoothingFactorChanged)
Q_PROPERTY(int smoothingIterations READ smoothingIterations WRITE setSmoothingIterations NOTIFY smoothingIterationsChanged)
// Ends bundling
Q_PROPERTY(bool blockEndpoints READ blockEndpoints WRITE setBlockEndpoints NOTIFY blockEndpointsChanged)
Q_PROPERTY(int endsIterations READ endsIterations WRITE setEndsIterations NOTIFY endsIterationsChanged)
Q_PROPERTY(float endsKernelSize READ endsKernelSize WRITE setEndsKernelSize NOTIFY endsKernelSizeChanged)
Q_PROPERTY(float endsSmoothingFactor READ endsSmoothingFactor WRITE setEndsSmoothingFactor NOTIFY endsSmoothingFactorChanged)
// General bundling options
Q_PROPERTY(float edgeSampling READ edgeSampling WRITE setEdgeSampling NOTIFY edgeSamplingChanged)
Q_PROPERTY(float advectionSpeed READ advectionSpeed WRITE setAdvectionSpeed NOTIFY advectionSpeedChanged)
Q_PROPERTY(float relaxation READ relaxation WRITE setRelaxation NOTIFY relaxationChanged)
Q_PROPERTY(bool bundleGPU READ bundleGPU WRITE setBundleGPU NOTIFY bundleGPUChanged)
Q_PROPERTY(float lineWidth READ lineWidth WRITE setLineWidth NOTIFY lineWidthChanged)
public:
static const int PADDING = 20;
LinePlot(QQuickItem *parent = 0);
void setColorScale(const ColorScale *scale);
const GraphDrawing *graphDrawing() const { return &m_gdFinal; }
const arma::uvec &indices() const { return m_indices; }
const arma::mat &points() const { return m_Y; }
const std::vector<float> &values() const { return m_values; }
const std::vector<float> &colorScale() const { return m_cmap; }
LinearScale<float> scaleX() const { return m_sx; }
LinearScale<float> scaleY() const { return m_sy; }
Renderer *createRenderer() const;
bool linesChanged() const { return m_linesChanged; }
bool valuesChanged() const { return m_valuesChanged; }
bool colorScaleChanged() const { return m_colorScaleChanged; }
void setLinesChanged(bool linesChanged) {
m_linesChanged = linesChanged;
}
void setValuesChanged(bool valuesChanged) {
m_valuesChanged = valuesChanged;
}
void setColorScaleChanged(bool colorScaleChanged) {
m_colorScaleChanged = colorScaleChanged;
}
// Q_PROPERTY's
int iterations() const { return m_iterations; }
float kernelSize() const { return m_kernelSize; }
float smoothingFactor() const { return m_smoothingFactor; }
int smoothingIterations() const { return m_smoothingIterations; }
void setIterations(int iterations);
void setKernelSize(float kernelSize);
void setSmoothingFactor(float smoothingFactor);
void setSmoothingIterations(int smoothingIterations);
bool blockEndpoints() const { return m_blockEndpoints; }
int endsIterations() const { return m_endsIterations; }
float endsKernelSize() const { return m_endsKernelSize; }
float endsSmoothingFactor() const { return m_endsSmoothingFactor; }
void setBlockEndpoints(bool blockEndpoints);
void setEndsIterations(int endsIterations);
void setEndsKernelSize(float endsKernelSize);
void setEndsSmoothingFactor(float endsSmoothingFactor);
float edgeSampling() const { return m_edgeSampling; }
float advectionSpeed() const { return m_advectionSpeed; }
float relaxation() const { return m_relaxation; }
bool bundleGPU() const { return m_bundleGPU; }
float lineWidth() const { return m_lineWidth; }
void setEdgeSampling(float edgeSampling);
void setAdvectionSpeed(float advectionSpeed);
void setRelaxation(float relaxation);
void setBundleGPU(bool bundleGPU);
void setLineWidth(float lineWidth);
signals:
void indicesChanged(const arma::uvec &indices);
void pointsChanged(const arma::mat &Y);
void valuesChanged(const arma::vec &values) const;
void scaleChanged(const LinearScale<float> &sx,
const LinearScale<float> &sy) const;
void itemBrushed(int item) const;
void selectionChanged(const std::vector<bool> &selection) const;
// Q_PROPERTY's
void iterationsChanged(int iterations) const;
void kernelSizeChanged(float kernelSize) const;
void smoothingFactorChanged(float smoothingFactor) const;
void smoothingIterationsChanged(int smoothingIterations) const;
void blockEndpointsChanged(bool blockEndpoints) const;
void endsIterationsChanged(int endsIterations) const;
void endsKernelSizeChanged(float endsKernelSize) const;
void endsSmoothingFactorChanged(float endsSmoothingFactor) const;
void edgeSamplingChanged(float edgeSampling) const;
void advectionSpeedChanged(float advectionSpeed) const;
void relaxationChanged(float relaxation) const;
void bundleGPUChanged(bool bundleGPU) const;
void lineWidthChanged(float lineWidth) const;
public slots:
// Lines are two consecutive elements in 'indices' (ref. points in 'Y')
void setLines(const arma::uvec &indices, const arma::mat &Y);
// One value for each line
void setValues(const arma::vec &values);
void setScale(const LinearScale<float> &sx,
const LinearScale<float> &sy);
void brushItem(int item);
void setSelection(const std::vector<bool> &selection);
private:
void buildGraph();
void bundle();
void relax();
// Data
arma::uvec m_indices;
arma::mat m_Y;
std::vector<float> m_values;
// Visuals
std::vector<float> m_cmap;
LinearScale<float> m_sx, m_sy;
std::unique_ptr<GraphDrawing> m_gdPtr;
GraphDrawing m_gdBundle, m_gdFinal;
// Internal state
int m_brushedItem;
std::vector<bool> m_selection;
bool m_anySelected;
bool m_linesChanged, m_valuesChanged, m_colorScaleChanged, m_updateOffsets;
// Q_PROPERTY's
int m_iterations;
float m_kernelSize;
float m_smoothingFactor;
int m_smoothingIterations;
bool m_blockEndpoints;
int m_endsIterations;
float m_endsKernelSize;
float m_endsSmoothingFactor;
float m_edgeSampling;
float m_advectionSpeed;
float m_relaxation;
bool m_bundleGPU;
float m_lineWidth;
friend class LinePlotRenderer;
};
#endif // LINEPLOT_H