GNU Radio Manual and C++ API Reference  3.7.4.1
The Free & Open Software Radio Ecosystem
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
waterfalldisplayform.h
Go to the documentation of this file.
1 /* -*- c++ -*- */
2 /*
3  * Copyright 2012 Free Software Foundation, Inc.
4  *
5  * This file is part of GNU Radio
6  *
7  * GNU Radio is free software; you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License as published by
9  * the Free Software Foundation; either version 3, or (at your option)
10  * any later version.
11  *
12  * GNU Radio is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with GNU Radio; see the file COPYING. If not, write to
19  * the Free Software Foundation, Inc., 51 Franklin Street,
20  * Boston, MA 02110-1301, USA.
21  */
22 
23 #ifndef WATERFALL_DISPLAY_FORM_H
24 #define WATERFALL_DISPLAY_FORM_H
25 
28 #include <QtGui/QtGui>
29 #include <vector>
30 #include <gnuradio/filter/firdes.h>
31 
33 
34 /*!
35  * \brief DisplayForm child for managing waterfall (spectrogram) plots.
36  * \ingroup qtgui_blk
37  */
39 {
40  Q_OBJECT
41 
42  public:
43  WaterfallDisplayForm(int nplots=1, QWidget* parent = 0);
45 
47 
48  int getFFTSize() const;
49  float getFFTAverage() const;
51 
52  int getColorMap(int which);
53  int getAlpha(int which);
54  double getMinIntensity(int which);
55  double getMaxIntensity(int which);
56 
57  void clearData();
58 
59  // returns the frequency that was last double-clicked on by the user
60  float getClickedFreq() const;
61 
62  // checks if there was a double-click event; reset if there was
63  bool checkClicked();
64 
65 public slots:
66  void customEvent(QEvent *e);
67 
68  void setSampleRate(const QString &samprate);
69  void setFFTSize(const int);
70  void setFFTAverage(const float);
72 
73  void setFrequencyRange(const double centerfreq,
74  const double bandwidth);
75 
76  void setIntensityRange(const double minIntensity,
77  const double maxIntensity);
78 
79  void setAlpha(int which, int alpha);
80 
81  void setColorMap(int which,
82  const int newType,
83  const QColor lowColor=QColor("white"),
84  const QColor highColor=QColor("white"));
85 
86  void autoScale(bool en=false);
87 
88 private slots:
89  void newData(const QEvent *updateEvent);
90  void onPlotPointSelected(const QPointF p);
91 
92 private:
93  QIntValidator* d_int_validator;
94 
95  double d_samp_rate, d_center_freq;
96  int d_fftsize;
97  float d_fftavg;
98  gr::filter::firdes::win_type d_fftwintype;
99  double d_units;
100 
101  bool d_clicked;
102  double d_clicked_freq;
103 
104  double d_min_val;
105  double d_max_val;
106 
107  FFTSizeMenu *d_sizemenu;
108  FFTAverageMenu *d_avgmenu;
109  FFTWindowMenu *d_winmenu;
110 };
111 
112 #endif /* WATERFALL_DISPLAY_FORM_H */
QWidget for displaying waterfall (spectrogram) plots.
Definition: WaterfallDisplayPlot.h:44
Base class for setting up and managing QTGUI plot forms.
Definition: displayform.h:41
void setFFTAverage(const float)
gr::filter::firdes::win_type getFFTWindowType() const
float getFFTAverage() const
float getClickedFreq() const
void setSampleRate(const QString &samprate)
void customEvent(QEvent *e)
void setFrequencyRange(const double centerfreq, const double bandwidth)
void setColorMap(int which, const int newType, const QColor lowColor=QColor("white"), const QColor highColor=QColor("white"))
void setAlpha(int which, int alpha)
Definition: form_menus.h:747
void setFFTSize(const int)
Definition: form_menus.h:627
void setFFTWindowType(const gr::filter::firdes::win_type)
int getColorMap(int which)
Definition: form_menus.h:868
void setIntensityRange(const double minIntensity, const double maxIntensity)
WaterfallDisplayForm(int nplots=1, QWidget *parent=0)
DisplayForm child for managing waterfall (spectrogram) plots.
Definition: waterfalldisplayform.h:38
WaterfallDisplayPlot * getPlot()
void autoScale(bool en=false)
double getMinIntensity(int which)
double getMaxIntensity(int which)
int getFFTSize() const
win_type
Definition: firdes.h:45
int getAlpha(int which)