attributefill/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/attributefill/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 
34 te::qt::plugins::attributefill::AbstractAction::AbstractAction(QMenu* menu): m_menu(menu), m_action(nullptr)
35 {
36 }
37 
39 
40 void te::qt::plugins::attributefill::AbstractAction::createAction(std::string name, std::string pixmap)
41 {
42  assert(m_menu);
43 
44  m_action = new QAction(m_menu);
45 
46  m_action->setText(name.c_str());
47 
48  if(pixmap.empty() == false)
49  m_action->setIcon(QIcon::fromTheme(pixmap.c_str()));
50 
51  connect(m_action, SIGNAL(triggered(bool)), this, SLOT(onActionActivated(bool)));
52 
53  m_menu->addAction(m_action);
54 }
55 
57 {
58  te::qt::af::evt::LayerAdded evt(layer.get());
59 
60  emit triggered(&evt);
61 }
62 
63 std::list<te::map::AbstractLayerPtr> te::qt::plugins::attributefill::AbstractAction::getLayers()
64 {
67 
68  emit triggered(&e);
69  emit triggered(&ed);
70 
71  std::list<te::map::AbstractLayerPtr> allLayers = e.m_layers;
72 
73  std::list<te::map::AbstractLayerPtr> layers;
74 
75  for (std::list<te::map::AbstractLayerPtr>::iterator it = allLayers.begin(); it != allLayers.end(); ++it)
76  {
77  if ((*it)->isValid())
78  layers.push_back(*it);
79  }
80 
81  te::map::AbstractLayerPtr selectedlayer = ed.m_layer;
82 
83  if (!selectedlayer || !selectedlayer->isValid())
84  return layers;
85 
86  std::list<te::map::AbstractLayerPtr> result;
87 
88  result.push_back(selectedlayer);
89 
90  for (std::list<te::map::AbstractLayerPtr>::iterator it = layers.begin(); it != layers.end(); ++it)
91  {
92  if ((*it)->getId() != selectedlayer->getId())
93  result.push_back(*it);
94  }
95 
96  return result;
97 }
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 addNewLayer(te::map::AbstractLayerPtr layer)
Add a new layer into layer explorer widget.
void triggered(te::qt::af::evt::Event *e)
std::list< te::map::AbstractLayerPtr > m_layers
Definition: LayerEvents.h:345
std::list< te::map::AbstractLayerPtr > getLayers()
Get the list of layers from app.
QAction * m_action
Action used to call the process.
This file defines the abstract class AbstractAction.
boost::intrusive_ptr< AbstractLayer > AbstractLayerPtr
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.