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 
57  public:
58  ProfileTools(te::qt::widgets::MapDisplay* display, const te::map::AbstractLayerPtr& layer, QObject* parent = 0);
59 
60  ~ProfileTools();
61 
62  void setType(EditType t);
63 
64  EditType getType() { return m_type; }
65 
66  void setLines(std::vector<te::gm::LineString*> &l);
67 
68  std::vector<te::gm::LineString*> getLines() { return m_lines; }
69 
70  bool mousePressEvent(QMouseEvent* e);
71 
72  bool mouseMoveEvent(QMouseEvent* e);
73 
74  bool mouseReleaseEvent(QMouseEvent* e);
75 
76  bool mouseDoubleClickEvent(QMouseEvent* e);
77 
78  protected:
79  EditType m_type;
80 
81  };
82  }
83 }
84 
85 #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:69
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:68
LINE_DELETE
Definition: ProfileTools.h:44
boost::intrusive_ptr< AbstractLayer > AbstractLayerPtr
LINE_CREATE
Definition: ProfileTools.h:44