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
*/
49
class
TEQTWIDGETSEXPORT
Pan
:
public
AbstractTool
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
AbstractTool.h
Abstract tool concept.
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::qt::widgets::MapDisplay
A widget to control the display of a set of layers.
Definition:
MapDisplay.h:72
te::qt::widgets::Pan
This class implements a concrete tool to geographic pan operation.
Definition:
Pan.h:50
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::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_actionCursor
QCursor m_actionCursor
An optional cursor to be used during the pan user action.
Definition:
Pan.h:94
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::~Pan
~Pan()
Destructor.
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::m_referencePoint
QPointF m_referencePoint
The reference origin point, in World Coordinate System.
Definition:
Pan.h:95
te::qt::widgets::Pan::m_origin
QPoint m_origin
Origin point on mouse pressed.
Definition:
Pan.h:92
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...
te::qt::widgets::Pan::m_delta
QPoint m_delta
Difference between pressed point and destination point on mouse move.
Definition:
Pan.h:93
te
TerraLib.
Definition:
AddressGeocodingOp.h:52
TEQTWIDGETSEXPORT
#define TEQTWIDGETSEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition:
Config.h:63
git_release
src
terralib
qt
widgets
tools
Pan.h
Generated on Mon Jun 5 2023 10:44:31 for TerraLib by
1.9.1