rp/AbstractAction.cpp
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/plugins/rp/AbstractAction.cpp
22 
23  \brief This file defines the abstract class AbstractAction
24 */
25 
26 // Terralib
27 #include "../../af/events/LayerEvents.h"
28 #include "../../af/ApplicationController.h"
29 
30 #include "AbstractAction.h"
31 
32 // STL
33 #include <cassert>
34 
36  m_menu(menu),
37  m_popupMenu(popupMenu),
38  m_action(nullptr),
39  m_popupAction(nullptr)
40 {
41 }
42 
44 {
45  // do not delete m_action pointer because its son of rp menu... and qt delete automatically
46 }
47 
49  bool /*checked*/)
50 {
51 }
52 
53 void te::qt::plugins::rp::AbstractAction::createAction(std::string name, std::string pixmap)
54 {
55  assert(m_menu);
56 
57  m_action = new QAction(m_menu);
58 
59  m_action->setText(name.c_str());
60 
61  if(pixmap.empty() == false)
62  m_action->setIcon(QIcon::fromTheme(pixmap.c_str()));
63 
64  connect(m_action, SIGNAL(triggered(bool)), this, SLOT(onActionActivated(bool)));
65 
66  m_menu->addAction(m_action);
67 }
68 
69 void te::qt::plugins::rp::AbstractAction::createPopUpAction(std::string name, std::string pixmap)
70 {
71  assert(m_popupMenu);
72 
73  m_popupAction = new QAction(m_popupMenu);
74 
75  m_popupAction->setText(name.c_str());
76 
77  if(pixmap.empty() == false)
78  m_popupAction->setIcon(QIcon::fromTheme(pixmap.c_str()));
79 
80  connect(m_popupAction, SIGNAL(triggered(bool)), this, SLOT(onPopUpActionActivated(bool)));
81 
82  m_popupMenu->addAction(m_popupAction);
83 }
84 
86 {
87  te::qt::af::evt::LayerAdded evt(layer.get());
88 
89  emit triggered(&evt);
90 }
91 
93 {
95 
97 
98  emit triggered(&evt);
99 
100  if(evt.m_layer.get())
101  {
102  std::unique_ptr<te::da::DataSetType> dsType = evt.m_layer->getSchema();
103 
104  if(dsType.get() && dsType->hasRaster())
105  layer = evt.m_layer;
106  }
107 
108  return layer;
109 }
110 
111 std::list<te::map::AbstractLayerPtr> te::qt::plugins::rp::AbstractAction::getLayers()
112 {
115 
116  emit triggered(&e);
117  emit triggered(&ed);
118 
119  std::list<te::map::AbstractLayerPtr> allLayers = e.m_layers;
120 
121  std::list<te::map::AbstractLayerPtr> layers;
122 
123  for (std::list<te::map::AbstractLayerPtr>::iterator it = allLayers.begin(); it != allLayers.end(); ++it)
124  {
125  if ((*it)->isValid())
126  layers.push_back(*it);
127  }
128 
129  te::map::AbstractLayerPtr selectedlayer = ed.m_layer;
130 
131  if (!selectedlayer || !selectedlayer->isValid())
132  return layers;
133 
134  std::list<te::map::AbstractLayerPtr> result;
135 
136  result.push_back(selectedlayer);
137 
138  for (std::list<te::map::AbstractLayerPtr>::iterator it = layers.begin(); it != layers.end(); ++it)
139  {
140  if ((*it)->getId() != selectedlayer->getId())
141  result.push_back(*it);
142  }
143 
144  return result;
145 }
This event signals that a new layer was created.
Definition: LayerEvents.h:71
te::map::AbstractLayerPtr m_layer
Layer selected.
Definition: LayerEvents.h:336
This event is used to get a single layer selected in layer tree.
Definition: LayerEvents.h:325
void createPopUpAction(std::string name, std::string pixmap="")
Create and set the actions parameters.
This file defines the abstract class AbstractAction.
void createAction(std::string name, std::string pixmap="")
Create and set the actions parameters.
virtual void onActionActivated(bool checked)=0
Slot function used when a action was selected.
te::map::AbstractLayerPtr getCurrentLayer()
Get the selected layer from layer explorer in app.
QAction * m_action
Action used to call the process.
virtual void onPopUpActionActivated(bool checked)
Slot function used when a action was selected from layer pop up.
void triggered(te::qt::af::evt::Event *e)
AbstractAction(QMenu *menu, QMenu *popupMenu)
Constructor.
std::list< te::map::AbstractLayerPtr > m_layers
Definition: LayerEvents.h:345
void addNewLayer(te::map::AbstractLayerPtr layer)
Add a new layer into layer explorer widget.
QAction * m_popupAction
Action used to call the process from pop up layer.
boost::intrusive_ptr< AbstractLayer > AbstractLayerPtr
std::list< te::map::AbstractLayerPtr > getLayers()
Get the list of layers from app.