-
Notifications
You must be signed in to change notification settings - Fork 16
/
plot.cpp
74 lines (59 loc) · 2.68 KB
/
plot.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
/*
USRP_Software_defined_radar is a software for real time sampling, processing, display and storing
Copyright (C) 2018 Jonas Myhre Christiansen <[email protected]>
This file is part of USRP_Software_defined_radar.
USRP_Software_defined_radar is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
USRP_Software_defined_radar is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with USRP_Software_defined_radar. If not, see <https://www.gnu.org/licenses/>.
*/
#include "plot.h"
Plot::Plot( QWidget *parent ):
QwtPlot( parent )
{
QwtPlotCanvas *canvas = new QwtPlotCanvas();
canvas->setBorderRadius( 10 );
setCanvas( canvas );
d_spectrogram = new QwtPlotSpectrogram();
d_spectrogram->setRenderThreadCount( 0 ); // use system specific thread count
d_spectrogram->setColorMap( new ColorMap() );
d_spectrogram->attach( this );
d_curve = new QwtPlotCurve();
d_curve->setStyle(QwtPlotCurve::NoCurve);
d_curve->setSymbol(new QwtSymbol(QwtSymbol::Diamond, Qt::white, QPen(Qt::black, 1), QSize(10,10)));
d_curve->attach(this);
t_curve = new QwtPlotCurve();
t_curve->setStyle(QwtPlotCurve::NoCurve);
t_curve->setSymbol(new QwtSymbol(QwtSymbol::RTriangle, Qt::green, QPen(Qt::black, 1), QSize(7,7)));
t_curve->attach(this);
QwtPlotMagnifier *magnifier = new QwtPlotMagnifier( canvas );
magnifier->setAxisEnabled( QwtPlot::yRight, false );
QwtPlotPanner *panner = new QwtPlotPanner( canvas );
panner->setAxisEnabled( QwtPlot::yRight, false );
QwtPlotPicker* clickPicker = new QwtPlotPicker(this->canvas());
clickPicker->setStateMachine(new QwtPickerClickPointMachine);
clickPicker->setMousePattern(QwtPicker::MouseSelect1, Qt::MiddleButton);
connect(clickPicker, SIGNAL(appended(QPointF)),
this, SLOT(pointSelected(QPointF)));
}
void Plot::exportPlot()
{
QwtPlotRenderer renderer;
renderer.exportTo( this, "rasterview.pdf" );
}
void Plot::setResampleMode( int mode )
{
QwtMatrixRasterData *data = static_cast<QwtMatrixRasterData *>( d_spectrogram->data() );
data->setResampleMode(
static_cast<QwtMatrixRasterData::ResampleMode>( mode ) );
replot();
}
void Plot::pointSelected(QPointF point) {
emit selectedPoint(point);
}