forked from seub/Harmony
-
Notifications
You must be signed in to change notification settings - Fork 0
/
canvasdelegatetests.cpp
92 lines (70 loc) · 2.1 KB
/
canvasdelegatetests.cpp
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
#include "canvasdelegatetests.h"
#include <QImage>
void CanvasDelegateTests::plotSequences()
{
rescaleForPlottingSequences();
drawSegment(Complex(0.0, yMin()), Complex(0.0, yMax));
drawSegment(Complex(xMin, 0.0), Complex(xMax(), 0.0));
uint i, n;
for (i=0; i!=sequences.size(); ++i)
{
for (n=0; n< sequences[i].size(); ++n)
{
drawPoint(Complex(n+1, sequences[i][n]), sequencesColors[i], 2);
}
}
}
void CanvasDelegateTests::rescaleForPlottingSequences()
{
std::vector<double> maxs;
for (const auto &sequence : sequences)
{
maxs.push_back(*std::max_element(sequence.begin(), sequence.end()));
}
double max = *std::max_element(maxs.begin(), maxs.end());
double mathsSizeY = 1.1*max;
yMax = 1.05*max;
std::vector<uint> sequencesNbElements;
for (const auto &sequence : sequences)
{
sequencesNbElements.push_back(sequence.size());
}
max = *std::max_element(sequencesNbElements.begin(), sequencesNbElements.end());
double mathsSizeX = 1.1*max;
xMin = -0.05*max;
scaleX = sizeX/mathsSizeX;
scaleY = sizeY/mathsSizeY;
}
void CanvasDelegateTests::addSequence(const std::vector<double> sequence, const QColor &color)
{
sequences.push_back(sequence);
sequencesColors.push_back(color);
}
void CanvasDelegateTests::redraw(bool back, bool top)
{
CanvasDelegate::redraw(back, top);
plotSequences();
}
void CanvasDelegateTests2::plotSequences()
{
uint i, n;
for (i=0; i!=sequences.size(); ++i)
{
for (n=0; n+1< sequences[i].size(); ++n)
{
drawH2Point(sequences[i][n], sequencesColors[i], 2);
}
drawH2Point(sequences[i].back(), "red", 4);
drawH2GeodesicArc(H2GeodesicArc(sequences[i].front(), sequences[i].back()));
}
}
void CanvasDelegateTests2::addSequence(const std::vector<H2Point> sequence, const QColor &color)
{
sequences.push_back(sequence);
sequencesColors.push_back(color);
}
void CanvasDelegateTests2::redraw(bool back, bool top)
{
H2CanvasDelegate::redraw(back, top);
plotSequences();
}