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 #include "../core/Config.h"
31 #include "../../edit/qt/tools/VertexTool.h"
32 #include "../../edit/Utils.h"
33 #include "../../sam/rtree/Index.h"
34 
35 // Qt
36 #include <QMouseEvent>
37 
38 namespace te
39 {
40  namespace mnt
41  {
42  enum TEMNTEXPORT EditType
43  {
47  VERTEX_ADD,
51  NONE
52  };
53 
55  {
56  Q_OBJECT
57 
58  public:
59  ProfileTools(te::qt::widgets::MapDisplay* display, const te::map::AbstractLayerPtr& layer, QObject* parent = 0);
60 
61  ~ProfileTools();
62 
63  void setType(EditType t);
64 
65  EditType getType() { return m_type; }
66 
67  void setLines(std::vector<te::gm::LineString*> &l);
68 
69  std::vector<te::gm::LineString*> getLines() { return m_lines; }
70 
71  bool mousePressEvent(QMouseEvent* e);
72 
73  bool mouseMoveEvent(QMouseEvent* e);
74 
75  bool mouseReleaseEvent(QMouseEvent* e);
76 
77  bool mouseDoubleClickEvent(QMouseEvent* e);
78 
79  protected:
80  EditType m_type;
81 
82  };
83  }
84 }
85 
86 #endif //__TERRALIB_MNT_INTERNAL_PROFILETOOLS_H
LINE_SELECT
Definition: ProfileTools.h:44
LINE_INVERT
Definition: ProfileTools.h:44
VERTEX_ADD
Definition: ProfileTools.h:44
#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:44
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:44
This class implements a concrete tool for vertex operations (move, add, etc.).
Definition: VertexTool.h:74
URI C++ Library.
std::vector< te::gm::LineString * > getLines()
Definition: ProfileTools.h:69
LINE_DELETE
Definition: ProfileTools.h:44
boost::intrusive_ptr< AbstractLayer > AbstractLayerPtr
LINE_CREATE
Definition: ProfileTools.h:44