SpatialStatisticsDialog.h
Go to the documentation of this file.
1 /* Copyright (C) 2008 National Institute For Space Research (INPE) - Brazil.
2 
3  This file is part of the TerraLib - a Framework for building GIS enabled applications.
4 
5  TerraLib is free software: you can redistribute it and/or modify
6  it under the terms of the GNU Lesser General Public License as published by
7  the Free Software Foundation, either version 3 of the License,
8  or (at your option) any later version.
9 
10  TerraLib is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  GNU Lesser General Public License for more details.
14 
15  You should have received a copy of the GNU Lesser General Public License
16  along with TerraLib. See COPYING. If not, write to
17  TerraLib Team at <terralib-team@terralib.org>.
18  */
19 
20 /*!
21  \file terralib/sa/qt/SpatialStatisticsDialog.h
22 
23  \brief A dialog to calculate spatial statistics from a attribute of a dataset.
24 */
25 
26 #ifndef __TERRALIB_SA_INTERNAL_SPATIALSTATISTICSDIALOG_H
27 #define __TERRALIB_SA_INTERNAL_SPATIALSTATISTICSDIALOG_H
28 
29 // TerraLib
30 #include "../../dataaccess/datasource/DataSourceInfo.h"
31 #include "../../maptools/AbstractLayer.h"
32 #include "../core/GeneralizedProximityMatrix.h"
33 #include "../Config.h"
34 #include "../Enums.h"
35 
36 // Qt
37 #include <QDialog>
38 
39 namespace Ui { class SpatialStatisticsDialogForm; }
40 
41 // Forward declarations
42 
43 namespace te
44 {
45  namespace sa
46  {
47 // Forward declarations
48 
49 
50  class TESAEXPORT SpatialStatisticsDialog : public QDialog
51  {
52  Q_OBJECT
53 
54  public:
55 
56  SpatialStatisticsDialog(QWidget* parent = 0, Qt::WindowFlags f = 0);
57 
59 
60  /*!
61  \brief Set the layer that can be used
62 
63  \param layers List of AbstractLayerPtr
64  */
65  void setLayers(std::list<te::map::AbstractLayerPtr> layers);
66 
67  te::map::AbstractLayerPtr getOutputLayer();
68 
69  protected slots:
70 
71  void onInputLayerComboBoxActivated(int index);
72 
73  void onGPMToolButtonClicked();
74 
75  void onOkPushButtonClicked();
76 
77  void onTargetDatasourceToolButtonPressed();
78 
79  void onTargetFileToolButtonPressed();
80 
81  protected:
82 
83  std::auto_ptr<te::sa::GeneralizedProximityMatrix> loadGPM();
84 
85  private:
86 
87  std::auto_ptr<Ui::SpatialStatisticsDialogForm> m_ui;
88 
90 
92 
93  bool m_toFile;
94  };
95  } // end namespace sa
96 } // end namespace te
97 
98 #endif // __TERRALIB_SA_INTERNAL_SPATIALSTATISTICSDIALOG_H
te::map::AbstractLayerPtr m_outputLayer
Generated Layer.
std::auto_ptr< Ui::SpatialStatisticsDialogForm > m_ui
te::da::DataSourceInfoPtr m_outputDatasource
URI C++ Library.
#define TESAEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:133
boost::intrusive_ptr< AbstractLayer > AbstractLayerPtr
boost::shared_ptr< DataSourceInfo > DataSourceInfoPtr