/*! * @file containerSettings.h * @brief Contains the ContainerSettings class * @author Diego CACERES (diego.caceres[AT]creatis.insa-lyon.fr) * @date 2011-05-19 */ #ifndef BUTTONGROUPSETTINGS_H_ #define BUTTONGROUPSETTINGS_H_ #include #include #include #include "system.h" #include "functor.h" /*! @namespace * @brief Contains the creaButtonContainer library included in creaMaracasVisu. */ namespace creaButtonContainer { /*! @namespace * @brief Contains the implementation of the model in creaButtonContainer library. * @see MVC Software Architecture */ namespace model { /*! @class ContainerSettings containerSettings.h "containerSettings.h" * @brief This class contains the settings of the button container. */ class ContainerSettings { public: // ---------------------------------------------------------------------------------- /*! @fn ContainerSettings::ContainerSettings( ) * @brief This is the constructor. */ ContainerSettings( ); // ---------------------------------------------------------------------------------- /*! @fn virtual ContainerSettings::~ContainerSettings( ) * @brief This is the destructor. */ virtual ~ContainerSettings( ); // ---------------------------------------------------------------------------------- /*! @fn ButtonGroupMap ContainerSettings::GetButtonGroupContainer( ) * @brief This function returns a container of buttons ordered by group. * @return ButtonGroupMap A container with buttons */ ButtonGroupMap GetButtonGroupContainer( ); // ---------------------------------------------------------------------------------- /*! @fn KeyMapList ContainerSettings::GetGroupNameList( ) * @brief This function returns a container with the name of the groups. * @return KeyMapList A list with the name of the button groups. */ KeyMapList GetGroupNameList( ); // ---------------------------------------------------------------------------------- /*! void ContainerSettings::SetButtonGroupContainer( ButtonGroupMap m_ButtonGroupContainer ) * @brief This function allows to create the ButtonGroupContainer. * @param bgContainer The ButtonGroupMap with all buttons. */ void SetButtonGroupContainer( ButtonGroupMap bgContainer ); // ---------------------------------------------------------------------------------- /*! void ContainerSettings::SetGroupNameList( KeyMapList gNameList ) * @brief This function sets a container with the name of the groups. * @param gNameList the KeyMapList with all groupNames. */ void SetGroupNameList( KeyMapList gNameList ); // ---------------------------------------------------------------------------------- /*! * @fn ContainerSettings::AddButton( const std::string & groupName, const std::string buttonName, const std::string iconpath, const std::string buttonDescription, FunctionEventType event ) * @brief This function adds a new button to the container. * @param groupName The name of the group of buttons. * @param buttonName The ID of the button. * @param iconpath The path of the button icon. * @param buttonDescription The description of the button. * @param event The event associated to the button. * @see class Functor, ConcreteFunctor for add an event for a button. * @exception std::bad_alloc */ void AddButton( const std::string & groupName, const std::string buttonName, const std::string iconpath, const std::string buttonDescription, FunctionEventType event ); // ---------------------------------------------------------------------------------- private: ButtonGroupMap m_ButtonGroupContainer; //! View pointer. KeyMapList m_GroupNameList; //!