source: ntrip/trunk/BNC/src/rinex/graphwin.cpp@ 4573

Last change on this file since 4573 was 4573, checked in by mervart, 12 years ago
File size: 5.5 KB
Line 
1// Part of BNC, a utility for retrieving decoding and
2// converting GNSS data streams from NTRIP broadcasters.
3//
4// Copyright (C) 2007
5// German Federal Agency for Cartography and Geodesy (BKG)
6// http://www.bkg.bund.de
7// Czech Technical University Prague, Department of Geodesy
8// http://www.fsv.cvut.cz
9//
10// Email: euref-ip@bkg.bund.de
11//
12// This program is free software; you can redistribute it and/or
13// modify it under the terms of the GNU General Public License
14// as published by the Free Software Foundation, version 2.
15//
16// This program is distributed in the hope that it will be useful,
17// but WITHOUT ANY WARRANTY; without even the implied warranty of
18// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19// GNU General Public License for more details.
20//
21// You should have received a copy of the GNU General Public License
22// along with this program; if not, write to the Free Software
23// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
24
25/* -------------------------------------------------------------------------
26 * BKG NTRIP Client
27 * -------------------------------------------------------------------------
28 *
29 * Class: t_graphWin
30 *
31 * Purpose: Window for plots
32 *
33 * Author: L. Mervart
34 *
35 * Created: 23-Jun-2012
36 *
37 * Changes:
38 *
39 * -----------------------------------------------------------------------*/
40
41#include "graphwin.h"
42#include "qwt_scale_widget.h"
43#include <qwt_scale_engine.h>
44
45using namespace std;
46
47// Constructor
48////////////////////////////////////////////////////////////////////////////
49t_graphWin::t_graphWin(QWidget* parent, const QString& fileName,
50 const QVector<QWidget*>& plots,
51 const QByteArray* scaleTitle,
52 const QwtInterval* scaleInterval) : QDialog(parent) {
53
54 _fileName = fileName;
55
56 this->setAttribute(Qt::WA_DeleteOnClose);
57
58 setWindowTitle(_fileName);
59
60 int ww = QFontMetrics(font()).width('w');
61 setMinimumSize(plots.size()*40*ww, 40*ww);
62
63 // Buttons
64 // -------
65 _buttonClose = new QPushButton(tr("Close"), this);
66 _buttonClose->setMaximumWidth(10*ww);
67 connect(_buttonClose, SIGNAL(clicked()), this, SLOT(slotClose()));
68
69 _buttonPrint = new QPushButton(tr("Print"), this);
70 _buttonPrint->setMaximumWidth(10*ww);
71 connect(_buttonPrint, SIGNAL(clicked()), this, SLOT(slotPrint()));
72
73 // Color Scale
74 // -----------
75 if (scaleTitle && scaleInterval) {
76 _colorScale = new QwtScaleWidget( this );
77 _colorScale->setAlignment( QwtScaleDraw::RightScale );
78 _colorScale->setColorBarEnabled( true );
79
80 QwtText title(*scaleTitle);
81 QFont font = _colorScale->font();
82 font.setBold( true );
83 title.setFont( font );
84 _colorScale->setTitle( title );
85
86 _colorScale->setColorMap(*scaleInterval, new t_colorMap());
87
88 QwtLinearScaleEngine scaleEngine;
89 _colorScale->setScaleDiv(scaleEngine.transformation(),
90 scaleEngine.divideScale(scaleInterval->minValue(),
91 scaleInterval->maxValue(),
92 8, 5));
93 }
94 else {
95 _colorScale = 0;
96 }
97
98 // Layout
99 // ------
100 _canvas = new QWidget(this);
101 QHBoxLayout* plotLayout = new QHBoxLayout(_canvas);
102 for (int ip = 0; ip < plots.size(); ip++) {
103 plotLayout->addWidget(plots[ip]);
104 }
105 if (_colorScale) {
106 plotLayout->addWidget(_colorScale);
107 }
108
109 QHBoxLayout* buttonLayout = new QHBoxLayout;
110 buttonLayout->addWidget(_buttonClose);
111 buttonLayout->addWidget(_buttonPrint);
112
113 QVBoxLayout* mainLayout = new QVBoxLayout(this);
114 mainLayout->addWidget(_canvas);
115 mainLayout->addLayout(buttonLayout);
116}
117
118// Destructor
119////////////////////////////////////////////////////////////////////////////
120t_graphWin::~t_graphWin() {
121}
122
123// Accept the Options
124////////////////////////////////////////////////////////////////////////////
125void t_graphWin::slotClose() {
126 done(0);
127}
128
129// Close Dialog gracefully
130////////////////////////////////////////////////////////////////////////////
131void t_graphWin::closeEvent(QCloseEvent* event) {
132 QDialog::closeEvent(event);
133}
134
135// Print the widget
136////////////////////////////////////////////////////////////////////////////
137void t_graphWin::slotPrint() {
138
139 QPrinter printer;
140 QPrintDialog* dialog = new QPrintDialog(&printer, this);
141 dialog->setWindowTitle(tr("Print Plot"));
142 if (dialog->exec() != QDialog::Accepted) {
143 return;
144 }
145 else {
146 QPainter painter;
147 painter.begin(&printer);
148 double xscale = printer.pageRect().width()/double(_canvas->width());
149 double yscale = printer.pageRect().height()/double(_canvas->height());
150 double scale = qMin(xscale, yscale);
151 painter.translate(printer.paperRect().x() + printer.pageRect().width()/2,
152 printer.paperRect().y() + printer.pageRect().height()/2);
153 painter.scale(scale, scale);
154 painter.translate(-width()/2, -height()/2);
155 _canvas->render(&painter);
156 }
157}
158
159// Save the Widget as PNG Files
160////////////////////////////////////////////////////////////////////////////
161void t_graphWin::savePNG(const QString& dirName, QByteArray ext) {
162 if (dirName.isEmpty()) {
163 return;
164 }
165 QImage image(_canvas->size(), QImage::Format_RGB32);
166 QPainter painter(&image);
167 _canvas->render(&painter);
168 QDir dir(dirName);
169 QFileInfo fileInfo(_fileName);
170 if (ext.isEmpty()) {
171 ext = ".png";
172 }
173 QString fileName = dir.path() + QDir::separator()
174 + fileInfo.completeBaseName() + ext;
175 image.save(fileName,"PNG");
176}
Note: See TracBrowser for help on using the repository browser.