blob: 5e828296211df72016aa3294285f988d7eb29075 (
plain)
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
|
#ifndef FREQUENCY_DISPLAY_PLOT_HPP
#define FREQUENCY_DISPLAY_PLOT_HPP
#include <cstdio>
#include <qwt_plot.h>
#include <qwt_painter.h>
#include <qwt_plot_canvas.h>
#include <qwt_plot_curve.h>
#include <qwt_scale_engine.h>
#include <qwt_scale_widget.h>
#include <qwt_plot_zoomer.h>
#include <qwt_plot_panner.h>
#include <qwt_plot_marker.h>
#include <highResTimeFunctions.h>
#include <qwt_symbol.h>
class FrequencyDisplayPlot:public QwtPlot{
Q_OBJECT
public:
FrequencyDisplayPlot(QWidget*);
virtual ~FrequencyDisplayPlot();
void SetFrequencyRange(const double, const double,
const double, const bool,
const double units=1000.0,
const std::string &strunits = "kHz");
double GetStartFrequency()const;
double GetStopFrequency()const;
void PlotNewData(const double* dataPoints, const int64_t numDataPoints,
const double noiseFloorAmplitude, const double peakFrequency,
const double peakAmplitude);
void ClearMaxData();
void ClearMinData();
void SetMaxFFTVisible(const bool);
void SetMinFFTVisible(const bool);
virtual void replot();
void set_yaxis(double min, double max);
public slots:
void SetLowerIntensityLevel(const double);
void SetUpperIntensityLevel(const double);
protected:
private:
void _resetXAxisPoints();
double _startFrequency;
double _stopFrequency;
double _maxYAxis;
double _minYAxis;
QwtPlotCurve* _fft_plot_curve;
QwtPlotCurve* _min_fft_plot_curve;
QwtPlotCurve* _max_fft_plot_curve;
QwtPlotMarker* _lower_intensity_marker;
QwtPlotMarker* _upper_intensity_marker;
QwtPlotPanner* _panner;
QwtPlotZoomer* _zoomer;
QwtPlotMarker *_markerPeakAmplitude;
QwtPlotMarker *_markerNoiseFloorAmplitude;
double* _dataPoints;
double* _xAxisPoints;
double* _minFFTPoints;
double* _maxFFTPoints;
int64_t _numPoints;
double _peakFrequency;
double _peakAmplitude;
double _noiseFloorAmplitude;
timespec _lastReplot;
bool _useCenterFrequencyFlag;
double _displayIntervalTime;
};
#endif /* FREQUENCY_DISPLAY_PLOT_HPP */
|