ProfileTools.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/mnt/qt/ProfileTools.h
22 
23 \brief This file defines the profile trajectory edition tools
24 */
25 
26 #ifndef __TERRALIB_MNT_INTERNAL_PROFILETOOLS_H
27 #define __TERRALIB_MNT_INTERNAL_PROFILETOOLS_H
28 
29 // TerraLib
30 #ifndef Q_MOC_RUN
31 #include "../../edit/qt/tools/VertexTool.h"
32 #include "../../edit/Utils.h"
33 #include "../../sam/rtree/Index.h"
34 #endif
35 #include "../core/Config.h"
36 
37 // Qt
38 #include <QMouseEvent>
39 
40 namespace te
41 {
42  namespace mnt
43  {
44  enum TEMNTEXPORT EditType
45  {
49  VERTEX_ADD,
53  NONE
54  };
55 
57  {
58  Q_OBJECT
59 
60  public:
61  ProfileTools(te::qt::widgets::MapDisplay* display, const te::map::AbstractLayerPtr& layer, QObject* parent = 0);
62 
63  ~ProfileTools();
64 
65  void setType(EditType t);
66 
67  EditType getType() { return m_type; }
68 
69  void setLines(std::vector<te::gm::LineString*> &l);
70 
71  std::vector<te::gm::LineString*> getLines() { return m_lines; }
72 
73  void updateRepository();
74 
75  bool mousePressEvent(QMouseEvent* e);
76 
77  bool mouseMoveEvent(QMouseEvent* e);
78 
79  bool mouseReleaseEvent(QMouseEvent* e);
80 
81  bool mouseDoubleClickEvent(QMouseEvent* e);
82 
83  protected:
84  EditType m_type;
85 
86  };
87  }
88 }
89 
90 #endif //__TERRALIB_MNT_INTERNAL_PROFILETOOLS_H
LINE_SELECT
Definition: ProfileTools.h:46
LINE_INVERT
Definition: ProfileTools.h:46
VERTEX_ADD
Definition: ProfileTools.h:46
#define TEMNTEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:41
VERTEX_DELETE
Definition: ProfileTools.h:46
A widget to control the display of a set of layers.
Definition: MapDisplay.h:71
Not visible.
Definition: TreeItem.h:60
VERTEX_MOVE
Definition: ProfileTools.h:46
This class implements a concrete tool for vertex operations (move, add, etc.).
Definition: VertexTool.h:74
TerraLib.
std::vector< te::gm::LineString * > getLines()
Definition: ProfileTools.h:71
LINE_DELETE
Definition: ProfileTools.h:46
boost::intrusive_ptr< AbstractLayer > AbstractLayerPtr
LINE_CREATE
Definition: ProfileTools.h:46