1 /*# ---------------------------------------------------------------------
3 # Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image
5 # Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton
6 # Previous Authors : Laurent Guigues, Jean-Pierre Roux
7 # CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil
9 # This software is governed by the CeCILL-B license under French law and
10 # abiding by the rules of distribution of free software. You can use,
11 # modify and/ or redistribute the software under the terms of the CeCILL-B
12 # license as circulated by CEA, CNRS and INRIA at the following URL
13 # http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
14 # or in the file LICENSE.txt.
16 # As a counterpart to the access to the source code and rights to copy,
17 # modify and redistribute granted by the license, users are provided only
18 # with a limited warranty and the software's author, the holder of the
19 # economic rights, and the successive licensors have only limited
22 # The fact that you are presently reading this means that you have had
23 # knowledge of the CeCILL-B license and that you accept its terms.
24 # ------------------------------------------------------------------------ */
26 #include "interfSegmentationMenu.h"
27 #include "interfMainPanel.h"
29 interfSegmentationMenu::interfSegmentationMenu(wxWindow * parent, int sizex, int sizey,wxEvtHandler* evtHandler, std::string datdir)
30 : interfMenuBar(parent, sizex, sizey)
32 this->datadir = datdir;
35 //contourevent = (wxContourEventHandler*)evtHandler;
39 segmentPanelITK = NULL;
41 //eventHandler = evtHandler;
47 void interfSegmentationMenu::initButtons(wxEvtHandler* evtHandler) {
49 std::vector<std::string> path, nom;
50 std::vector<wxObjectEventFunction> funct;
52 path.push_back(datadir + "/Segmentation.png");
53 nom.push_back("Find shapes by automatic segmentation");
54 funct.push_back((wxObjectEventFunction) &interfSegmentationMenu:: onSegmentationPressed);
56 path.push_back(datadir + "/ITK.png");
57 nom.push_back("Find shapes by automatic segmentation with ITK");
58 funct.push_back((wxObjectEventFunction) &interfSegmentationMenu:: onSegmentationPressedITK);
60 path.push_back(datadir + "/snake.png");
61 nom.push_back("Find shapes using border snake interaction");
62 funct.push_back((wxObjectEventFunction) &interfSegmentationMenu:: onSnakePressed);
65 path.push_back(datadir + "/Threshold.png");
66 nom.push_back("Superpose a 'Red Image' to the selected Image Threshold");
67 funct.push_back((wxObjectEventFunction)&interfSegmentationMenu::onThreshold);
69 this->addButtons(path, nom);
70 this->setVectorFunction(funct);
72 this->connectEvents(evtHandler);
77 interfSegmentationMenu::~interfSegmentationMenu()
82 ** Responds to the events of the buttons, when the same panel is responsible for it. It gets the name
83 ** of the button corresponding to the method that has to be executed,
84 ** it uses attribute eventHandler to call the methods define by the application.
85 ** see setEventHandler(wxEventHandler*)
89 void interfSegmentationMenu::onSegmentationPressed(wxCommandEvent& event)
91 interfMainPanel::getInstance()->onSegmentationPressed();
96 void interfSegmentationMenu::onSegmentationPressedITK(wxCommandEvent& event)
98 interfMainPanel::getInstance()->onSegmentationPressedITK();
101 void interfSegmentationMenu::onSnakePressed(wxCommandEvent& event)
103 interfMainPanel::getInstance()->onSnakePressed();
107 void interfSegmentationMenu::onThreshold(wxCommandEvent& event)
109 interfMainPanel::getInstance()->onThresholdPressed();
112 //------------------------------------------------------------------------------------------------------------