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 )