X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=lib%2FmaracasVisuLib%2Fsrc%2Finterface%2FwxWindows%2Fwidgets%2FcreaPanelButtonContainer%2FbuttonContainerSettings.cxx;h=80dee9a41172b129d35786b893cc58862311e880;hb=65c158dc171f8d3114ee3544b2a94a1f41880df0;hp=9f60e03c4ee16411269334db9972734f996d9bf9;hpb=4b092ee0b1bcda4d298e5ffc3b58b599e273db20;p=creaMaracasVisu.git diff --git a/lib/maracasVisuLib/src/interface/wxWindows/widgets/creaPanelButtonContainer/buttonContainerSettings.cxx b/lib/maracasVisuLib/src/interface/wxWindows/widgets/creaPanelButtonContainer/buttonContainerSettings.cxx index 9f60e03..80dee9a 100644 --- a/lib/maracasVisuLib/src/interface/wxWindows/widgets/creaPanelButtonContainer/buttonContainerSettings.cxx +++ b/lib/maracasVisuLib/src/interface/wxWindows/widgets/creaPanelButtonContainer/buttonContainerSettings.cxx @@ -1,106 +1,199 @@ -/*************************************************************** - * Name: buttonContainerSettings.cxx - * Purpose: It is the ButtonGroupSettings - * Author: Diego CACERES (diego.caceres[AT]creatis.insa-lyon.fr) - * Modified: 2011-05-09 - * Copyright: Diego CACERES (http://www.creatis.insa-lyon.fr/~caceres/) - * License: - **************************************************************/ +/*! + * @file buttonContainerSettings.cxx + * @brief Implements the ButtonContainerSettings class. + * @author Diego CACERES (diego.caceres[AT]creatis.insa-lyon.fr) + * @date 2011-06-02 + */ + #include "buttonContainerSettings.h" -#include namespace creaPanelButtonContainer { - + // ---------------------------------------------------------------------------------- ButtonContainerSettings::ButtonContainerSettings( ) { } + // ---------------------------------------------------------------------------------- ButtonContainerSettings::~ButtonContainerSettings( ) { } - ButtonGroupMap + // ---------------------------------------------------------------------------------- + ButtonContainerSettings::ButtonGroupMap ButtonContainerSettings::GetButtonGroupContainer( ) { return m_ButtonGroupContainer; } - - KeyMapList + // ---------------------------------------------------------------------------------- + ButtonContainerSettings::KeyMapList ButtonContainerSettings::GetGroupNameList( ) { return m_GroupNameList; } - - //GetButtonPanel returns the panel asociated to de buttonAction - PanelButton - ButtonContainerSettings::GetPanelButton( const std::string &buttonName ) + // ---------------------------------------------------------------------------------- + //GetButtonPanel returns the panel associated to the buttonAction + ButtonContainerSettings::PanelButton + ButtonContainerSettings::GetPanelButton( const StringType &buttonName ) { - for( KeyMapList::iterator it = this->m_GroupNameList.begin( ); it - != this->m_GroupNameList.end( ); ++it ) + try { - ButtonList list = this->m_ButtonGroupContainer[ ( *it ) ]; - for( ButtonList::iterator it1 = list.begin( ); it1 != list.end( ); ++it1 ) + for( KeyMapList::iterator it = this->m_GroupNameList.begin( ); it + != this->m_GroupNameList.end( ); ++it ) { - if ( ( *it1 )->first->first.compare( buttonName ) == 0 ) + ButtonList list = this->m_ButtonGroupContainer[ ( *it ) ]; + for( ButtonList::iterator it1 = list.begin( ); it1 != list.end( ); ++it1 ) { - return ( ( *it1 )->second->second ); - }//fi + if ( ( *it1 )->first->first.compare( buttonName ) == 0 ) + { + return ( ( *it1 )->second->second ); + }//fi + }//rof }//rof - }//rof + }//yrt + catch ( std::exception& e ) + { + std::cerr + << "ButtonContainerSettings::GetPanelButton( const StringType &buttonName ) " + << "exception: " << e.what( ) << std::endl; + }//hctac return ( NULL ); } - ButtonGroupSettings* + // ---------------------------------------------------------------------------------- + ButtonContainerSettings::ButtonGroupSettings* ButtonContainerSettings::GetButtonGroupSettings( TFunctor* functor ) { - ButtonGroupSettings* settings = new ButtonGroupSettings( ); - for( KeyMapList::iterator it = this->m_GroupNameList.begin( ); it - != this->m_GroupNameList.end( ); ++it ) + try { - ButtonList list = this->m_ButtonGroupContainer[ ( *it ) ]; - for( ButtonList::iterator it1 = list.begin( ); it1 != list.end( ); ++it1 ) + ButtonGroupSettings* settings = new ButtonGroupSettings( ); + for( KeyMapList::iterator it = this->m_GroupNameList.begin( ); it + != this->m_GroupNameList.end( ); ++it ) { - settings->CreateGroup( *it ); - settings->AddButton( ( *it ), ( *it1 )->first->first, - ( *it1 )->first->second, ( *it1 )->second->first, functor ); + ButtonList list = this->m_ButtonGroupContainer[ ( *it ) ]; + for( ButtonList::iterator it1 = list.begin( ); it1 != list.end( ); ++it1 ) + { + settings->AddButton( ( *it ), ( *it1 )->first->first, + ( *it1 )->first->second, ( *it1 )->second->first, functor ); + }//rof }//rof - }//rof - return ( settings ); + return ( settings ); + }//yrt + catch ( std::exception& e ) + { + std::cerr + << "ButtonContainerSettings::GetPanelButton( const StringType &buttonName ) " + << "exception: " << e.what( ) << std::endl; + }//hctac } + // ---------------------------------------------------------------------------------- void ButtonContainerSettings::SetButtonGroupContainer( ButtonGroupMap m_ButtonGroupContainer ) { this->m_ButtonGroupContainer = m_ButtonGroupContainer; } - + // ---------------------------------------------------------------------------------- void ButtonContainerSettings::SetGroupNameList( KeyMapList m_GroupNameList ) { this->m_GroupNameList = m_GroupNameList; } - + // ---------------------------------------------------------------------------------- void - ButtonContainerSettings::CreateGroup( const std::string & groupName ) + ButtonContainerSettings::AddButton( const StringType & groupName, + const StringType &buttonName, const StringType &iconpath, + const StringType &buttonDescription, PanelButton panel ) { - this->m_GroupNameList.push_back( groupName ); + try + { + //builds the button information + //I don't know the try catch doesn't work!! + if ( panel == NULL ) + { + std::cerr << "ButtonContainerSettings::AddButton" + << "exception: NULL Pointer in panel " << std::endl; + exit( 1 ); + } + panel->Show( false ); + ButtonPair* pair = new ButtonPair( + new ButtonInfo( buttonName, iconpath ), + new ActionButton( buttonDescription, panel ) ); + for( KeyMapList::iterator it = this->m_GroupNameList.begin( ); it + != this->m_GroupNameList.end( ); ++it ) + { + if ( ( *it ).compare( groupName ) == 0 ) + { + this->m_ButtonGroupContainer[ groupName ].push_back( pair ); + return; + }//fi + }//rof + this->m_GroupNameList.push_back( groupName ); + this->m_ButtonGroupContainer[ groupName ].push_back( pair ); + }//yrt + catch ( const std::exception& e ) + { + std::cerr + << "ButtonContainerSettings::AddButton( const StringType & groupName," + << "const StringType &buttonName, const StringType &iconpath," + << "const StringType &buttonDescription, PanelButton panel ) " + << "exception: " << e.what( ) << std::endl; + }//hctac + } + // ---------------------------------------------------------------------------------- + void + ButtonContainerSettings::AddButton( BCPSettingsStruct* info ) + { + try + { + //builds the button information + //I don't know the try catch doesn't work!! + if ( info->panel == NULL ) + { + std::cerr << "ButtonContainerSettings::AddButton" + << "exception: NULL Pointer in panel " << std::endl; + exit( 1 ); + } + info->panel->Show( false ); + ButtonPair* pair = new ButtonPair( + new ButtonInfo( info->buttonName, info->iconpath ), + new ActionButton( info->buttonDescription, info->panel ) ); + for( KeyMapList::iterator it = this->m_GroupNameList.begin( ); it + != this->m_GroupNameList.end( ); ++it ) + { + if ( ( *it ).compare( info->groupName ) == 0 ) + { + this->m_ButtonGroupContainer[ info->groupName ].push_back( pair ); + return; + }//fi + }//rof + this->m_GroupNameList.push_back( info->groupName ); + this->m_ButtonGroupContainer[ info->groupName ].push_back( pair ); + }//yrt + catch ( const std::exception& e ) + { + std::cerr + << "ButtonContainerSettings::AddButton( BCPSettingsStruct* info )" + << "exception: " << e.what( ) << std::endl; + exit( 1 ); + }//hctac } + // ---------------------------------------------------------------------------------- void - ButtonContainerSettings::AddButton( const std::string & groupName, - const std::string buttonName, const std::string iconpath, - const std::string buttonDescription, PanelButton panel ) + ButtonContainerSettings::AddButtons( BCStructVectorType infoList ) { - for( KeyMapList::iterator it = this->m_GroupNameList.begin( ); it - != this->m_GroupNameList.end( ); ++it ) + try { - if ( ( *it ).compare( groupName ) == 0 ) + for( BCStructVectorType::iterator it = infoList.begin( ); it + != infoList.end( ); ++it ) { - panel->Show( false ); - ButtonPair* pair = new ButtonPair( - new ButtonInfo( buttonName, iconpath ), - new ActionButton( buttonDescription, panel ) ); - this->m_ButtonGroupContainer[ groupName ].push_back( pair ); - return; - }//fi - }//rof + this->AddButton( *it ); + }//rof + }//yrt + catch ( std::exception& e ) + { + std::cerr + << "ButtonContainerSettings::AddButtons( BCStructVectorType infoList )" + << "exception: " << e.what( ) << std::endl; + }//hctac } +// ---------------------------------------------------------------------------------- }//ecapseman