X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=kernel%2Fsrc%2FbbtkWx.cxx;h=46712c4869ad4bcc1bc15da6845677437b2df7ef;hb=865c4a8acc43605c07d519a1d029d5361deeff54;hp=e186c7923a6b8342a768dcc99996ed0164c9324e;hpb=5934ccb7ca0fabdbe6c1907b2aea3696e19a0251;p=bbtk.git diff --git a/kernel/src/bbtkWx.cxx b/kernel/src/bbtkWx.cxx index e186c79..46712c4 100644 --- a/kernel/src/bbtkWx.cxx +++ b/kernel/src/bbtkWx.cxx @@ -5,37 +5,172 @@ namespace bbtk { + //========================================================================= + class WxApp; + //========================================================================= -//EED + //========================================================================= + static WxApp* mgWxApp = 0; static wxWindow* mgTopWindow = 0; + static wxWindow* mgTopWindowParent = 0; + static bool mgAutoDestroyTopWindow = true; static int mgNbWindowsAlive = 0; static int mgNbWindowsShown = 0; + //========================================================================= + + //========================================================================= + // BBTKWXSIG + static Wx::Signal_type mgWxSignal; + // \BBTKWXSIG + //========================================================================= - void Wx::CreateInvisibleTopWindow() + + //========================================================================= + // The wxApp class which is used when no user wxApp was created + class WxApp : public wxApp + { + public: + bool OnInit( ); + int OnExit() { return true; } + }; + //========================================================================= + IMPLEMENT_APP_NO_MAIN(WxApp); + //========================================================================= + bool WxApp::OnInit( ) + { + wxApp::OnInit(); +#ifdef __WXGTK__ + //See http://www.wxwindows.org/faqgtk.htm#locale + setlocale(LC_NUMERIC, "C"); +#endif + return true; + } + //========================================================================= + + //========================================================================= + void Wx::CreateWxAppIfNeeded() + { + if (wxApp::GetInstance()==0) + { + if (mgWxApp != 0) + { + bbtkGlobalError("Wx::CreateWxAppIfNeeded() : INTERNAL ERROR ! (wxApp::GetInstance()==0) && (mgWxApp != 0)"); + } + bbtkDebugMessage("wx",1," --> Creating bbtk wxApp"< Destructing bbtk WxApp"< Creating bbtk top window"<Hide(); + Wx::SetTopWindow(top); } - - void Wx::ResetCursor() + //========================================================================= + + //========================================================================= + void Wx::DestroyTopWindowIfNeeded() { - if (!GetTopWindow()) return; - bbtkDebugMessage("wx",9,"wx::ResetCursor()"< Destructing bbtk top window"<Close(); + mgTopWindow = 0; + + DestroyWxAppIfNeeded(); + } + } + //========================================================================= + + //========================================================================= + void Wx::LoopUntilAllWindowsClose() + { + int i = 0; + while (mgTopWindow != 0) + { + if (i % 100 == 0) + { + bbtkDebugMessage("wx",2,"Wx::Loop "<IsShown())) - { - bbmgTopWindow->Close(); - } - */ + mgNbWindowsAlive++; + bbtkDebugMessage("wx",2,"* Number of windows alive = "<IsShown())) - { - mgTopWindow->Close(); - } + mgNbWindowsAlive--; + bbtkDebugMessage("wx",2,"* Number of windows alive = "<0); - } + /* + //========================================================================= + void Wx::ResetCursor() + { + if (!TopWindowExists()) return; + bbtkDebugMessage("wx",9,"Wx::ResetCursor()"<