Pan.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/Pan.h
22 
23  \brief This class implements a concrete tool to geographic pan operation.
24 */
25 
26 #ifndef __TERRALIB_QT_WIDGETS_INTERNAL_PAN_H
27 #define __TERRALIB_QT_WIDGETS_INTERNAL_PAN_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 Pan
44 
45  \brief This class implements a concrete tool to geographic pan operation.
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 associated with the given map display and with the specified cursors.
60 
61  \param display The map display associated with the tool.
62  \param cursor The default tool cursor.
63  \param actionCursor An optional cursor to be used during the pan user action. If Qt::BlankCursor, it will be NOT modified.
64  \param parent The tool's parent.
65 
66  \note The tool will NOT take the ownership of the given pointers.
67  \note If the given cursor is different of Qt::BlankCursor, it will be setted on map display.
68  */
69  Pan(MapDisplay* display, const QCursor& cursor, const QCursor& actionCursor = Qt::BlankCursor, QObject* parent = 0);
70 
71  /*! \brief Destructor. */
72  ~Pan();
73 
74  //@}
75 
76  /** @name AbstractTool Methods
77  * Methods related with tool behavior.
78  */
79  //@{
80 
81  bool mousePressEvent(QMouseEvent* e);
82 
83  bool mouseMoveEvent(QMouseEvent* e);
84 
85  bool mouseReleaseEvent(QMouseEvent* e);
86 
87  //@}
88 
89  protected:
90 
91  bool m_panStarted; //!< Flag that indicates if pan operation was started.
92  QPoint m_origin; //!< Origin point on mouse pressed.
93  QPoint m_delta; //!< Difference between pressed point and destination point on mouse move.
94  QCursor m_actionCursor; //!< An optional cursor to be used during the pan user action.
95  QPointF m_referencePoint; //!< The reference origin point, in World Coordinate System.
96 
97  };
98 
99  } // end namespace widgets
100  } // end namespace qt
101 } // end namespace te
102 
103 #endif // __TERRALIB_QT_WIDGETS_INTERNAL_PAN_H
te::qt::widgets::AbstractTool
This class defines an interface for objects that can receive application events and respond to them,...
Definition: AbstractTool.h:64
te
TerraLib.
Definition: AddressGeocodingOp.h:52
te::qt::widgets::MapDisplay
A widget to control the display of a set of layers.
Definition: MapDisplay.h:72
te::qt::widgets::Pan::mouseReleaseEvent
bool mouseReleaseEvent(QMouseEvent *e)
This event handler can be reimplemented in a concrete tool class to receive mouse release events for ...
te::qt::widgets::Pan::mousePressEvent
bool mousePressEvent(QMouseEvent *e)
This event handler can be reimplemented in a concrete tool class to receive mouse press events for th...
TEQTWIDGETSEXPORT
#define TEQTWIDGETSEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:63
te::qt::widgets::Pan::m_panStarted
bool m_panStarted
Flag that indicates if pan operation was started.
Definition: Pan.h:91
te::qt::widgets::Pan::Pan
Pan(MapDisplay *display, const QCursor &cursor, const QCursor &actionCursor=Qt::BlankCursor, QObject *parent=0)
It constructs a pan tool associated with the given map display and with the specified cursors.
te::qt::widgets::Pan::m_referencePoint
QPointF m_referencePoint
The reference origin point, in World Coordinate System.
Definition: Pan.h:95
te::qt::widgets::Pan::m_actionCursor
QCursor m_actionCursor
An optional cursor to be used during the pan user action.
Definition: Pan.h:94
te::qt::widgets::Pan::m_delta
QPoint m_delta
Difference between pressed point and destination point on mouse move.
Definition: Pan.h:93
te::qt::widgets::Pan::mouseMoveEvent
bool mouseMoveEvent(QMouseEvent *e)
This event handler can be reimplemented in a concrete tool class to receive mouse move events for the...
te::qt::widgets::Pan::m_origin
QPoint m_origin
Origin point on mouse pressed.
Definition: Pan.h:92
te::qt::widgets::Pan::~Pan
~Pan()
Destructor.
te::qt::widgets::Pan
This class implements a concrete tool to geographic pan operation.
Definition: Pan.h:50
AbstractTool.h
Abstract tool concept.