GeometricOpAction.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/vp/GeometricOpAction.cpp
22 
23  \brief This file defines the GeometricOp class
24 */
25 
26 // Terralib
27 #include "../../../vp/qt/GeometricOpDialog.h"
28 #include "../../af/ApplicationController.h"
29 #include "../../af/events/LayerEvents.h"
30 #include "GeometricOpAction.h"
31 
32 // Qt
33 #include <QObject>
34 #include <QMessageBox>
35 
36 // STL
37 #include <memory>
38 
40  : te::qt::plugins::vp::AbstractAction(menu)
41 {
42  createAction(tr("Geometric Operation...").toUtf8().data(), "vector-processing-geometric-op");
43  m_action->setObjectName("Processing.Vector Processing.Gometric Operation");
44 }
45 
47 
49 {
52 
53  dlg.setLayers( getLayers() );
54 
55  if(dlg.exec() != QDialog::Accepted)
56  return;
57 
58  std::vector<te::map::AbstractLayerPtr> layers = dlg.getOutLayer();
59 
60  if(layers.empty())
61  return;
62 
63  int reply = QMessageBox::question(nullptr, tr("Geometric Operation"), tr("The operation was concluded successfully. Would you like to add the layer to the project?"), QMessageBox::No, QMessageBox::Yes);
64 
65  if(reply == QMessageBox::Yes)
66  {
67  for(std::size_t i = 0; i < layers.size(); ++i)
68  addNewLayer(layers[i]);
69  }
70 }
std::vector< te::map::AbstractLayerPtr > getOutLayer()
void createAction(std::string name, std::string pixmap="")
Create and set the actions parameters.
void setLayers(std::list< te::map::AbstractLayerPtr > layers)
static ApplicationController & getInstance()
It returns a reference to the singleton instance.
URI C++ Library.
Definition: Attributes.h:37
void addNewLayer(te::map::AbstractLayerPtr layer)
Add a new layer into layer explorer widget.
QAction * m_action
Action used to call the process.
virtual void onActionActivated(bool checked)
std::list< te::map::AbstractLayerPtr > getLayers()
Get the list of layers from app.
This is an abstract class used to register actions into vp pluging.
This class is GUI used to define the wizard for the VP geometric operation.