sa/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/sa/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 #include "AbstractAction.h"
30 
31 // STL
32 #include <cassert>
33 
35  m_menu(menu),
36  m_action(nullptr)
37 {
38 }
39 
41 {
42  // do not delete m_action pointer because its son of rp menu... and qt delete automatically
43 }
44 
45 void te::qt::plugins::sa::AbstractAction::createAction(std::string name, std::string pixmap)
46 {
47  assert(m_menu);
48 
49  m_action = new QAction(m_menu);
50 
51  m_action->setText(tr(name.c_str()));
52 
53  if(pixmap.empty() == false)
54  m_action->setIcon(QIcon::fromTheme(pixmap.c_str()));
55 
56  connect(m_action, SIGNAL(triggered(bool)), this, SLOT(onActionActivated(bool)));
57 
58  m_menu->addAction(m_action);
59 }
60 
62 {
63  te::qt::af::evt::LayerAdded evt(layer.get());
64 
65  emit triggered(&evt);
66 }
67 
69 {
71 
73 
74  emit triggered(&evt);
75 
76  if(evt.m_layer.get())
77  {
78  std::unique_ptr<te::da::DataSetType> dsType = evt.m_layer->getSchema();
79 
80  if(dsType.get() && dsType->hasRaster())
81  layer = evt.m_layer;
82  }
83 
84  return layer;
85 }
86 
87 std::list<te::map::AbstractLayerPtr> te::qt::plugins::sa::AbstractAction::getLayers()
88 {
90 
91  emit triggered(&e);
92 
93  return e.m_layers;
94 }
This event signals that a new layer was created.
Definition: LayerEvents.h:71
QAction * m_action
Action used to call the process.
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
std::list< te::map::AbstractLayerPtr > getLayers()
Get the list of layers from app.
te::map::AbstractLayerPtr getCurrentLayer()
Get the selected layer from layer explorer in app.
virtual void onActionActivated(bool checked)=0
Slot function used when a action was selected.
void triggered(te::qt::af::evt::Event *e)
void addNewLayer(te::map::AbstractLayerPtr layer)
Add a new layer into layer explorer widget.
AbstractAction(QMenu *menu)
Constructor.
This file defines the abstract class AbstractAction.
std::list< te::map::AbstractLayerPtr > m_layers
Definition: LayerEvents.h:345
void createAction(std::string name, std::string pixmap="")
Create and set the actions parameters.
boost::intrusive_ptr< AbstractLayer > AbstractLayerPtr