X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=kernel%2Fsrc%2FbbtkWxGUIPackageBrowser.cxx;h=18de91fff0fc1b359dda7509231beec5a33e10d9;hb=01454e3b435c3c8ac4327ecddda74e7d740463f6;hp=2a5d0f5561845480f41c34e01528bbf3450e1602;hpb=302e341409d918a232cd2ec25f2c533c27eb9011;p=bbtk.git diff --git a/kernel/src/bbtkWxGUIPackageBrowser.cxx b/kernel/src/bbtkWxGUIPackageBrowser.cxx index 2a5d0f5..18de91f 100644 --- a/kernel/src/bbtkWxGUIPackageBrowser.cxx +++ b/kernel/src/bbtkWxGUIPackageBrowser.cxx @@ -3,8 +3,8 @@ Program: bbtk Module: $RCSfile: bbtkWxGUIPackageBrowser.cxx,v $ Language: C++ - Date: $Date: 2008/03/28 13:42:18 $ - Version: $Revision: 1.1 $ + Date: $Date: 2008/04/24 13:56:34 $ + Version: $Revision: 1.6 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -29,19 +29,28 @@ * \brief */ - +/* #ifdef _USE_WXWIDGETS_ +#define CHECKBOXVIEW 1 + #include "bbtkWxGUIPackageBrowser.h" #include "ThirdParty/wx/treemultictrl/wxTreeMultiCtrl.h" #include "bbtkInterpreter.h" +#include "bbtkBlackBoxInputDescriptor.h" +#include "bbtkBlackBoxOutputDescriptor.h" +#include "bbtkWxBlackBox.h" +#include "wx/grid.h" +#include + namespace bbtk { //================================================================ - WxGUIPackageBrowserBlackBox::WxGUIPackageBrowserBlackBox(wxWindow* parent, - WxGUIPackageBrowser* browser, - BlackBoxDescriptor* descr) : + WxGUIPackageBrowserBlackBox:: + WxGUIPackageBrowserBlackBox(wxWindow* parent, + WxGUIPackageBrowser* browser, + BlackBoxDescriptor::Pointer descr) : wxPanel(parent, -1), mBrowser(browser), mDescriptor(descr) @@ -49,10 +58,198 @@ namespace bbtk wxBoxSizer *sizer = new wxBoxSizer(wxVERTICAL); wxStaticText* s = new wxStaticText(this,-1, - std2wx(descr->GetTypeName())); + std2wx(descr->GetDescription())); + sizer->Add(s,0,wxGROW); + s = new wxStaticText(this,-1, + std2wx(descr->GetAuthor())); + sizer->Add(s,0,wxGROW); + s = new wxStaticText(this,-1, + std2wx(descr->GetCategory())); + sizer->Add(s,0,wxGROW); + + std::vector > user_defined; + std::vector > ubb_defined; + std::vector > wxbb_defined; + + std::string titlecol("#BBBBFF"); + std::string usercol("#FFFFFF"); + std::string ubbcol("#DDFFFF"); + std::string wxbbcol("#EEFFFF"); + + const BlackBoxDescriptor::InputDescriptorMapType& imap = + descr->GetInputDescriptorMap(); + BlackBoxDescriptor::InputDescriptorMapType::const_iterator in; + for ( in = imap.begin(); in != imap.end(); ++in ) + { + // Skips system-defined inputs + std::string col(usercol); + int iotype = 0; + if (in->second->GetCreatorTypeInfo() == + typeid(AtomicBlackBoxDescriptor)) + { + col = ubbcol; + iotype = 1; + } + else if (in->second->GetCreatorTypeInfo() == + typeid(WxBlackBoxDescriptor)) + { + col = wxbbcol; + iotype = 2; + } + + std::string name(in->second->GetName()); + //Utilities::html_format(name); + + std::string type("<"); + type += in->second->GetTypeName(); + type += ">"; + //Utilities::html_format(type); + + std::string descr(in->second->GetDescription()); + //Utilities::html_format(descr); + + std::vector out; + out.push_back(name); + out.push_back(type); + out.push_back(descr); + + if (iotype==0) user_defined.push_back(out); + else if (iotype==1) ubb_defined.push_back(out); + else if (iotype==2) wxbb_defined.push_back(out); + + } - sizer->Add(s,1,wxGROW); + wxBoxSizer *inputs = + new wxStaticBoxSizer + ( new wxStaticBox(this, wxID_ANY, _T("Inputs")), wxVERTICAL ); + wxFlexGridSizer* grid = new wxFlexGridSizer(3); + + wxTextAttr ionameattr(*wxRED,*wxBLACK); + wxTextAttr iotypeattr(*wxBLACK,*wxRED); + + int n = 0; + std::vector >::iterator hi; + for (hi=user_defined.begin();hi!=user_defined.end();++hi) + { + + grid->Add( new wxStaticText(this,-1,std2wx((*hi)[0]))); + grid->Add( new wxStaticText(this,-1,std2wx((*hi)[1]))); + grid->Add( new wxStaticText(this,-1,std2wx((*hi)[2]))); + // grid->SetCellValue( n, 0, std2wx((*hi)[0]) ); + // grid->SetReadOnly( n, 0 ); + } + // grid->Add( new wxStaticLine(this,-1)); + for (hi=wxbb_defined.begin();hi!=wxbb_defined.end();++hi) + { + grid->Add( new wxStaticText(this,-1, + std2wx((*hi)[0]))); + grid->Add( new wxStaticText(this,-1, + std2wx((*hi)[1]))); + grid->Add( new wxStaticText(this,-1, + std2wx((*hi)[2]))); + } + for (hi=ubb_defined.begin();hi!=ubb_defined.end();++hi) + { + grid->Add( new wxStaticText(this,-1, + std2wx((*hi)[0]))); + grid->Add( new wxStaticText(this,-1, + std2wx((*hi)[1]))); + grid->Add( new wxStaticText(this,-1, + std2wx((*hi)[2]))); + } + + inputs->Add(grid,0,wxGROW); + sizer->Add(inputs,0,wxGROW); + + // Outputs + user_defined.clear(); + ubb_defined.clear(); + wxbb_defined.clear(); + const BlackBoxDescriptor::OutputDescriptorMapType& omap = + descr->GetOutputDescriptorMap(); + BlackBoxDescriptor::OutputDescriptorMapType::const_iterator out; + for ( out = omap.begin(); out != omap.end(); ++out ) + { + // Skips system-defined inputs + std::string col(usercol); + int iotype = 0; + if (out->second->GetCreatorTypeInfo() == + typeid(AtomicBlackBoxDescriptor)) + { + col = ubbcol; + iotype = 1; + } + else if (out->second->GetCreatorTypeInfo() == + typeid(WxBlackBoxDescriptor)) + { + col = wxbbcol; + iotype = 2; + } + + std::string name(out->second->GetName()); + //Utilities::html_format(name); + + std::string type("<"); + type += out->second->GetTypeName(); + type += ">"; + //Utilities::html_format(type); + + std::string descr(out->second->GetDescription()); + //Utilities::html_format(descr); + + std::vector out; + out.push_back(name); + out.push_back(type); + out.push_back(descr); + + if (iotype==0) user_defined.push_back(out); + else if (iotype==1) ubb_defined.push_back(out); + else if (iotype==2) wxbb_defined.push_back(out); + + } + + wxBoxSizer *outputs = + new wxStaticBoxSizer + ( new wxStaticBox(this, wxID_ANY, _T("Outputs")), wxVERTICAL ); + wxFlexGridSizer* ogrid = new wxFlexGridSizer(3); + + + n = 0; + for (hi=user_defined.begin();hi!=user_defined.end();++hi) + { + ogrid->Add( new wxStaticText(this,-1, + std2wx((*hi)[0]))); + ogrid->Add( new wxStaticText(this,-1, + std2wx((*hi)[1]))); + ogrid->Add( new wxStaticText(this,-1, + std2wx((*hi)[2]))); + // grid->SetCellValue( n, 0, std2wx((*hi)[0]) ); + // grid->SetReadOnly( n, 0 ); + } + for (hi=wxbb_defined.begin();hi!=wxbb_defined.end();++hi) + { + ogrid->Add( new wxStaticText(this,-1, + std2wx((*hi)[0]))); + ogrid->Add( new wxStaticText(this,-1, + std2wx((*hi)[1]))); + ogrid->Add( new wxStaticText(this,-1, + std2wx((*hi)[2]))); + } + for (hi=ubb_defined.begin();hi!=ubb_defined.end();++hi) + { + ogrid->Add( new wxStaticText(this,-1, + std2wx((*hi)[0]))); + ogrid->Add( new wxStaticText(this,-1, + std2wx((*hi)[1]))); + ogrid->Add( new wxStaticText(this,-1, + std2wx((*hi)[2]))); + } + + outputs->Add(ogrid,0,wxGROW); + sizer->Add(outputs,0,wxGROW); + + SetSizer(sizer); SetAutoLayout(true); Layout(); @@ -72,9 +269,9 @@ namespace bbtk WxGUIPackageBrowserUser* user ) : wxPanel(parent, -1), mUser(user), - mInterpreter(0) + mInterpreter() { - std::cout << "WxGUIPackageBrowser::WxGUIPackageBrowser"<SetCaptionFont(somefont); mTree->SetSpacingY(1); + // mTree->SetCheckboxView(true); SetSizer(sizer); SetAutoLayout(true); @@ -107,34 +305,48 @@ namespace bbtk //================================================================ WxGUIPackageBrowser::~WxGUIPackageBrowser() { - if (mInterpreter) delete mInterpreter; + // std::cout << "del interpreter" << std::endl; + // if (mInterpreter) delete mInterpreter; + // std::cout << "ok" << std::endl; } //================================================================ //================================================================ void WxGUIPackageBrowser::IncludeAll() + { + if (!mInterpreter) mInterpreter = bbtk::Interpreter::New(); + mInterpreter->SetCommandLine(true); + mInterpreter->InterpretLine("include *"); + + Factory::Pointer F = mInterpreter->GetExecuter()->GetFactory(); + BuildFromFactory(F); + } + //================================================================ + //================================================================ + + void WxGUIPackageBrowser::BuildFromFactory(Factory::Pointer F) { #ifndef LINUX wxTreeMultiWindowInfo wndinfo(wxTMC_BG_ADJUST_CNT, 8, 0); #else wxTreeMultiWindowInfo wndinfo(wxTMC_BG_ADJUST_ALL, 8, 0); #endif - - if (!mInterpreter) mInterpreter = new bbtk::Interpreter(); - mInterpreter->SetCommandLine(true); - mInterpreter->InterpretLine("include *"); - - Factory* F = mInterpreter->GetExecuter()->GetFactory(); - + mTree->DeleteAllItems(); const Factory::PackageMapType& M = F->GetPackageMap(); Factory::PackageMapType::const_iterator i; for (i=M.begin();i!=M.end();++i) { - Package* P = i->second.mPackage; + Package::Pointer P = i->second; wxString packname = std2wx(P->GetName()); if (packname==_T("user")) continue; wxTreeMultiItem pack = mTree->AddRoot(packname,packname); + wxString packinfo = std2wx(P->GetDescription()); + packinfo += _T(" - by ")+ std2wx(P->GetAuthor()); + packinfo += _T(" - v. ")+ std2wx(P->GetVersion()); + mTree->AppendWindow(pack, + new wxStaticText(mTree, + -1,packinfo)); Package::BlackBoxMapType::iterator j; for (j=P->GetBlackBoxMap().begin(); j!=P->GetBlackBoxMap().end(); @@ -152,8 +364,8 @@ namespace bbtk mTree->CollapseNodes(true); // Test exclude - // wxTreeMultiItem item = mTree->FindItem(_T("Add")); - // if(item.IsOk()) mTree->Exclude(item); + wxTreeMultiItem item = mTree->FindItem(_T("Add")); + if(item.IsOk()) mTree->Exclude(item); } //================================================================ @@ -174,14 +386,14 @@ namespace bbtk // WxGUICommand* com = new WxGUICommand(this,this); // sizer->Add(com); - SetSizer(sizer); + SetSizer(sizer); + + + // Creates the parent window of all bbtk windows as a child of this + Wx::CreateTopWindow(this); + // bbtkAddWxObserver(WxGUIConsole::OnWxSignal); + - // Creates and sets the parent window of all bbtk windows - wxWindow* top = new wxPanel(this,-1); - top->Hide(); - - Wx::SetTopWindow(top); - SetAutoLayout(true); Layout(); } @@ -197,3 +409,4 @@ namespace bbtk #endif //_USE_WXWIDGETS_ +*/