src/terralib/qt/plugins/cellspace/Plugin.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/cellspace/Plugin.cpp
22 
23  \brief Plugin implementation for the Cellular Spaces Qt Plugin widget.
24 */
25 
26 // TerraLib
27 #include "../../../common/Config.h"
28 #include "../../../core/translator/Translator.h"
29 #include "../../../core/logger/Logger.h"
30 #include "../../af/ApplicationController.h"
31 #include "../../af/events/LayerEvents.h"
32 #include "CreateCellLayerAction.h"
33 #include "Plugin.h"
34 
35 // QT
36 #include <QMenu>
37 #include <QMenuBar>
38 
40  : te::core::CppPlugin(pluginInfo),
41  m_cellSpaceMenu(nullptr),
42  m_popupAction(nullptr),
43  m_createCellLayer(nullptr)
44 {
45 }
46 
48 
50 {
51  if(m_initialized)
52  return;
53 
54  TE_LOG_TRACE(TE_TR("TerraLib Qt Cellular Spaces Plugin startup!"));
55 
56 // add plugin menu
57  // Fred: revisar
58  QMenu* pluginMenu = te::qt::af::AppCtrlSingleton::getInstance().getMenu("Processing");
59  m_cellSpaceMenu = new QMenu(pluginMenu);
60 
61  // Insert action before plugin manager action
62  QAction* pluginsSeparator = te::qt::af::AppCtrlSingleton::getInstance().findAction("ManagePluginsSeparator");
63 
64  pluginMenu->insertMenu(pluginsSeparator, m_cellSpaceMenu);
65 
66  m_cellSpaceMenu->setTitle(tr("Cellular Spaces"));
67  m_cellSpaceMenu->setIcon(QIcon::fromTheme("cellspace"));
68 
69  // register actions
71 
72 // add pop up menu
73  m_popupAction = new QAction(m_cellSpaceMenu);
74  m_popupAction->setText(tr("Cellular Spaces"));
75 
76  m_initialized = true;
77 
79 }
80 
82 {
83  if(!m_initialized)
84  return;
85 
86 // remove menu
87  delete m_cellSpaceMenu;
88 
89  // unregister actions
91 
92  TE_LOG_TRACE(TE_TR("TerraLib Qt Cellular Spaces Plugin shutdown!"));
93 
94  m_initialized = false;
95 
96  te::qt::af::AppCtrlSingleton::getInstance().removeListener(this);
97 }
98 
100 {
103 }
104 
106 {
107  delete m_createCellLayer;
108 }
109 
void unRegisterActions()
Function used to unregister all raster processing actions.
QAction * m_popupAction
Cellular Spaces pop up action registered.
Plugin implementation for the SA Qt Plugin widget.
void triggered(te::qt::af::evt::Event *e)
A base class for application events.
Basic information about a plugin.
This class register the contrast action into Cellular Space Plugin.
#define TE_TR(message)
It marks a string in order to get translated.
Definition: Translator.h:242
void registerActions()
Function used to register all raster processing actions.
void startup()
This method will be called by applications to startup some plugin&#39;s functionality.
static ApplicationController & getInstance()
It returns a reference to the singleton instance.
URI C++ Library.
Definition: Attributes.h:37
#define TERRALIB_PLUGIN_CALL_BACK_IMPL(PLUGIN_CLASS_NAME)
This macro should be used by C++ plugins in order to declare the exportable/callable DLL function...
#define TE_LOG_TRACE(message)
Use this tag in order to log a message to the TerraLib default logger with the TRACE level...
Definition: Logger.h:293
QMenu * m_cellSpaceMenu
Cellular Spaces Main Menu registered.
void shutdown()
This method will be called by applicatons to shutdown plugin&#39;s functionality.