All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
BasicStrokePropertyItem.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/se/BasicStrokePropertyItem.h
22 
23  \brief A widget used to define the basic fill se object.
24 */
25 
26 #ifndef __TERRALIB_QT_WIDGETS_SE_INTERNAL_BASICSTROKEPROPERTYITEM_H
27 #define __TERRALIB_QT_WIDGETS_SE_INTERNAL_BASICSTROKEPROPERTYITEM_H
28 
29 // TerraLib
30 #include "../Config.h"
31 #include "../propertybrowser/AbstractPropertyItem.h"
32 
33 namespace te
34 {
35 // Forward declarations
36  namespace se
37  {
38  class Stroke;
39  }
40 
41  namespace qt
42  {
43  namespace widgets
44  {
45  /*!
46  \class BasicFillPropertyItem
47 
48  \brief A widget used to define the basic fill se object.
49 
50  */
51 
53  {
54  Q_OBJECT
55 
56  public:
57  /** @name Initializer Methods
58  * Methods related to instantiation and destruction.
59  */
60  //@{
61 
62  /*! \brief Constructor */
63  BasicStrokePropertyItem(QtTreePropertyBrowser* pb, QColor c = QColor());
64 
65  /*! \brief Destructor. */
67 
68  //@}
69 
70  public:
71 
72  /*!
73  \brief Sets a stroke element to this widget.
74 
75  \param stroke A valid stroke element.
76 
77  \note The widget will NOT take the ownership of the given stroke.
78  \note The widget form will be update based on given stroke parameters.
79  */
80  void setStroke(const te::se::Stroke* stroke);
81 
82  /*!
83  \brief Gets the configured stroke element.
84 
85  \return The configured stroke element.
86 
87  \note The caller will take the ownership of the returned stroke.
88  */
89  te::se::Stroke* getStroke() const;
90 
91  protected:
92 
93  /*! \brief Updates the widget form based on internal stroke element. */
94  void updateUi();
95 
96  /*! \brief Updates the widget form element used to visualize the stroke color. */
97  void updateUiStrokeColor();
98 
99  QMap<int, QIcon> getDashIcons();
100  QMap<int, QIcon> getJoinIcons();
101  QMap<int, QIcon> getCapIcons();
102 
103  QStringList getDashIconsNames();
104 
105  QStringList getJoinNames();
106 
107  QStringList getCapNames();
108 
109  public slots:
110 
111  virtual void valueChanged(QtProperty* p, int value);
112  virtual void valueChanged(QtProperty* p, double value);
113  virtual void valueChanged(QtProperty* p, const QColor &value);
114 
115  signals:
116 
117  /*! This signal is emitted when the internal stroke element is changed. */
118  void strokeChanged();
119 
120  protected:
121 
122  QtProperty* m_colorProperty;
123  QtProperty* m_opacityProperty;
124  QtProperty* m_widthProperty;
125  QtProperty* m_dashProperty;
126  QtProperty* m_joinProperty;
127  QtProperty* m_capProperty;
128 
129  QColor m_color; //!< Auxiliary color attribute.
130 
131  te::se::Stroke* m_stroke; //!< Stroke element that will be configured by this widget.
132 
133  std::vector<std::string> m_dashes; //!< Predefined dash styles. TODO: it can be filled out, based on a file, etc (?)
134  std::map<int, std::string> m_joinMap;
135  std::map<int, std::string> m_capMap;
136 
137  bool m_update;
138 
139  };
140  }
141  }
142 }
143 
144 #endif //__TERRALIB_QT_WIDGETS_SE_INTERNAL_BASICSTROKEPROPERTYITEM_H
A widget used to define the main property items that can be used to describe a se object...
QColor m_color
Auxiliary color attribute.
te::se::Stroke * m_stroke
Stroke element that will be configured by this widget.
A Stroke specifies the appearance of a linear geometry.
Definition: Stroke.h:67
#define TEQTWIDGETSEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:66
std::vector< std::string > m_dashes
Predefined dash styles. TODO: it can be filled out, based on a file, etc (?)