interfEditMenu Class Reference

#include <interfEditMenu.h>

Inheritance diagram for interfEditMenu:

Inheritance graph
[legend]
Collaboration diagram for interfEditMenu:

Collaboration graph
[legend]

List of all members.

Public Member Functions

 interfEditMenu (wxWindow *parent, int sizex, int sizey, wxEvtHandler *evtHandler, std::string datdir="data/Icons")
 ~interfEditMenu ()
virtual void initButtons (wxEvtHandler *evtHandler)
void onCopy (wxCommandEvent &event)
void onPaste (wxCommandEvent &event)
void onUndo (wxCommandEvent &event)
void onRedo (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 8 of file interfEditMenu.h.


Constructor & Destructor Documentation

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

Definition at line 4 of file interfEditMenu.cxx.

References interfMenuBar::datadir, and initButtons().

00005         : interfMenuBar(parent, sizex, sizey)
00006 {
00007         this->datadir = datdir;
00008 //      eventHandler = evtHandler;
00009         initButtons(this);
00010 }

Here is the call graph for this function:

interfEditMenu::~interfEditMenu (  ) 

Definition at line 65 of file interfEditMenu.cxx.

00066 {
00067 }


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(), interfSegmentationMenu::initButtons(), interfNewContourMenu::initButtons(), interfIOMenu::initButtons(), interfImageToolsMenu::initButtons(), 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(), interfSegmentationMenu::initButtons(), interfNewContourMenu::initButtons(), interfIOMenu::initButtons(), interfImageToolsMenu::initButtons(), 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 interfEditMenu::initButtons ( wxEvtHandler *  evtHandler  )  [virtual]

Implements interfMenuBar.

Definition at line 12 of file interfEditMenu.cxx.

References interfMenuBar::addButtons(), interfMenuBar::connectEvents(), interfMenuBar::datadir, onCopy(), onPaste(), onRedo(), onUndo(), interfMenuBar::setButtonName(), and interfMenuBar::setVectorFunction().

Referenced by interfEditMenu().

00012                                                          {
00013 
00014         std::vector<std::string> path, nom;
00015         std::vector<wxObjectEventFunction> funct;
00016 
00017         path.push_back(datadir + "/copy.png");
00018         nom.push_back("Copy the selected contour  ctrl + c");
00019         funct.push_back((wxObjectEventFunction) &interfEditMenu:: onCopy);
00020 
00021         path.push_back(datadir + "/paste.png");
00022         nom.push_back("Paste the copied contour  ctrl + v");
00023         funct.push_back((wxObjectEventFunction) &interfEditMenu:: onPaste);
00024 
00025         path.push_back(datadir + "/undo.png");
00026         nom.push_back("Undo  ctrl + z");
00027         funct.push_back((wxObjectEventFunction) &interfEditMenu:: onUndo);
00028 
00029         path.push_back(datadir + "/redo.png");
00030         nom.push_back("Redo  ctrl + y");
00031         funct.push_back((wxObjectEventFunction) &interfEditMenu:: onRedo);
00032 
00033 
00034     this->addButtons(path, nom);
00035         this->setVectorFunction(funct);
00036 
00037         this->setButtonName(0, 'C');
00038         this->setButtonName(1, 'P');
00039         this->setButtonName(2, '-');
00040         this->setButtonName(3, '-');
00041 
00042         this->connectEvents(evtHandler);
00043 
00044 }

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 interfEditMenu::onCopy ( wxCommandEvent &  event  ) 

Definition at line 45 of file interfEditMenu.cxx.

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

Referenced by initButtons().

00046 {
00047         interfMainPanel::getInstance()->onCopy();
00048 }

Here is the call graph for this function:

Here is the caller graph for this function:

void interfEditMenu::onPaste ( wxCommandEvent &  event  ) 

Definition at line 50 of file interfEditMenu.cxx.

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

Referenced by initButtons().

00051 {
00052         interfMainPanel::getInstance()->onPaste();
00053 }

Here is the call graph for this function:

Here is the caller graph for this function:

void interfEditMenu::onRedo ( wxCommandEvent &  event  ) 

Definition at line 60 of file interfEditMenu.cxx.

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

Referenced by initButtons().

00061 {
00062         interfMainPanel::getInstance()->onRedo();
00063 }

Here is the call graph for this function:

Here is the caller graph for this function:

void interfEditMenu::onUndo ( wxCommandEvent &  event  ) 

Definition at line 55 of file interfEditMenu.cxx.

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

Referenced by initButtons().

00056 {
00057         interfMainPanel::getInstance()->onUndo();
00058 }

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 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(), interfSegmentationMenu::initButtons(), interfNewContourMenu::initButtons(), interfIOMenu::initButtons(), interfImageToolsMenu::initButtons(), 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:33 2012 for creaContours_lib by  doxygen 1.5.7.1