]> Creatis software - bbtk.git/blobdiff - kernel/src/bbtkWx.h
*** empty log message ***
[bbtk.git] / kernel / src / bbtkWx.h
index 30c86f8ab7335c3a02ea5fcc1efa72217e322edb..d3f3318f86bd3a854ad93d266d743ebb3320e20a 100644 (file)
@@ -1,14 +1,7 @@
 #ifndef __bbtkWx_h_INCLUDED__
 #define __bbtkWx_h_INCLUDED__
 
-
-/*
-#ifdef wxUSE_STD_IOSTREAM
-#undef wxUSE_STD_IOSTREAM
-#endif
-#define wxUSE_STD_IOSTREAM 0
-*/
-
+//===========================================================================
 // Wx headers
 #ifdef _USE_WXWIDGETS_
 // For compilers that support precompilation, includes "wx/wx.h".
 #endif //__WXGTK__
 // EO Wx headers
 
+#else //_USE_WXWIDGETS_
+
+// define wxWindow
+typedef void wxWindow;
+
+#endif // EO _USE_WXWIDGETS_
+//===========================================================================
+
+//===========================================================================
 #include "bbtkSystem.h"
+//===========================================================================
 
+//===========================================================================
 // SIGNAL/SLOT MECHANISM 
 // FOR bbtk WINDOWS CREATION/DESTRUCTION OBSERVATION 
 // BBTKWXSIG
 #include <boost/signal.hpp>
 #include <boost/bind.hpp>
 // \BBTKWXSIG
+//===========================================================================
 
 namespace bbtk
 {
+
   //==================================================================
   /// Global wx handlers (cursor...)
   
@@ -57,17 +63,28 @@ namespace bbtk
     typedef Signal_type::slot_function_type Slot_function_type;
     // \BBTKWXSIG
 
+    /*
     static void ResetCursor();
     static void BeginBusyCursor(); 
     static void EndBusyCursor();
+    */
+
+    static void LoopUntilAllWindowsClose();
+
+    class BusyCursor
+    {
+    public:
+      BusyCursor();
+      ~BusyCursor();
+    };
+
+    static void SetTopWindowParent(wxWindow*);
+    static void SetAutoDestroyTopWindow(bool);
 
-    static void CreateTopWindow(wxWindow* parent=0, bool autodestroy=true);
     /// Returns the creation time parent of all bbtk windows 
     /// (window can be reparented after creation)
     static wxWindow* GetTopWindow();
     static bool TopWindowExists();
-
-    static void AutoDestroyTopWindow(bool);
     
     static void IncNbWindowsAlive();
     static void DecNbWindowsAlive();
@@ -82,7 +99,15 @@ namespace bbtk
     // BBTKWXSIG
     static void AddSignalObserver(Slot_function_type);
     // \BBTKWXSIG
+
   private:
+
+    static void CreateWxAppIfNeeded();
+    static void DestroyWxAppIfNeeded();
+
+    static void CreateTopWindowIfNeeded();
+    static void DestroyTopWindowIfNeeded();
+
     /// Sets the creation time parent of all bbtk windows
     static void SetTopWindow(wxWindow*);
   }; // struct Wx
@@ -90,6 +115,8 @@ namespace bbtk
   
 
 
+
+#ifdef _USE_WXWIDGETS_
   //==================================================================
   /// Conversion std::string to wxString 
   inline wxString std2wx(const std::string& s){
@@ -119,41 +146,10 @@ namespace bbtk
     return s2;
   }
   //==================================================================
-
+#endif // EO _USE_WXWIDGETS
 
   
 } // namespace bbtk
   
 
-
-#else // _USE_WXWIDGETS
-
-
-namespace bbtk
-{
-
-  struct BBTK_EXPORT Wx
-  {
-    static void ResetCursor() {}
-    static void BeginBusyCursor() {}
-    static void EndBusyCursor() {}
-    static void CreateInvisibleTopWindow() {}
-    static wxWindow* GetTopWindow() { return 0; }
-    static void SetTopWindow(wxWindow*) {}
-    static void IncNbWindowsAlive() {}
-    static void DecNbWindowsAlive() {}
-    static int  GetNbWindowsAlive() { return 0; }
-    static bool IsSomeWindowAlive() { return false; }
-    
-    static void IncNbWindowsShown() {}
-    static void DecNbWindowsShown() {}
-    static int  GetNbWindowsShown() { return 0; }
-    static bool IsSomeWindowShown() { return false; }
-  }; // struct Wx
-
-} // namespace bbtk
-  
-
-
-#endif // EO _USE_WXWIDGETS
 #endif // EO __bbtkWx_h_INCLUDED__