X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=kernel%2Fsrc%2FbbtkWx.h;h=d3f3318f86bd3a854ad93d266d743ebb3320e20a;hb=d325fab57e4ef788ab6cca976407c61e58e3ecff;hp=c03b4d52c9a7f9406b5a63857794602623d992d8;hpb=a26195c366a89795288009cf7e20f11afa494970;p=bbtk.git diff --git a/kernel/src/bbtkWx.h b/kernel/src/bbtkWx.h index c03b4d5..d3f3318 100644 --- a/kernel/src/bbtkWx.h +++ b/kernel/src/bbtkWx.h @@ -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". @@ -29,23 +22,101 @@ #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 +#include +// \BBTKWXSIG +//=========================================================================== namespace bbtk { + //================================================================== /// Global wx handlers (cursor...) + +// BBTKWXSIG +#define bbtkAddWxSignalObserver(METHOD) \ + Wx::AddSignalObserver(boost::bind(&METHOD, this)) +// \BBTKWXSIG + + struct BBTK_EXPORT Wx + { + public: + // BBTKWXSIG + typedef boost::signals::trackable SignalObserver; + typedef boost::signal Signal_type; + 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); + + /// Returns the creation time parent of all bbtk windows + /// (window can be reparented after creation) + static wxWindow* GetTopWindow(); + static bool TopWindowExists(); + + static void IncNbWindowsAlive(); + static void DecNbWindowsAlive(); + static int GetNbWindowsAlive(); + static bool IsSomeWindowAlive(); + + static void IncNbWindowsShown(); + static void DecNbWindowsShown(); + static int GetNbWindowsShown(); + static bool IsSomeWindowShown(); + + // 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 + //================================================================== + - struct BBTK_EXPORT wx - { public: - static void ResetCursor(); - static void BeginBusyCursor(); - static void EndBusyCursor(); - static int mBeginBusyCallsCount; - }; // struct wx -//================================================================== +#ifdef _USE_WXWIDGETS_ //================================================================== /// Conversion std::string to wxString inline wxString std2wx(const std::string& s){ @@ -75,29 +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() {} - }; // struct wx - -} // namespace bbtk - - - -#endif // EO _USE_WXWIDGETS #endif // EO __bbtkWx_h_INCLUDED__