SciDAVis  1.D4
Double2MonthFilter.h
Go to the documentation of this file.
1 /***************************************************************************
2  File : Double2MonthFilter.h
3  Project : SciDAVis
4  --------------------------------------------------------------------
5  Copyright : (C) 2007 by Knut Franke, Tilman Benkert
6  Email (use @ for *) : knut.franke*gmx.de, thzs@gmx.net
7  Description : Conversion filter double -> QDateTime, interpreting
8  the input numbers as months of the year.
9 
10  ***************************************************************************/
11 
12 /***************************************************************************
13  * *
14  * This program is free software; you can redistribute it and/or modify *
15  * it under the terms of the GNU General Public License as published by *
16  * the Free Software Foundation; either version 2 of the License, or *
17  * (at your option) any later version. *
18  * *
19  * This program is distributed in the hope that it will be useful, *
20  * but WITHOUT ANY WARRANTY; without even the implied warranty of *
21  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
22  * GNU General Public License for more details. *
23  * *
24  * You should have received a copy of the GNU General Public License *
25  * along with this program; if not, write to the Free Software *
26  * Foundation, Inc., 51 Franklin Street, Fifth Floor, *
27  * Boston, MA 02110-1301 USA *
28  * *
29  ***************************************************************************/
30 #ifndef DOUBLE2MONTH_FILTER_H
31 #define DOUBLE2MONTH_FILTER_H
32 
33 #include "../AbstractSimpleFilter.h"
34 #include <QDateTime>
35 #include <math.h>
36 #include "lib/XmlStreamReader.h"
37 #include <QXmlStreamWriter>
38 
41 {
42  Q_OBJECT
43  public:
44  virtual QDate dateAt(int row) const {
45  return dateTimeAt(row).date();
46  }
47  virtual QTime timeAt(int row) const {
48  return dateTimeAt(row).time();
49  }
50  virtual QDateTime dateTimeAt(int row) const {
51  if (!d_inputs.value(0)) return QDateTime();
52  double input_value = d_inputs.value(0)->valueAt(row);
53  // Don't use Julian days here since support for years < 1 is bad
54  // Use 1900-01-01 instead
55  QDate result_date = QDate(1900,1,1).addMonths(qRound(input_value - 1.0));
56  QTime result_time = QTime(0,0,0,0);
57  return QDateTime(result_date, result_time);
58  }
59 
62 
63  protected:
64  virtual bool inputAcceptable(int, const AbstractColumn *source) {
65  return source->dataType() == SciDAVis::TypeDouble;
66  }
67 };
68 
69 #endif // ifndef DOUBLE2MONTH_FILTER_H
70