Loading...
Searching...
No Matches
ProfileTools.h
Go to the documentation of this file.
1/* Copyright (C) 2008 National Institute For Space Research (INPE) - Brazil.
2
3This file is part of the TerraLib - a Framework for building GIS enabled applications.
4
5TerraLib is free software: you can redistribute it and/or modify
6it under the terms of the GNU Lesser General Public License as published by
7the Free Software Foundation, either version 3 of the License,
8or (at your option) any later version.
9
10TerraLib is distributed in the hope that it will be useful,
11but WITHOUT ANY WARRANTY; without even the implied warranty of
12MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13GNU Lesser General Public License for more details.
14
15You should have received a copy of the GNU Lesser General Public License
16along with TerraLib. See COPYING. If not, write to
17TerraLib 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
40namespace te
41{
42 namespace mnt
43 {
44 enum TEMNTEXPORT EditType
45 {
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
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
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
VERTEX_MOVE
Definition: ProfileTools.h:48
LINE_CREATE
Definition: ProfileTools.h:47
LINE_SELECT
Definition: ProfileTools.h:46
VERTEX_ADD
Definition: ProfileTools.h:49
LINE_INVERT
Definition: ProfileTools.h:52
LINE_DELETE
Definition: ProfileTools.h:51
VERTEX_DELETE
Definition: ProfileTools.h:50
This class implements a concrete tool for vertex operations (move, add, etc.).
Definition: VertexTool.h:75
bool mouseDoubleClickEvent(QMouseEvent *e)
This event handler can be reimplemented in a concrete tool class to receive mouse double click events...
void setLines(std::vector< te::gm::LineString * > &l)
void setType(EditType t)
bool mousePressEvent(QMouseEvent *e)
This event handler can be reimplemented in a concrete tool class to receive mouse press events for th...
bool mouseReleaseEvent(QMouseEvent *e)
This event handler can be reimplemented in a concrete tool class to receive mouse release events for ...
ProfileTools(te::qt::widgets::MapDisplay *display, const te::map::AbstractLayerPtr &layer, QObject *parent=0)
std::vector< te::gm::LineString * > getLines()
Definition: ProfileTools.h:71
bool mouseMoveEvent(QMouseEvent *e)
This event handler can be reimplemented in a concrete tool class to receive mouse move events for the...
A widget to control the display of a set of layers.
Definition: MapDisplay.h:72
boost::intrusive_ptr< AbstractLayer > AbstractLayerPtr
TerraLib.
#define TEMNTEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:41