PointPicker.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/qt/widgets/tools/PointPicker.h
22 
23  \brief This class implements a concrete tool to geographic coordinate picker on mouse click operation.
24 */
25 
26 #ifndef __TERRALIB_QT_WIDGETS_INTERNAL_POINTPICKER_H
27 #define __TERRALIB_QT_WIDGETS_INTERNAL_POINTPICKER_H
28 
29 // TerraLib
30 #include "../Config.h"
31 #include "AbstractTool.h"
32 
33 // Forward declarations
34 class QPointF;
35 
36 namespace te
37 {
38  namespace qt
39  {
40  namespace widgets
41  {
42 // Forward declarations
43  class MapDisplay;
44 
45  /*!
46  \class PointPicker
47 
48  \brief This class implements a concrete tool to geographic coordinate picker on mouse click operation.
49  */
51  {
52  Q_OBJECT
53 
54  public:
55 
56  /** @name Initializer Methods
57  * Methods related to instantiation and destruction.
58  */
59  //@{
60 
61  /*!
62  \brief It constructs a coordinate tracking tool associated with the given map display.
63 
64  \param display The map display associated with the tool.
65  \param cursor The default tool cursor.
66  \param parent The tool's parent.
67 
68  \note The tool will NOT take the ownership of the given pointers.
69  */
70  PointPicker(MapDisplay* display, const QCursor& cursor, QObject* parent = 0);
71 
72  /*! \brief Destructor. */
74 
75  /*!
76  \brief It constructs a coordinate tracking tool associated with the given map display.
77  The mouse buttons to be listened can be set using this functions. For this, use the Qt enum MouseButton.
78  The following sintax can be used: setMouseButtons(Qt::LeftButton | Qt::RightButton)
79  */
80  void setMouseButtons(int buttons);
81 
82  //@}
83 
84  /** @name AbstractTool Methods
85  * Methods related with tool behavior.
86  */
87  //@{
88 
89  bool mousePressEvent(QMouseEvent* e);
90 
91  bool mouseMoveEvent(QMouseEvent* e);
92 
93  bool mouseReleaseEvent(QMouseEvent* e);
94 
95  //@}
96 
97  signals:
98 
99  /*! This signal is emitted when a coordinate was picked. */
100  void pointPicked(QPointF& coordinate);
101 
102  /*! This signal is emitted when a mouse moving. */
103  void pointPickerMoving(QPointF& coordinate);
104 
105  private:
107  };
108 
109  } // end namespace widgets
110  } // end namespace qt
111 } // end namespace te
112 
113 #endif // __TERRALIB_QT_WIDGETS_INTERNAL_POINTPICKER_H
Abstract tool concept.
This class defines an interface for objects that can receive application events and respond to them,...
Definition: AbstractTool.h:64
A widget to control the display of a set of layers.
Definition: MapDisplay.h:72
This class implements a concrete tool to geographic coordinate picker on mouse click operation.
Definition: PointPicker.h:51
PointPicker(MapDisplay *display, const QCursor &cursor, QObject *parent=0)
It constructs a coordinate tracking tool associated with the given map display.
void pointPickerMoving(QPointF &coordinate)
bool mousePressEvent(QMouseEvent *e)
This event handler can be reimplemented in a concrete tool class to receive mouse press events for th...
void pointPicked(QPointF &coordinate)
bool mouseReleaseEvent(QMouseEvent *e)
This event handler can be reimplemented in a concrete tool class to receive mouse release events for ...
void setMouseButtons(int buttons)
It constructs a coordinate tracking tool associated with the given map display. The mouse buttons to ...
bool mouseMoveEvent(QMouseEvent *e)
This event handler can be reimplemented in a concrete tool class to receive mouse move events for the...
TerraLib.
#define TEQTWIDGETSEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:63