X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;ds=sidebyside;f=lib%2FEditorGraphicBBS%2FbbsWxGUIEditorGraphic%2FwxTabPanelsManager.cxx;h=9e6fa1550d8c3a3221d1082799032b8df1131c3e;hb=a3c95f8a4a71a532a46804e8c4f213aa2188d73b;hp=86750fc35833f4ee646b04e3a0d14805fe7a97fc;hpb=b184acbd5222d80d87287b1de3ef085cfbdd83a3;p=bbtkGEditor.git diff --git a/lib/EditorGraphicBBS/bbsWxGUIEditorGraphic/wxTabPanelsManager.cxx b/lib/EditorGraphicBBS/bbsWxGUIEditorGraphic/wxTabPanelsManager.cxx index 86750fc..9e6fa15 100644 --- a/lib/EditorGraphicBBS/bbsWxGUIEditorGraphic/wxTabPanelsManager.cxx +++ b/lib/EditorGraphicBBS/bbsWxGUIEditorGraphic/wxTabPanelsManager.cxx @@ -1,4 +1,29 @@ -/*========================================================================= +/* +# --------------------------------------------------------------------- +# +# 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$ Language: C++ @@ -11,32 +36,31 @@ Version: $Revision$ * Copyright (c) CREATIS-LRMN (Centre de Recherche en Imagerie Medicale) * Authors : Eduardo Davila, Laurent Guigues, Jean-Pierre Roux * -* 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 +* 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. +* 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. -* ------------------------------------------------------------------------ */ +* ------------------------------------------------------------------------ */ /** -* \file -* \brief Class bbtk::wxTabPanelsManager . +* \file +* \brief Class bbtk::wxTabPanelsManager . */ #include "wxTabPanelsManager.h" - namespace bbtk { @@ -44,37 +68,50 @@ namespace bbtk //========================================================================= wxTabPanelsManager::wxTabPanelsManager(wxGUIEditorGraphicBBS *parent) { - printf ("EED %p wxTabPanelsManager()\n" , this ); - _parent = parent; - _lastId = 0; - _notebook = _parent->getAuiNotebook(); + _parent = parent; + _lastId = 0; + _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); + } //========================================================================= wxTabPanelsManager::~wxTabPanelsManager() { - printf ("EED %p ~wxTabPanelsManager()\n" , this ); } - + + //========================================================================= + wxGUIEditorGraphicBBS* wxTabPanelsManager::GetParentGUIEditorGraphicBBS() const + { + return this->_parent; + } + //========================================================================= - void wxTabPanelsManager::addNewTab() + 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); + _panels[_lastId] = newPanel; + _actual = newPanel; + _notebook->AddPage(newPanel, tabName ,true); } + + + + //========================================================================= wxAuiNotebook* wxTabPanelsManager::getAuiNotebook() { return _notebook; } - + //========================================================================= wxGEditorTabPanel* wxTabPanelsManager::getActualTabPanel() { @@ -97,16 +134,16 @@ namespace bbtk //========================================================================= - std::string wxTabPanelsManager::getActualDiagramBBS() + std::string wxTabPanelsManager::getActualDiagramBBS(bool wln) { - return _actual->getDiagramBBS(); + return _actual->getDiagramBBS(wln); } //========================================================================= - 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(); } //========================================================================= @@ -132,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); + _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->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() @@ -155,11 +218,11 @@ namespace bbtk void wxTabPanelsManager::setActualDiagramComplexBox(bool val) { - _actual->setComplexBox(val); + _actual->setComplexBox(val); } //========================================================================= - + void wxTabPanelsManager::addActualDiagramComplexInputPort(std::string portName) { _actual->addComplexInputPort(portName); @@ -192,19 +255,188 @@ namespace bbtk //========================================================================= + void wxTabPanelsManager::VerifyLastTabPanel() + { +printf("wxTabPanelsManager::VerifyActualTabPanel %d \n", this->_notebook->GetPageCount() ); + if (this->_notebook->GetPageCount()==0) + { + this->_actual=NULL; + } + } + + //========================================================================= + void wxTabPanelsManager::OnTabChanged(wxAuiNotebookEvent& event) { - int index = event.GetSelection(); - wxGEditorTabPanel* tab =(wxGEditorTabPanel*)_notebook->GetPage(index); - int id = tab->getPanelId(); - _actual = _panels[id]; + 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... "<