/*! * @file button.h * @brief Contains the Button class. * @author Diego CACERES (diego.caceres[AT]creatis.insa-lyon.fr) * @date 2011-05-24 */ #ifndef BUTTON_H #define BUTTON_H #include #include #include #include #include #include #include "functor.h" #include "system.h" /*! @namespace * @brief Contains the creaButtonContainer library included in creaMaracasVisu. */ namespace creaButtonContainer { /*! @namespace * @brief Contains the implementation of the view in creaButtonContainer library. * @see MVC Software Architecture */ namespace view { /*! @class Button button.h "button.h" * @brief This class contains the Button in the view perspective. * @details This class contains the information of a button, it derives from wxBitmapButton. * @see wxBitmapButton */ class Button : public wxBitmapButton { public: //typedef definition /*! @typedef creaButtonContainer::model::TFunctor TFunctor; * @brief Defines the TFunctor type. */ typedef creaButtonContainer::model::TFunctor TFunctor; // ---------------------------------------------------------------------------------- //end of typedef definition public: // ---------------------------------------------------------------------------------- /*! @fn Button::Button( wxWindow* parent, long id, ButtonPair* pair ); * @brief This is the constructor. * @param parent The wxWindow* parent. * @param id The wxID of the button. * @param pair The button information. */ Button( wxWindow* parent, long id, ButtonPair* pair ); // ---------------------------------------------------------------------------------- /*! @fn virtual Button::~Button( ); * @brief This is the destructor. */ virtual ~Button( ); // ---------------------------------------------------------------------------------- /*! @fn long Button::GetID( ); * @brief This method gets the wxID of the button. * @return long wxID of the button. */ long GetID( ); // ---------------------------------------------------------------------------------- /*! @fn std::string Button::GetButtonName( ); * @brief This method returns the name of the button. * @return std::string The name of the button. */ std::string GetButtonName( ); // ---------------------------------------------------------------------------------- /*! @fn std::string Button::GetIconPath( ); * @brief This method returns the iconPath of the button. * @return std::string The path of the icon. */ std::string GetIconPath( ); // ---------------------------------------------------------------------------------- /*! @fn std::string Button::GetDescription( ); * @brief This method returns a the description of the button. * @return std::string The tooltip of the button. */ std::string GetDescription( ); // ---------------------------------------------------------------------------------- /*! @fn void Button::Execute( ); * @brief This method executes the Functor (Call_Back Function). * This is the event of the button that it was defined to be called remotely using * call_back functions. In this project it was implemented using Functors. * @exception std::bad_alloc * @see TFunctor */ void Execute( ); // ---------------------------------------------------------------------------------- private: ButtonPair* m_ButtonPair; //!