X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;ds=sidebyside;f=kernel%2Fsrc%2FbbtkWx.cxx;h=46712c4869ad4bcc1bc15da6845677437b2df7ef;hb=865c4a8acc43605c07d519a1d029d5361deeff54;hp=346d0fbfe94263dfe720a2a634ce61041691943c;hpb=2b8d8f686974ab38c9ffcf0f88dd533b01b68e84;p=bbtk.git diff --git a/kernel/src/bbtkWx.cxx b/kernel/src/bbtkWx.cxx index 346d0fb..46712c4 100644 --- a/kernel/src/bbtkWx.cxx +++ b/kernel/src/bbtkWx.cxx @@ -5,38 +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(wxWindow* parent) + + //========================================================================= + // 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()"<