FILE(GLOB ${BBTK_PACKAGE_NAME}_CXX_SOURCES "." "*.cxx")
FILE(GLOB ${BBTK_PACKAGE_NAME}_H_SOURCES "." "*.h")
ENDIF(${BBTK_PACKAGE_NAME}_COMPILE_ALL_CXX)
-
-
-SET(${BBTK_PACKAGE_NAME}_CXX_SOURCES
- ${${BBTK_PACKAGE_NAME}_CXX_SOURCES}
- #${CMAKE_CURRENT_BINARY_DIR_NAME}/
- bb${BBTK_PACKAGE_NAME}Package
- )
+IF(NOT PROJECT_BINARY_DIR STREQUAL ${PROJECT_SOURCE_DIR})
+ SET(${BBTK_PACKAGE_NAME}_CXX_SOURCES
+ ${${BBTK_PACKAGE_NAME}_CXX_SOURCES}
+ bb${BBTK_PACKAGE_NAME}Package
+ )
+ENDIF(NOT PROJECT_BINARY_DIR STREQUAL ${PROJECT_SOURCE_DIR})
#----------------------------------------------------------------------------
\section{The Development environment (bbStudio)}
\label{bbStudio}
-Just run it, typing in a console \texttt{bbed}.
+Just run it, typing in a console \bbStudio
+or clicking on its icon or its menu entry.
+At start, \bbStudio opens with the 'Help' tab selected.
You'll get something like in figure
\ref{bbi-fig-bbStudio-gui}
(the exact appearance of \bbStudio is system and \bbtk version dependent)
\end{center}
\end{figure}
-All the entries of this Help 'bookmark' are self-explanatory :
+The 'Help' tab of \bbStudio is used to browse the html help of \BBTK.
+All the entries of the starting page are self-explanatory :
\begin{itemize}
\item {\bf\emph{Wiki}}: Direct link to the bbtk Wiki (intranet only, right now, www
\begin{table}[!ht]
\caption{\label{bbi-list_of_packages} List of bbtk supplied packages.}
\small
-\begin{tabular}{|ll||}
+\begin{tabular}{|lp{10cm}|}
\hline
Package & What it's used for \\ \hline
\texttt{std} & : the 'standard' package including basic useful boxes \\ \hline
\begin{table}[!ht]
\caption{\label{categories} \texttt{Black Box} categories}
\small
-\begin{tabular}{|ll|}
+\begin{tabular}{|lp{10cm}|}
\hline
- \texttt{Categ name} & : Meaning \\ \hline \\ \hline
+ \texttt{Category name} & : Meaning \\ \hline \\ \hline
\texttt{adaptor} & : Adaptor box \\ \hline
\texttt{application} & : Final application, end user intended \\ \hline
\texttt{atomic box} & : System category.
Outputs : \\
- Out : the isosurface mesh (vtkPolyData*)
- \paragraph{ImageGaussianSmooth}\\
+ \paragraph{ImageGaussianSmooth}
Performs a gaussian convolution of the input image\\
Receives : \\
- In : an image (vtkImageData*)\\
Outputs :
- Out : The image (vtkImageData*)
- \paragraph{SegmentationConnectivity} \\
+ \paragraph{SegmentationConnectivity}
Segmentation with min max threshold and connectivity \\
Receives : \\
- In : an image (vtkImageData*)\\
<meta http-equiv="Content-Type"
content="text/html; charset=iso-8859-1">
</head>
+
<body style="color: rgb(0, 0, 0); background-color: rgb(255, 255, 255);">
-<small><a target="information" href="home.html">Home</a><br>
-Screenshots<br>
+<small>
+<a target="information" href="home.html">Home</a>
+<br>Screenshots<br>
<a target="information" href="download.html">Download</a><br>
<a target="information" href="install.html">Install</a><br>
License<br>
-bbtk <a target="information"
- href="http://www.creatis.insa-lyon.fr/mywiki/Informatique/bbtk">Wiki</a>
-<br>
-<a target="information"
- href="http://www.creatis.insa-lyon.fr/mailman/listinfo/bbtk-users">bbtk users mailing list</a>
-<br>
-</small><font size="2"><a target="information"
- href="../bbdoc/index-category.html#demo">Demos</a></font><br>
-<font size="2"><a target="information"
- href="../bbdoc/index-category.html#example">Examples</a></font><br>
-
-
-
-<hr style="width: 100%; height: 2px;">Documentation<small><span
- style="font-weight: bold;"></span><br>
-<span style="font-weight: bold;"></span></small>
-<blockquote><small> </small></blockquote>
-
+bbtk <a target="information" href="http://www.creatis.insa-lyon.fr/mywiki/Informatique/bbtk">Wiki</a> <br>
+<a target="information" href="http://www.creatis.insa-lyon.fr/mailman/listinfo/bbtk-users">bbtk users mailing list</a> <br>
+<a target="information" href="../bbdoc/index-category.html#demo">Demos</a><br>
+<a target="information" href="../bbdoc/index-category.html#example">Examples</a>
+</small>
+<hr style="width: 100%; height: 2px;">BBTK doc<br><br>
<small><font size="3"><small><a href="../bbtkUsersGuide/bbtkUsersGuide.html" target="information">User's Guide</a>
(<font size="2"><small><small><a href="../bbtkUsersGuide/bbtkUsersGuide.pdf" target="information">pdf</a></small></small></font>)
<small><font size="3"><small> <small><font size="3"><small><a href="../bbtkDevelopersGuide/bbtkDevelopersGuide.html"
target="information">Developer's Guide</a>
(<font size="2"><small><small><a href="../bbtkDevelopersGuide/bbtkDevelopersGuide.pdf" target="information">pdf</a></small></small></font>)<br>
-
Reference Manual(pdf)<br> </small></font></small>
-
- <small><font size="3"><small> <a href="../doxygen/bbtk/main.html" target="information">Doxygen doc</a></small></font></small>
+<small><font size="3"><small> <a href="../doxygen/bbtk/main.html" target="information">bbtk library doxygen doc</a></small></font></small>
<ul>
</ul>
-<hr style="width: 100%; height: 2px;">Boxes<br>
-<br>
+<hr style="width: 100%; height: 2px;">Boxes doc<br><br>
<font size="2">
+<small>
<a target="information" href="../bbdoc/index-alpha.html">Alphabetical list</a><br>
<a target="information" href="../bbdoc/index-package.html">List by package</a><br>
<a target="information" href="../bbdoc/index-category.html">List by category</a><br>
<a target="information" href="../bbdoc/index-adaptors.html">List of adaptors</a></font><br>
-
+</small>
<hr style="width: 100%; height: 2px;">
<blockquote><big> </big></blockquote>
Program: bbtk
Module: $RCSfile: bbtkConfigurationFile.cxx,v $
Language: C++
- Date: $Date: 2008/03/17 10:51:35 $
- Version: $Revision: 1.14 $
+ Date: $Date: 2008/09/10 07:25:23 $
+ Version: $Revision: 1.15 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See doc/license.txt or
// ==> Then we look for bbtk_config.xml in ".bbtk"
else
{
-#if defined(__GNUC__)
- std::string str_home(getenv("HOME"));
-#elif defined(_WIN32)
- std::string str_home(getenv("USERPROFILE"));
-#endif
-//EED configXmlFullPathName = str_home + mFile_separator + ".bbtk/bbtk_config.xml";
- configXmlFullPathName = str_home + "/.bbtk/bbtk_config.xml";
- Utilities::replace( configXmlFullPathName , INVALID_FILE_SEPARATOR , VALID_FILE_SEPARATOR);
-
+ configXmlFullPathName = Utilities::MakeUserSettingsFullFileName("bbtk_config.xml");
if (!Utilities::FileExists( configXmlFullPathName ))
{
// ==> Nothing found, we create bbtk_config.xml in ".bbtk"
Program: bbtk
Module: $RCSfile: bbtkConfigurationFile.h,v $
Language: C++
- Date: $Date: 2008/03/26 08:27:19 $
- Version: $Revision: 1.7 $
+ Date: $Date: 2008/09/10 07:25:23 $
+ Version: $Revision: 1.8 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See doc/license.txt or
#include <vector>
- // file separator
-#if defined(_WIN32)
-#define VALID_FILE_SEPARATOR "\\"
-#define INVALID_FILE_SEPARATOR "/"
-#else
-#define INVALID_FILE_SEPARATOR "\\"
-#define VALID_FILE_SEPARATOR "/"
-#endif
-
-
namespace bbtk
{
Program: bbtk
Module: $RCSfile: bbtkSystem.h,v $
Language: C++
- Date: $Date: 2008/07/24 14:37:05 $
- Version: $Revision: 1.5 $
+ Date: $Date: 2008/09/10 07:25:23 $
+ 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
} // namespace bbtk
//-----------------------------------------------------------------------------
+ // file separator
+#if defined(_WIN32)
+#define VALID_FILE_SEPARATOR "\\"
+#define INVALID_FILE_SEPARATOR "/"
+#else
+#define INVALID_FILE_SEPARATOR "\\"
+#define VALID_FILE_SEPARATOR "/"
+#endif
+
#endif
#include "bbtkUtilities.h"
+
namespace bbtk
{
return libname;
}
+ // =======================================================================
+ /// Builds the complete path to the file 'name' located
+ /// in user settings dir, e.g. /home/username/.bbtk/
+ std::string Utilities::MakeUserSettingsFullFileName(const std::string& name)
+ {
+#if defined(__GNUC__)
+ std::string str_home(getenv("HOME"));
+#elif defined(_WIN32)
+ std::string str_home(getenv("USERPROFILE"));
+#endif
+ std::string fullname = str_home + "/.bbtk/" + name;
+ Utilities::replace( fullname,
+ INVALID_FILE_SEPARATOR ,
+ VALID_FILE_SEPARATOR);
+ return fullname;
+ }
+
+
+
//========================================================================
bool Utilities::IsAtRoot(std::string cwd)
Program: bbtk
Module: $RCSfile: bbtkUtilities.h,v $
Language: C++
- Date: $Date: 2008/05/06 13:45:12 $
- Version: $Revision: 1.15 $
+ Date: $Date: 2008/09/10 07:25:23 $
+ Version: $Revision: 1.16 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See doc/license.txt or
static std::string MakePkgnameFromPath(std::string path, std::string pkgname, bool addExt);
//========================================================================
+ // =======================================================================
+ /// Builds the complete path to the file 'name' located
+ /// in user settings dir, e.g. /home/username/.bbtk/
+ static std::string MakeUserSettingsFullFileName(const std::string& name);
+
+
static bool IsAtRoot(std::string cwd);
// ======================================================================
Program: bbtk
Module: $RCSfile: bbtkWxGUIScriptingInterface.cxx,v $
Language: C++
- Date: $Date: 2008/07/24 14:37:06 $
- Version: $Revision: 1.15 $
+ Date: $Date: 2008/09/10 07:25:23 $
+ Version: $Revision: 1.16 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See Doc/License.txt or
#include "bbtkWxBlackBox.h"
#include "bbtkConfigurationFile.h"
#include "bbtkWxStreamRedirector.h"
-
+#include "bbtkUtilities.h"
+
//#include "icons/cc_run.xpm"
WxGUIScriptingInterface::WxGUIScriptingInterface( wxWindow *parent, wxString title, wxSize size)
: wxFrame((wxFrame *)parent, -1, title, wxDefaultPosition, size)
{
-// m_mgr = new wxAuiManager(this);
- m_mgr.SetManagedWindow(this);
-
- mInterpreter = bbtk::Interpreter::New();
+ // m_mgr = new wxAuiManager(this);
+ m_mgr.SetManagedWindow(this);
+
+ mInterpreter = bbtk::Interpreter::New();
mInterpreter->SetUser(this);
mInterpreter->SetCommandLine(true);
mInterpreter->SetThrow(true);
+
//==============
// Menu
wxInitAllImageHandlers();
wxMenu *menuTools = new wxMenu;
menuTools->Append( ID_Menu_EditConfig, _T("&Edit bbtk config") );
menuTools->Append( ID_Menu_CreatePackage, _T("Create &package") );
- menuTools->Append( ID_Menu_CreateBlackBox, _T("Create &blackbox") );
+ menuTools->Append( ID_Menu_CreateBlackBox, _T("Create &black box") );
menuTools->Append( ID_Menu_ShowImageGraph, _T("&Show last image graph") );
menuTools->Append( ID_Menu_CreateIndex, _T("&Generate index") );
menuWindows->AppendCheckItem(ID_Menu_Windows_Command,
_T("Show 'command' panel") )->Check();
menuWindows->AppendSeparator();
- menuWindows->Append( ID_Menu_Windows_PackageBrowser, _T("Show Package &Browser") );
+ menuWindows->Append( ID_Menu_Windows_PackageBrowser, _T("Launch Package &Browser") );
- menuWindows->AppendSeparator();
- menuWindows->Append ( ID_Menu_Windows_Save, _T("Save interface configuration"));
+ // menuWindows->AppendSeparator();
+ // menuWindows->Append ( ID_Menu_Windows_Save, _T("Save interface configuration"));
wxMenu *menuOptions = new wxMenu;
mwxMenuItemReset = menuOptions->AppendCheckItem(-1,
mWxGUITextEditor = new WxGUITextEditor(this,this);
mWxGUITextEditor->SetFileNameFilter("*.bbs");
- mWxGUIHtmlBrowser = new WxGUIHtmlBrowser(this,wxSize(200,0),this);
+ mWxGUIHtmlBrowser = new WxGUIHtmlBrowser(this,wxSize(200,0),this);
-
- /*
- wxBitmap bmp_run(cc_run_xpm);
- mwxButtonRun = new wxBitmapButton( this, ID_Button_Run,bmp_run);//_T("Run") );
- */
-
mWxGUIOutputMessages = new WxGUIOutputMessages(this);
mWxGUICommand = new WxGUICommand(this,this);
mWxGUICommand->SetFocus();
+#if NOTEBOOK
mwxNotebook = new wxAuiNotebook(this,
-1,
.Center()
// .MinSize(wxSize(100,100))
);
+#else
- /*
//
m_mgr.AddPane(mWxGUITextEditor,
wxAuiPaneInfo().Name(wxT("editor_content"))
.Caption(wxT("Files"))
.MinimizeButton(true)
.MaximizeButton(true)
- .Center()
+ .Left()
.MinSize(wxSize(100,100))
);
.Position(1)
.MinSize(wxSize(100,100))
);
- */
- // m_mgr.AddPane(mwxButtonRun,
- // wxAuiPaneInfo().Name(wxT("button_run_content")));
+#endif
// parent window of all bbtk windows will be a child of this
Wx::SetTopWindowParent(this);
//bbtkAddWxSignalObserver(WxGUIPackageBrowser2Window::OnWxSignal);
//.PaneBorder(false));
- m_mgr.Update();
+ LoadPerspective();
+
+ // m_mgr.Update();
SetAutoLayout(true);
Layout();
- mwxNotebook->SetSelection(1);
+ // mwxNotebook->SetSelection(1);
mWxGUIHtmlBrowser->GoHome();
// Refresh();
// m_mgr.Update();
+ // LoadPerspective();
+
}
//================================================================
//================================================================
WxGUIScriptingInterface::~WxGUIScriptingInterface()
{
+ SavePerspective();
m_mgr.UnInit();
}
//================================================================
//================================================================
void WxGUIScriptingInterface::OnMenuWindowsPackageBrowser(wxCommandEvent& WXUNUSED(event))
{
- wxBusyCursor wait;
- WxGUIPackageBrowser2 *browser = new WxGUIPackageBrowser2(this);
- browser->IncludeAll();
- mwxNotebook->AddPage(browser,_T("Package Browser"),true);
+ wxBusyCursor wait;
+ WxGUIPackageBrowser2Window *helpbrowser = new
+ WxGUIPackageBrowser2Window(this,_T("Package Browser"), wxSize(600,600) );
+ helpbrowser->Show();
+
+ /*
+ wxBusyCursor wait;
+ WxGUIPackageBrowser2 *browser = new WxGUIPackageBrowser2(this);
+ browser->IncludeAll();
+ */
+#if NOTEBOOK
+ // mwxNotebook->AddPage(browser,_T("Package Browser"),true);
+#else
+ /*
+ m_mgr.AddPane(browser,
+ wxAuiPaneInfo().Name(wxT("package_brower"))
+ .Caption(wxT("Package browser"))
+ .MinimizeButton(true)
+ .MaximizeButton(true)
+ .Bottom()
+ .Position(1)
+ .MinSize(wxSize(100,100))
+ );
+ */
+#endif
}
//================================================================
&& (target[s-4]=='.'))
{
mWxGUITextEditor->Open(target);
+#if NOTEBOOK
mwxNotebook->SetSelection(0);
+#endif
mWxGUITextEditor->SetFocus();
return false;
}
//================================================================
void WxGUIScriptingInterface::OnMenuWindowsSave( wxCommandEvent& WXUNUSED(event))
{
- // TO DO : Save it into ConfigurationFile
- // m_mgr.SavePerspective();
+ SavePerspective();
+ }
+ //================================================================
+
+ //================================================================
+ void WxGUIScriptingInterface::SavePerspective()
+ {
+ // std::cout << "Saving configuration..."<<std::endl;
+ std::string conf = wx2std(m_mgr.SavePerspective());
+ std::string fname = Utilities::MakeUserSettingsFullFileName("bbStudio.aui");
+ std::ofstream f;
+ f.open(fname.c_str(), std::ios::out );
+ f << conf << std::endl;
+
+ int w,h;
+ GetSize(&w,&h);
+
+ f << w << " " << h << std::endl;
+
+ f.close();
}
//================================================================
+ //================================================================
+ void WxGUIScriptingInterface::LoadPerspective()
+ {
+ std::string fname =
+ Utilities::MakeUserSettingsFullFileName("bbStudio.aui");
+ if ( Utilities::FileExists( fname ))
+ {
+ // std::cout << "Loading configuration..."<<std::endl;
+
+ std::ifstream f;
+ f.open(fname.c_str());
+ std::string conf;
+ f >> conf;
+
+ int w,h;
+
+ f >> w >> h ;
+
+ f.close();
+
+ // std::cout << conf << std::endl;
+
+ SetSize(w,h);
+ m_mgr.LoadPerspective(std2wx(conf));
+ }
+ else
+ {
+ m_mgr.Update();
+ }
+ }
+ //================================================================
//================================================================
void WxGUIScriptingInterface::OnPaneClose(wxAuiManagerEvent& evt)
EVT_MENU(ID_Menu_Windows_Help, WxGUIScriptingInterface::OnMenuWindowsHelp)
EVT_MENU(ID_Menu_Windows_Messages, WxGUIScriptingInterface::OnMenuWindowsMessages)
EVT_MENU(ID_Menu_Windows_Command, WxGUIScriptingInterface::OnMenuWindowsCommand)
+ EVT_MENU(ID_Menu_Windows_Save, WxGUIScriptingInterface::OnMenuWindowsSave)
EVT_MENU(ID_Menu_Windows_PackageBrowser, WxGUIScriptingInterface::OnMenuWindowsPackageBrowser)
EVT_AUI_PANE_CLOSE(WxGUIScriptingInterface::OnPaneClose)
// EVT_BUTTON(ID_Button_Run, WxGUIScriptingInterface::OnButtonRun )
Program: bbtk
Module: $RCSfile: bbtkWxGUIScriptingInterface.h,v $
Language: C++
- Date: $Date: 2008/06/26 06:50:05 $
- Version: $Revision: 1.8 $
+ Date: $Date: 2008/09/10 07:25:23 $
+ Version: $Revision: 1.9 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See Doc/License.txt or
wxWindow* w);
void OnPaneClose(wxAuiManagerEvent& evt);
-
+ void SavePerspective();
+ void LoadPerspective();
// void OnButtonRun(wxCommandEvent& WXUNUSED(event));
// Interpreter callbacks
Program: bbtk
Module: $RCSfile: bbtkWxGUITextEditor.cxx,v $
Language: C++
- Date: $Date: 2008/07/24 14:37:06 $
- Version: $Revision: 1.15 $
+ Date: $Date: 2008/09/10 07:25:23 $
+ Version: $Revision: 1.16 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See Doc/License.txt or
}
mwxNotebook->DeletePage(mwxNotebook->GetSelection());
FocusOnCurrentPage();
- return false;
+ return true;
}
//================================================================