X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=kernel%2Fsrc%2FbbtkWx.cxx;h=46712c4869ad4bcc1bc15da6845677437b2df7ef;hb=d1d5708a8d72ce09181c7ff0924d2fff15e3c2cc;hp=aa05db7b0633e969f12352490573b3335a180011;hpb=174ea6d71477e40679f4fd71952e3f2a03416098;p=bbtk.git diff --git a/kernel/src/bbtkWx.cxx b/kernel/src/bbtkWx.cxx index aa05db7..46712c4 100644 --- a/kernel/src/bbtkWx.cxx +++ b/kernel/src/bbtkWx.cxx @@ -2,39 +2,149 @@ #include "bbtkWx.h" #include "bbtkMessageManager.h" -#include -//#include namespace bbtk { + //========================================================================= + class WxApp; + //========================================================================= + //========================================================================= + static WxApp* mgWxApp = 0; static wxWindow* mgTopWindow = 0; + static wxWindow* mgTopWindowParent = 0; + static bool mgAutoDestroyTopWindow = true; static int mgNbWindowsAlive = 0; static int mgNbWindowsShown = 0; - static bool mgAutoDestroyTopWindow = true; + //========================================================================= + //========================================================================= // BBTKWXSIG static Wx::Signal_type mgWxSignal; // \BBTKWXSIG + //========================================================================= + + //========================================================================= + // 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); - mgAutoDestroyTopWindow = autodestroy; } //========================================================================= - + + //========================================================================= + void Wx::DestroyTopWindowIfNeeded() + { + if ( (mgNbWindowsAlive==0) && + (mgAutoDestroyTopWindow) ) + { + bbtkDebugMessage("wx",1," --> 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 "< Destructing top window"<Close(); - mgTopWindow = 0; - } - // BBTKWXSIG + + DestroyTopWindowIfNeeded(); + // BBTKWXSIG mgWxSignal(); // \BBTKWXSIG } @@ -123,13 +228,9 @@ namespace bbtk mgNbWindowsShown--; bbtkDebugMessage("wx",2,"* Number of windows shown = "< Destructing top window"<Close(); - mgTopWindow = 0; - } + + DestroyTopWindowIfNeeded(); + // BBTKWXSIG mgWxSignal(); // \BBTKWXSIG @@ -166,6 +267,29 @@ namespace bbtk } //========================================================================= + + //========================================================================= + Wx::BusyCursor::BusyCursor() + { + if (TopWindowExists()) + { + bbtkDebugMessage("wx",2, + "Wx::BusyCursor::BusyCursor()"<