1
#include <qwt_color_map.h>
2
#include <qwt_plot_spectrogram.h>
3
#include <qwt_scale_widget.h>
4
#include <qwt_scale_draw.h>
5
#include <qwt_plot_zoomer.h>
6
#include <qwt_plot_panner.h>
7
#include <qwt_plot_layout.h>
10
class SpectrogramData: public QwtRasterData
14
QwtRasterData(QwtDoubleRect(-1.5, -1.5, 3.0, 3.0))
18
virtual QwtRasterData *copy() const
20
return new SpectrogramData();
23
virtual QwtDoubleInterval range() const
25
return QwtDoubleInterval(0.0, 10.0);
28
virtual double value(double x, double y) const
30
const double c = 0.842;
32
const double v1 = x * x + (y-c) * (y+c);
33
const double v2 = x * (y+c) + x * (y+c);
35
return 1.0 / (v1 * v1 + v2 * v2);
39
class MyZoomer: public QwtPlotZoomer
42
MyZoomer(QwtPlotCanvas* canvas):
45
setTrackerMode(QwtPicker::AlwaysOn);
49
virtual QwtText trackerText( const QwtDoublePoint& p ) const
51
QwtText t( QwtPlotPicker::trackerText( p ));
53
#if QT_VERSION >= 0x040300
56
t.setBackgroundBrush( QBrush(c) );
63
Plot::Plot(QWidget *parent):
66
d_spectrogram = new QwtPlotSpectrogram();
68
QwtLinearColorMap colorMap(Qt::darkCyan, Qt::red);
69
colorMap.addColorStop(0.1, Qt::cyan);
70
colorMap.addColorStop(0.6, Qt::green);
71
colorMap.addColorStop(0.95, Qt::yellow);
73
d_spectrogram->setColorMap(colorMap);
75
d_spectrogram->setData(SpectrogramData());
76
d_spectrogram->attach(this);
78
QwtValueList contourLevels;
79
for ( double level = 0.5; level < 10.0; level += 1.0 )
80
contourLevels += level;
81
d_spectrogram->setContourLevels(contourLevels);
83
QwtScaleWidget *rightAxis = axisWidget(QwtPlot::yRight);
84
rightAxis->setTitle("Intensity");
85
rightAxis->setColorBarEnabled(true);
86
rightAxis->setColorMap(d_spectrogram->data().range(),
87
d_spectrogram->colorMap());
89
setAxisScale(QwtPlot::yRight,
90
d_spectrogram->data().range().minValue(),
91
d_spectrogram->data().range().maxValue() );
92
enableAxis(QwtPlot::yRight);
94
plotLayout()->setAlignCanvasToScales(true);
97
// LeftButton for the zooming
98
// MidButton for the panning
99
// RightButton: zoom out by 1
100
// Ctrl+RighButton: zoom out to full size
102
QwtPlotZoomer* zoomer = new MyZoomer(canvas());
103
#if QT_VERSION < 0x040000
104
zoomer->setMousePattern(QwtEventPattern::MouseSelect2,
105
Qt::RightButton, Qt::ControlButton);
107
zoomer->setMousePattern(QwtEventPattern::MouseSelect2,
108
Qt::RightButton, Qt::ControlModifier);
110
zoomer->setMousePattern(QwtEventPattern::MouseSelect3,
113
QwtPlotPanner *panner = new QwtPlotPanner(canvas());
114
panner->setAxisEnabled(QwtPlot::yRight, false);
115
panner->setMouseButton(Qt::MidButton);
117
// Avoid jumping when labels with more/less digits
118
// appear/disappear when scrolling vertically
120
const QFontMetrics fm(axisWidget(QwtPlot::yLeft)->font());
121
QwtScaleDraw *sd = axisScaleDraw(QwtPlot::yLeft);
122
sd->setMinimumExtent( fm.width("100.00") );
124
const QColor c(Qt::darkBlue);
125
zoomer->setRubberBandPen(c);
126
zoomer->setTrackerPen(c);
129
void Plot::showContour(bool on)
131
d_spectrogram->setDisplayMode(QwtPlotSpectrogram::ContourMode, on);
135
void Plot::showSpectrogram(bool on)
137
d_spectrogram->setDisplayMode(QwtPlotSpectrogram::ImageMode, on);
138
d_spectrogram->setDefaultContourPen(on ? QPen() : QPen(Qt::NoPen));