All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
ViewRubberBand.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 #ifndef __TERRALIB_LAYOUT_INTERNAL_VIEWRUBBER_BAND_H
21 #define __TERRALIB_LAYOUT_INTERNAL_VIEWRUBBER_BAND_H
22 
23 // TerraLib
24 #include "../../../core/Config.h"
25 #include "../AbstractViewTool.h"
26 
27 // Qt
28 #include <QRectF>
29 #include <QBrush>
30 #include <QPen>
31 #include <QPixmap>
32 
33 class QRubberBand;
34 
35 namespace te
36 {
37  namespace layout
38  {
39  // Forward declarations
40  class View;
41 
42  /*!
43  \class ViewRubberBand
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 rubber band associated with the given map display and with the specified cursor.
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  ViewRubberBand(View* view, QObject* parent = 0);
68 
69  /*! \brief Destructor. */
70  ~ViewRubberBand();
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  QPoint m_origin; //!< Origin point on mouse pressed.
90  QRectF m_rect; //!< The boundary rectangle managed by the rubber band.
91  QPen m_pen; //!< The pen used to draw the rubber band shape.
92  QBrush m_brush; //!< The brush used to draw the rubber band shape.
93  bool m_started;
94  QPixmap* m_draft;
95  QRubberBand* m_rubberBand;
96 
97  };
98  } // end namespace layout
99 } // end namespace te
100 
101 #endif
#define TELAYOUTEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:99
This class implements a concrete tool to geographic pan operation.
QPen m_pen
The pen used to draw the rubber band shape.
Class representing the view. This view is child of QGraphicsView, part of Graphics View Framework...
Definition: View.h:89
QBrush m_brush
The brush used to draw the rubber band shape.
QPoint m_origin
Origin point on mouse pressed.
QRectF m_rect
The boundary rectangle managed by the rubber band.