]> Creatis software - bbtk.git/blobdiff - kernel/src/bbtkWxGUIPackageBrowser.cxx
*** empty log message ***
[bbtk.git] / kernel / src / bbtkWxGUIPackageBrowser.cxx
index 2a5d0f5561845480f41c34e01528bbf3450e1602..18de91fff0fc1b359dda7509231beec5a33e10d9 100644 (file)
@@ -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
  * \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 <wx/statline.h>
+
 
 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<std::vector<std::string> > user_defined;
+    std::vector<std::vector<std::string> > ubb_defined;
+    std::vector<std::vector<std::string> > 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<std::string> 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<std::vector<std::string> >::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<std::string> 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"<<std::endl;
+
     wxBoxSizer *sizer = new wxBoxSizer(wxVERTICAL);
     mTree = new wxTreeMultiCtrl(this, -1);
     
@@ -96,6 +293,7 @@ namespace bbtk
     mTree->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_
+*/