X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=lib%2FEditorGraphicBBS%2FbbsWxGUIEditorGraphic%2FwxBlackBoxEditionDialog.cxx;h=b6e28501bc2324bb8432fd7367c8b370f2e71f63;hb=refs%2Ftags%2FCREATOOLS_2-0-3;hp=94289132d605eee4826f25cf1947e7f358ffbeed;hpb=8a680b0e68359ef1d8dc810d776a4f354ffb65e5;p=bbtkGEditor.git diff --git a/lib/EditorGraphicBBS/bbsWxGUIEditorGraphic/wxBlackBoxEditionDialog.cxx b/lib/EditorGraphicBBS/bbsWxGUIEditorGraphic/wxBlackBoxEditionDialog.cxx index 9428913..b6e2850 100644 --- a/lib/EditorGraphicBBS/bbsWxGUIEditorGraphic/wxBlackBoxEditionDialog.cxx +++ b/lib/EditorGraphicBBS/bbsWxGUIEditorGraphic/wxBlackBoxEditionDialog.cxx @@ -1,4 +1,4 @@ -/*========================================================================= +/*========================================================================= Program: bbtk Module: $RCSfile$ Language: C++ @@ -11,26 +11,26 @@ 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::wxBlackBoxEditionDialog . +* \file +* \brief Class bbtk::wxBlackBoxEditionDialog . */ #include "wxBlackBoxEditionDialog.h" @@ -40,13 +40,15 @@ namespace bbtk { //========================================================================= - wxBlackBoxEditionDialog::wxBlackBoxEditionDialog(wxGUIEditorGraphicBBS *parent,GBlackBoxModel *model):wxDialog(parent,wxID_ANY,_T(""), wxDefaultPosition, wxSize(480, 640)) + wxBlackBoxEditionDialog::wxBlackBoxEditionDialog(wxGUIEditorGraphicBBS *parent,GBlackBoxModel *model):wxDialog(parent,wxID_ANY,_T(""), wxDefaultPosition, wxSize(480, 640),wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER) { _model=model; - std::string title("BlackBox Editing - Name:"); - title+=_model->getBBTKName(); - title+=" Type:"; + std::string title("BlackBox Editing - "); + title+=_model->getBBTKPackage(); + title+=":"; title+=_model->getBBTKType(); + title+=":"; + title+=_model->getBBTKName(); SetTitle(std2wx(title)); constructBlackBoxEditionDialog(); @@ -54,12 +56,6 @@ namespace bbtk //========================================================================= - wxBlackBoxEditionDialog::wxBlackBoxEditionDialog(wxGUIEditorGraphicBBS *parent,wxVtkSceneManager* scene):wxDialog(parent, wxID_ANY, _T(""), wxDefaultPosition, wxSize(300, 300)) - { - - } - - //========================================================================= wxBlackBoxEditionDialog::~wxBlackBoxEditionDialog() { @@ -72,57 +68,82 @@ namespace bbtk { wxBoxSizer *sizerDialog = new wxBoxSizer(wxVERTICAL); - wxStaticText *text = new wxStaticText(this, -1, _T("Input Ports")); - + wxScrolledWindow *scrollWin = new wxScrolledWindow( this, -1, wxDefaultPosition, wxSize(200,200), wxVSCROLL); + + wxStaticText *text = new wxStaticText(scrollWin, -1, wxT("Input Ports")); + wxFont font(11, wxDEFAULT, wxNORMAL, wxBOLD); + text->SetFont(font); + + + std::vector lstInputs = _model->getInputPorts(); - wxGridSizer *sizer = new wxGridSizer(lstInputs.size(),3,5,5); - for(int i = 0;igetBBTKName()),wxDefaultPosition,wxSize(100,30)); - wxStaticText *lblType = new wxStaticText(this, -1, std2wx(port->getBBTKType()),wxDefaultPosition,wxSize(150,30)); - wxTextCtrl *txtValue = new wxTextCtrl(this, -1, _T(""),wxDefaultPosition,wxSize(50,15)); + GPortModel* port = lstInputs[i]; + std::string type = port->getBBTKType(); + wxStaticText *lblName = new wxStaticText(scrollWin, -1, std2wx(port->getBBTKName()),wxDefaultPosition,wxSize(100,25)); + wxStaticText *lblType = new wxStaticText(scrollWin, -1, std2wx(type),wxDefaultPosition,wxSize(250,25)); + wxTextCtrl *txtValue = new wxTextCtrl(scrollWin, -1, _T(""),wxDefaultPosition,wxSize(90,25)); if(port->getValue()!="") { - txtValue->SetLabel(crea::std2wx(port->getValue())); + txtValue->SetValue(crea::std2wx(port->getValue())); } if(port->isConnected()) { std::string connected("--Port Connected--"); - txtValue->SetLabel(crea::std2wx(connected)); + txtValue->SetValue(crea::std2wx(connected)); + txtValue->SetEditable(false); + } + + char et = '*'; + if(type.find(et)!=-1) + { + std::string noEditable("--No editable--"); + txtValue->SetValue(crea::std2wx(noEditable)); txtValue->SetEditable(false); } _lstNames.push_back(lblName); - _lstTypes.push_back(lblType); _lstValues.push_back(txtValue); + _lstTypes.push_back(lblType); - sizer->Add(lblName,0,wxEXPAND,5); - sizer->Add(lblType,0,wxCENTRE|wxEXPAND,5); - sizer->Add(txtValue,0,wxEXPAND,5); + sizer->Add(lblName,1,wxEXPAND,5); + sizer->Add(txtValue,1,wxEXPAND,5); + sizer->Add(lblType,1,wxCENTRE|wxEXPAND,5); } - - wxBoxSizer *buts = new wxBoxSizer(wxHORIZONTAL); - wxButton *okButton = new wxButton(this, 1003, _T("Ok"),wxDefaultPosition, wxSize(70, 30)); - wxButton *closeButton = new wxButton(this, 1004, _T("Close"), wxDefaultPosition, wxSize(70, 30)); + + + wxBoxSizer *buts = new wxBoxSizer(wxHORIZONTAL); + wxButton *okButton = new wxButton(scrollWin, -1, _T("Ok"),wxDefaultPosition, wxSize(70, 30)); + wxButton *closeButton = new wxButton(scrollWin, -1, _T("Close"), wxDefaultPosition, wxSize(70, 30)); // connect command event handlers - Connect(1003,wxEVT_COMMAND_BUTTON_CLICKED,wxCommandEventHandler(wxBlackBoxEditionDialog::onClickOk)); - Connect(1004,wxEVT_COMMAND_BUTTON_CLICKED,wxCommandEventHandler(wxBlackBoxEditionDialog::onClickClose)); - + Connect(okButton->GetId(),wxEVT_COMMAND_BUTTON_CLICKED,wxCommandEventHandler(wxBlackBoxEditionDialog::onClickOk)); + Connect(closeButton->GetId(),wxEVT_COMMAND_BUTTON_CLICKED,wxCommandEventHandler(wxBlackBoxEditionDialog::onClickClose)); + buts->Add(okButton,0,wxCENTRE|wxEXPAND,5); buts->Add(closeButton,0,wxCENTRE|wxEXPAND,5); - sizerDialog->Add(text,0,wxALIGN_TOP,10); - sizerDialog->AddSpacer(5); - sizerDialog->Add(sizer,0,wxALIGN_CENTER,10); - sizerDialog->Add(buts,0,wxALIGN_CENTER | wxTOP | wxBOTTOM,10); + sizerDialog->AddSpacer(10); + sizerDialog->Add(text,0,wxALIGN_TOP|wxALIGN_CENTER); + sizerDialog->AddSpacer(15); + sizerDialog->Add(sizer,0,wxALIGN_CENTER); + sizerDialog->AddSpacer(15); + sizerDialog->Add(buts,0,wxALIGN_CENTER | wxTOP | wxBOTTOM); + + scrollWin->SetSizer(sizerDialog); + scrollWin->Centre(); + + + scrollWin->SetVirtualSize(400,400); + scrollWin->SetSize(300,300); + scrollWin->SetScrollbars(10, 10, 50, 50); +// scrollWin->SetSizer(sizer); - SetSizer(sizerDialog); - Centre(); ShowModal(); Destroy(); } @@ -131,11 +152,14 @@ namespace bbtk void wxBlackBoxEditionDialog::onClickOk(wxCommandEvent& event) { - - for(int i=0;i<_lstValues.size();i++) + for(int i=0;i<(int)_lstValues.size();i++) { - std::string text = wx2std(_lstValues[i]->GetLabelText()); - _model->setValueToInputPort(i,text); + std::string text = wx2std(_lstValues[i]->GetValue()); + //TOFIX Search a better alternative + if(text!="--No editable--" && text!="--Port Connected--") + { + _model->setValueToInputPort(i,text); + } } Close(true); @@ -145,7 +169,8 @@ namespace bbtk void wxBlackBoxEditionDialog::onClickClose(wxCommandEvent& event) { - Close(true); +printf("EED wxBlackBoxEditionDialog::onClickClose\n"); + Close(true); } //=========================================================================