interfSegmentationMenu Class Reference

#include <interfSegmentationMenu.h>

Inheritance diagram for interfSegmentationMenu:

Inheritance graph
[legend]
Collaboration diagram for interfSegmentationMenu:

Collaboration graph
[legend]

List of all members.

Public Member Functions

 interfSegmentationMenu (wxWindow *parent, int sizex, int sizey, wxEvtHandler *evtHandler, std::string datdir="data/Icons")
 ~interfSegmentationMenu ()
virtual void initButtons (wxEvtHandler *evtHandler)
void onSegmentationPressed (wxCommandEvent &event)
void onSegmentationPressedITK (wxCommandEvent &event)
void onSnakePressed (wxCommandEvent &event)
virtual void addButtons (std::vector< std::string > vpath, std::vector< std::string > vnom)
virtual wxBitmapButton * getButton (std::string imgpath, int sizex, int sizey)
virtual wxStaticText * getText (std::string nom, int sizex, int sizey)
virtual void setVectorFunction (std::vector< wxObjectEventFunction > vectf)
virtual void connectEvents (wxEvtHandler *evtHandler)
virtual void connectEvents ()
virtual void setButtonName (int i, const char c)
void onActionButtonPressed (wxCommandEvent &event)
virtual void setEventHandlers (std::vector< wxEvtHandler * > hand)

Protected Attributes

std::string datadir


Detailed Description

Definition at line 9 of file interfSegmentationMenu.h.


Constructor & Destructor Documentation

interfSegmentationMenu::interfSegmentationMenu ( wxWindow *  parent,
int  sizex,
int  sizey,
wxEvtHandler *  evtHandler,
std::string  datdir = "data/Icons" 
)

Definition at line 4 of file interfSegmentationMenu.cxx.

References interfMenuBar::datadir, and initButtons().

00005         : interfMenuBar(parent, sizex, sizey)
00006 {
00007         this->datadir   = datdir;
00008 
00009 /*EED Borrame
00010         //contourevent  = (wxContourEventHandler*)evtHandler;
00011         infoWin                 = NULL;
00012         configPanel             = NULL;
00013         spreadPanel             = NULL;
00014         segmentPanelITK = NULL;
00015         
00016         //eventHandler  = evtHandler;
00017 */
00018 
00019         initButtons(this);
00020 }

Here is the call graph for this function:

interfSegmentationMenu::~interfSegmentationMenu (  ) 

Definition at line 52 of file interfSegmentationMenu.cxx.

00053 {
00054 }


Member Function Documentation

virtual void interfMenuBar::addButtons ( std::vector< std::string >  vpath,
std::vector< std::string >  vnom 
) [inline, virtual, inherited]

This method add a series of button in a line, it uses the method getbutton to create the button and static text to create the text, it also initialice the flexgridsizer to add the buttons and the text into the panel

Parameters:
vector path, this parameter contains the path of the images to include in the path
vector nom, this parameter contains the names corresponding to each path of image given

Definition at line 39 of file interfMenuBar.h.

References interfMenuBar::flexsizer, interfMenuBar::getButton(), and interfMenuBar::vectbutton.

Referenced by interfToolsMenu::initButtons(), initButtons(), interfNewContourMenu::initButtons(), interfIOMenu::initButtons(), interfImageToolsMenu::initButtons(), interfEditMenu::initButtons(), and interfDeleteMenu::initButtons().

00039                                                                                   {
00040                 
00041                 int sizex = 80;
00042                 int sizey = 80;
00043         
00044                 //RaC 11-09
00045                 //This constructor function as well but it is neccessary to change vpath.size() by 6
00046                 //flexsizer = new wxFlexGridSizer(2,vpath.size(),2,2);
00047                 flexsizer = new wxFlexGridSizer(6);
00048                 this->SetSizer(flexsizer, true);
00049                 this->SetAutoLayout( true );
00050                 
00051                 //first row of the sizer, the buttons are being added
00052                 for(int i = 0; i < (int)(vpath.size());i++){
00053                         std::string p = vpath[i];
00054                         wxBitmapButton* bitmapbutton = this->getButton(p, sizex, sizey);
00055                         flexsizer->Add(bitmapbutton,wxFIXED_MINSIZE);
00056                         
00057                 }
00058                 //second row of the sizer, the names are being added
00059                 
00060                 for(int i = 0; i < (int)(vnom.size()); i++){
00061                         //sizex = vectbutton[i]->GetSize().GetWidth();
00062                         std::string n = vnom[i];
00063                         vectbutton[i]->SetToolTip(wxString(n.c_str(),wxConvUTF8));
00064                         //wxStaticText* statictext = getText(n, sizex, 15);
00065                         //flexsizer->Add(statictext, wxEXPAND |wxALIGN_CENTER_HORIZONTAL | wxALIGN_CENTRE_HORIZONTAL|wxSHAPED);
00066                 }
00067                 this->Layout();
00068         }

Here is the call graph for this function:

Here is the caller graph for this function:

virtual void interfMenuBar::connectEvents (  )  [inline, virtual, inherited]

This method connect the events seted in the vector vectfunct each function must have a button to relate with, see function setVectorFunction()

Definition at line 129 of file interfMenuBar.h.

References interfMenuBar::vectbutton, interfMenuBar::vectfunct, and interfMenuBar::vecthand.

Referenced by interfToolsMenu::initButtons(), initButtons(), interfNewContourMenu::initButtons(), interfIOMenu::initButtons(), interfImageToolsMenu::initButtons(), interfEditMenu::initButtons(), and interfDeleteMenu::initButtons().

00129                                     {   
00130 
00131                 for(int i = 0; i < (int)(vectbutton.size());i++){
00132                         Connect(vectbutton[i]->GetId(), wxEVT_COMMAND_BUTTON_CLICKED, vectfunct[i],NULL,vecthand[i]);
00133                 }
00134         }

Here is the caller graph for this function:

virtual void interfMenuBar::connectEvents ( wxEvtHandler *  evtHandler  )  [inline, virtual, inherited]

This method connect the events seted in the vector vectfunct each function must have a button to relate with, see function setVectorFunction()

Definition at line 118 of file interfMenuBar.h.

References interfMenuBar::vectbutton, and interfMenuBar::vectfunct.

00118                                                             {   
00119 
00120                 for(int i = 0; i < (int)(vectbutton.size());i++){
00121                         Connect(vectbutton[i]->GetId(), wxEVT_COMMAND_BUTTON_CLICKED, vectfunct[i],NULL,evtHandler);
00122                 }
00123         }

virtual wxBitmapButton* interfMenuBar::getButton ( std::string  imgpath,
int  sizex,
int  sizey 
) [inline, virtual, inherited]

This method creates the button with the given image and returns it

Parameters:
string imgpath is the string containing the path to the image of the button being created
int x indicates the x coordinate where the button should be located
int y indicates the y coordinate where the button should be located

Definition at line 77 of file interfMenuBar.h.

References interfMenuBar::vectbutton, and interfMenuBar::vectimgpath.

Referenced by interfMenuBar::addButtons().

00077                                                                                   {
00078                 vectimgpath.push_back(imgpath);
00079                                 
00080                 
00081                 wxBitmap* bitmap = new wxBitmap(wxString(imgpath.c_str(),wxConvUTF8), wxBITMAP_TYPE_PNG);
00082 
00083                 //wxSize(sizex,sizey)
00084                 wxBitmapButton* bitmapbutton = new wxBitmapButton(this, -1, *bitmap, wxDefaultPosition, wxDefaultSize,
00085                                                                                         wxBU_AUTODRAW, wxDefaultValidator, wxString(_T("")));
00086 
00087                 vectbutton.push_back(bitmapbutton);
00088                 return bitmapbutton;
00089         }

Here is the caller graph for this function:

virtual wxStaticText* interfMenuBar::getText ( std::string  nom,
int  sizex,
int  sizey 
) [inline, virtual, inherited]

This method create the static text with the given string and returns it, it also push it back into the vector nom

Parameters:
string nom text wich will be added to the statictext
int sizex size of the text
int sizey size of the text

Definition at line 98 of file interfMenuBar.h.

References interfMenuBar::vectnom.

00098                                                                           {
00099                 vectnom.push_back(nom);
00100                 return new wxStaticText(this, -1, wxString(nom.c_str(),wxConvUTF8), wxDefaultPosition, 
00101                                                                 wxSize(sizex,sizey), wxALIGN_CENTRE, wxString(nom.c_str(),wxConvUTF8));
00102         }

void interfSegmentationMenu::initButtons ( wxEvtHandler *  evtHandler  )  [virtual]

Implements interfMenuBar.

Definition at line 22 of file interfSegmentationMenu.cxx.

References interfMenuBar::addButtons(), interfMenuBar::connectEvents(), interfMenuBar::datadir, onSegmentationPressed(), onSegmentationPressedITK(), onSnakePressed(), and interfMenuBar::setVectorFunction().

Referenced by interfSegmentationMenu().

00022                                                                  {
00023 
00024         std::vector<std::string> path, nom;
00025         std::vector<wxObjectEventFunction> funct;
00026 
00027         path.push_back(datadir + "/Segmentation.png");
00028         nom.push_back("Find shapes by automatic segmentation");
00029         funct.push_back((wxObjectEventFunction) &interfSegmentationMenu:: onSegmentationPressed);
00030 
00031         path.push_back(datadir + "/ITK.png");
00032         nom.push_back("Find shapes by automatic segmentation with ITK");
00033         funct.push_back((wxObjectEventFunction) &interfSegmentationMenu:: onSegmentationPressedITK);
00034 
00035         path.push_back(datadir + "/snake.png");
00036         nom.push_back("Find shapes using border snake interaction");
00037         funct.push_back((wxObjectEventFunction) &interfSegmentationMenu:: onSnakePressed);
00038 
00039 /*EED Borrame
00040         path.push_back(datadir + "/Threshold.png");
00041         nom.push_back("Superpose a 'Red Image' to the selected Image Threshold");
00042         funct.push_back((wxObjectEventFunction)&interfSegmentationMenu::onThreshold);
00043 */
00044         this->addButtons(path, nom);    
00045         this->setVectorFunction(funct);
00046 
00047         this->connectEvents(evtHandler);
00048            
00049 
00050 }

Here is the call graph for this function:

Here is the caller graph for this function:

void interfMenuBar::onActionButtonPressed ( wxCommandEvent &  event  )  [inline, inherited]

Responds to the events of the buttons, when the same panel is responsible for it. It gets the name of the button corresponding to the method that has to be executed, it uses attribute eventHandler to call the methods define by the application. see setEventHandler(wxEventHandler*)

Reimplemented in interfIOMenu.

Definition at line 155 of file interfMenuBar.h.

00156         {
00157                 if(true)//if(eventHandler!=NULL)
00158                 {
00159                         std::string theStr = std::string( ((wxButton *)event.GetEventObject())->GetName().ToAscii());
00160                         const char * toolCommand = theStr.c_str();
00161                         event.SetId( GetId() );
00162                         event.SetEventObject( this );
00163                         event.SetClientData( (void *) toolCommand);
00164                         //eventHandler->ProcessEvent( event );
00165                 }
00166         }

void interfSegmentationMenu::onSegmentationPressed ( wxCommandEvent &  event  ) 

Responds to the events of the buttons, when the same panel is responsible for it. It gets the name of the button corresponding to the method that has to be executed, it uses attribute eventHandler to call the methods define by the application. see setEventHandler(wxEventHandler*)

Definition at line 64 of file interfSegmentationMenu.cxx.

References interfMainPanel::getInstance(), and interfMainPanel::onSegmentationPressed().

Referenced by initButtons().

Here is the call graph for this function:

Here is the caller graph for this function:

void interfSegmentationMenu::onSegmentationPressedITK ( wxCommandEvent &  event  ) 

Definition at line 71 of file interfSegmentationMenu.cxx.

References interfMainPanel::getInstance(), and interfMainPanel::onSegmentationPressedITK().

Referenced by initButtons().

Here is the call graph for this function:

Here is the caller graph for this function:

void interfSegmentationMenu::onSnakePressed ( wxCommandEvent &  event  ) 

Definition at line 76 of file interfSegmentationMenu.cxx.

References interfMainPanel::getInstance(), and interfMainPanel::onSnakePressed().

Referenced by initButtons().

00077 {
00078         interfMainPanel::getInstance()->onSnakePressed();
00079 }

Here is the call graph for this function:

Here is the caller graph for this function:

virtual void interfMenuBar::setButtonName ( int  i,
const char  c 
) [inline, virtual, inherited]

Sets the name of the button, this is used to relate the name of the button to a specific command int i index in the array of buttons use fuction setVectorFuncion(<vect>) to set the vector first const char name of the button see wxContour_ActionCommandsID.h to view the commands

Definition at line 142 of file interfMenuBar.h.

References interfMenuBar::vectbutton.

Referenced by interfEditMenu::initButtons().

00142                                                        {
00143                 if(i < (int)(vectbutton.size())){
00144                         std::string ac = c+"";
00145                         vectbutton[i]->SetName(wxString(ac.c_str(),wxConvUTF8));
00146                 }
00147         }

Here is the caller graph for this function:

virtual void interfMenuBar::setEventHandlers ( std::vector< wxEvtHandler * >  hand  )  [inline, virtual, inherited]

Definition at line 168 of file interfMenuBar.h.

References interfMenuBar::vecthand.

Referenced by interfNewContourMenu::initButtons().

00168                                                                     {
00169 
00170                 for(int i = 0; i < (int)(hand.size());i++){
00171                         vecthand.push_back(hand[i]);
00172                 }
00173         }

Here is the caller graph for this function:

virtual void interfMenuBar::setVectorFunction ( std::vector< wxObjectEventFunction >  vectf  )  [inline, virtual, inherited]

Sets the vector funcion, this vector must contain a function for each button created they must be ordered in the same way as the vector that contains the image path and name of the button. See addButton(<vect>, <vect>)

Definition at line 108 of file interfMenuBar.h.

References interfMenuBar::vectfunct.

Referenced by interfToolsMenu::initButtons(), initButtons(), interfNewContourMenu::initButtons(), interfIOMenu::initButtons(), interfImageToolsMenu::initButtons(), interfEditMenu::initButtons(), and interfDeleteMenu::initButtons().

00108                                                                               {
00109                 for(int i = 0; i < (int)(vectf.size());i++){
00110                         vectfunct.push_back(vectf[i]);
00111                 }               
00112         }

Here is the caller graph for this function:


Member Data Documentation

std::string interfMenuBar::datadir [protected, inherited]


The documentation for this class was generated from the following files:

Generated on Wed Jun 27 23:28:34 2012 for creaContours_lib by  doxygen 1.5.7.1