X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=lib%2FEditorGraphicBBS%2FbbsWxGUIEditorGraphic%2FwxTabPanelsManager.cxx;h=9e6fa1550d8c3a3221d1082799032b8df1131c3e;hb=a3c95f8a4a71a532a46804e8c4f213aa2188d73b;hp=bca6b0b81f8396454147308d43ea481cb2b284e4;hpb=56cbba59d070c955c4aab46e59908ab82f5e390d;p=bbtkGEditor.git diff --git a/lib/EditorGraphicBBS/bbsWxGUIEditorGraphic/wxTabPanelsManager.cxx b/lib/EditorGraphicBBS/bbsWxGUIEditorGraphic/wxTabPanelsManager.cxx index bca6b0b..9e6fa15 100644 --- a/lib/EditorGraphicBBS/bbsWxGUIEditorGraphic/wxTabPanelsManager.cxx +++ b/lib/EditorGraphicBBS/bbsWxGUIEditorGraphic/wxTabPanelsManager.cxx @@ -1,3 +1,28 @@ +/* +# --------------------------------------------------------------------- +# +# Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image +# pour la Santé) +# Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton +# +# This software is governed by the CeCILL-B license under French law and +# abiding by the rules of distribution of free software. You can use, +# modify and/ or redistribute the software under the terms of the CeCILL-B +# license as circulated by CEA, CNRS and INRIA at the following URL +# http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html +# or in the file LICENSE.txt. +# +# As a counterpart to the access to the source code and rights to copy, +# modify and redistribute granted by the license, users are provided only +# with a limited warranty and the software's author, the holder of the +# economic rights, and the successive licensors have only limited +# liability. +# +# The fact that you are presently reading this means that you have had +# knowledge of the CeCILL-B license and that you accept its terms. +# ------------------------------------------------------------------------ +*/ + /*========================================================================= Program: bbtk Module: $RCSfile$ @@ -36,7 +61,6 @@ Version: $Revision$ #include "wxTabPanelsManager.h" - namespace bbtk { @@ -49,6 +73,8 @@ namespace bbtk _notebook = _parent->getAuiNotebook(); addNewTab(); _notebook->Connect(wxEVT_COMMAND_AUINOTEBOOK_PAGE_CHANGED,wxAuiNotebookEventHandler(wxTabPanelsManager::OnTabChanged),0,this); + _notebook->Connect(wxEVT_COMMAND_AUINOTEBOOK_PAGE_CLOSE,wxAuiNotebookEventHandler(wxTabPanelsManager::OnTabClose),0,this); + } //========================================================================= @@ -57,16 +83,29 @@ namespace bbtk } //========================================================================= - void wxTabPanelsManager::addNewTab() + wxGUIEditorGraphicBBS* wxTabPanelsManager::GetParentGUIEditorGraphicBBS() const + { + return this->_parent; + } + + //========================================================================= + void wxTabPanelsManager::addNewTab(wxString tabName) { _lastId++; - wxGEditorTabPanel *newPanel = new wxGEditorTabPanel(_notebook,_lastId); + + //EED 13/10/2012 wxGEditorTabPanel *newPanel = new wxGEditorTabPanel( _notebook,_lastId ); + wxGEditorTabPanel *newPanel = new wxGEditorTabPanel( _notebook,_lastId, _parent->GetBBTKFactory() ); + newPanel->setPanelsManager(this); _panels[_lastId] = newPanel; _actual = newPanel; - _notebook->AddPage(newPanel,_T("Diagram"),true); + _notebook->AddPage(newPanel, tabName ,true); } + + + + //========================================================================= wxAuiNotebook* wxTabPanelsManager::getAuiNotebook() { @@ -102,9 +141,9 @@ namespace bbtk //========================================================================= - std::string wxTabPanelsManager::getActualComplexBoxBBS(std::string cbName,std::string cbAuthor,std::string cbCategory,std::string cbDescription) + std::string wxTabPanelsManager::getActualComplexBoxBBS() { - return _actual->saveComplexBoxBBS(cbName,cbAuthor,cbCategory,cbDescription); + return _actual->saveComplexBoxBBS(); } //========================================================================= @@ -130,18 +169,44 @@ namespace bbtk //========================================================================= - void wxTabPanelsManager::saveActualDiagram(std::string &content) + void wxTabPanelsManager::saveActualDiagram(std::string &content, const std::string &path) //DFCH { - _actual->saveDiagram(content); + _actual->saveDiagram(content, path); } //========================================================================= - void wxTabPanelsManager::loadDiagram(ifstream &inputStream) + void wxTabPanelsManager::loadDiagram(ifstream &inputStream, const std::string &path) //DFCH + { + _actual->loadDiagram(inputStream, path); + } + + //========================================================================= + void wxTabPanelsManager::saveTempandUpdate(const std::string &action) //FCY + { + _parent->SaveTempActualDiagram(action); + } + //========================================================================= + void wxTabPanelsManager::saveTempActualDiagram(const std::string &action) //FCY + { + _actual->saveTempDiagram(action); + } + //========================================================================= + void wxTabPanelsManager::loadTempDiagram(unsigned short un) //FCY { - _actual->loadDiagram(inputStream); + _actual->loadTempDiagram(un); } + //========================================================================= + unsigned short wxTabPanelsManager::getUndoState( std::string &stun) //FCY + { + return _actual->getUndoState(stun); + } + //========================================================================= + unsigned short wxTabPanelsManager::getRedoState(std::string &stre) //FCY + { + return _actual->getRedoState(stre); + } //========================================================================= bool wxTabPanelsManager::isActualDiagramComplexBox() @@ -203,18 +268,175 @@ printf("wxTabPanelsManager::VerifyActualTabPanel %d \n", this->_notebook->GetPa void wxTabPanelsManager::OnTabChanged(wxAuiNotebookEvent& event) { -printf("wxTabPanelsManager::OnTabChanged \n"); int index = event.GetSelection(); wxGEditorTabPanel* tab = (wxGEditorTabPanel*)_notebook->GetPage(index); int id = tab->getPanelId(); _actual = _panels[id]; _parent->refreshGUIControls(); + } //========================================================================= + void wxTabPanelsManager::OnTabClose(wxAuiNotebookEvent& event) + { + + std::cout<<"RaC wxTabPanelsManager::OnTabClose Start... "<<_panels.size()<0) + { + wxGEditorTabPanel* tab = (wxGEditorTabPanel*)_notebook->GetPage(index); + int id = tab->getPanelId(); + tab->deleteAllBoxes(); + _panels.erase(id); + + _notebook->RemovePage(index); + + std::cout<<"RaC wxTabPanelsManager::OnTabClose IMPORTANT. The complete tab is not erased from memory... "<