PanMiddleClick.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/PanMiddleClick.h
22 
23  \brief This class implements a concrete tool to geographic pan operation with mouse middle button.
24 */
25 
26 #ifndef __TERRALIB_QT_WIDGETS_INTERNAL_PANMIDDLECLICK_H
27 #define __TERRALIB_QT_WIDGETS_INTERNAL_PANMIDDLECLICK_H
28 
29 // TerraLib
30 #include "../Config.h"
31 #include "AbstractTool.h"
32 
33 namespace te
34 {
35  namespace qt
36  {
37  namespace widgets
38  {
39 // Forward declarations
40  class MapDisplay;
41 
42  /*!
43  \class PanMiddleClick
44 
45  \brief This class implements a concrete tool to geographic pan operation with mouse middle click.
46 
47  \ingroup widgets
48  */
50  {
51  public:
52 
53  /** @name Initializer Methods
54  * Methods related to instantiation and destruction.
55  */
56  //@{
57 
58  /*!
59  \brief It constructs a pan tool, with mouse middle button, associated with the given map display and with the specified cursors.
60 
61  \param display The map display associated with the tool.
62  \param parent The tool's parent.
63 
64  \note The tool will NOT take the ownership of the given pointers.
65  \note If the given cursor is different of Qt::BlankCursor, it will be setted on map display.
66  */
67  PanMiddleClick(MapDisplay* display, QObject* parent = 0);
68 
69  /*! \brief Destructor. */
70  ~PanMiddleClick();
71 
72  //@}
73 
74  /** @name AbstractTool Methods
75  * Methods related with tool behavior.
76  */
77  //@{
78 
79  bool mousePressEvent(QMouseEvent* e);
80 
81  bool mouseMoveEvent(QMouseEvent* e);
82 
83  bool mouseReleaseEvent(QMouseEvent* e);
84 
85  //@}
86 
87  protected:
88 
89  bool m_panStarted; //!< Flag that indicates if pan operation was started.
90  QPoint m_origin; //!< Origin point on mouse pressed.
91  QPoint m_delta; //!< Difference between pressed point and destination point on mouse move.
92  QCursor m_currentCursor; //!< Current cursor to be used in the end of the pan user action.
93  QPointF m_referencePoint; //!< The reference origin point, in World Coordinate System.
94 
95  };
96 
97  } // end namespace widgets
98  } // end namespace qt
99 } // end namespace te
100 
101 #endif // __TERRALIB_QT_WIDGETS_INTERNAL_PANMIDDLECLICK_H
Abstract tool concept.
This class implements a concrete tool to geographic pan operation with mouse middle click...
A widget to control the display of a set of layers.
Definition: MapDisplay.h:69
This class defines an interface for objects that can receive application events and respond to them...
Definition: AbstractTool.h:62
QPoint m_delta
Difference between pressed point and destination point on mouse move.
URI C++ Library.
bool m_panStarted
Flag that indicates if pan operation was started.
QPoint m_origin
Origin point on mouse pressed.
#define TEQTWIDGETSEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:63
QPointF m_referencePoint
The reference origin point, in World Coordinate System.
QCursor m_currentCursor
Current cursor to be used in the end of the pan user action.