]> git.saurik.com Git - wxWidgets.git/blobdiff - include/wx/mac/toplevel.h
Reverted part of patch #876969 ("Fixes to Borland warnings"), resulted in bugs when...
[wxWidgets.git] / include / wx / mac / toplevel.h
index 89f8cc9580c9380bcfb1f78543f8da35a9a8224c..ffb0bcd288f30ff962c2f161a8b87bbc5db52bcf 100644 (file)
@@ -1,21 +1,25 @@
 ///////////////////////////////////////////////////////////////////////////////
 // Name:        wx/mac/toplevel.h
 // Purpose:     wxTopLevelWindowMac is the Mac implementation of wxTLW
 ///////////////////////////////////////////////////////////////////////////////
 // Name:        wx/mac/toplevel.h
 // Purpose:     wxTopLevelWindowMac is the Mac implementation of wxTLW
-// Author:      Vadim Zeitlin
+// Author:      Stefan Csomor
 // Modified by:
 // Created:     20.09.01
 // RCS-ID:      $Id$
 // Modified by:
 // Created:     20.09.01
 // RCS-ID:      $Id$
-// Copyright:   (c) 2001 SciTech Software, Inc. (www.scitechsoft.com)
+// Copyright:   (c) 2001 Stefan Csomor
 // Licence:     wxWindows licence
 ///////////////////////////////////////////////////////////////////////////////
 
 #ifndef _WX_MSW_TOPLEVEL_H_
 #define _WX_MSW_TOPLEVEL_H_
 
 // Licence:     wxWindows licence
 ///////////////////////////////////////////////////////////////////////////////
 
 #ifndef _WX_MSW_TOPLEVEL_H_
 #define _WX_MSW_TOPLEVEL_H_
 
-#ifdef __GNUG__
+#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
     #pragma interface "toplevel.h"
 #endif
 
     #pragma interface "toplevel.h"
 #endif
 
+#if wxUSE_SYSTEM_OPTIONS
+    #define wxMAC_WINDOW_PLAIN_TRANSITION _T("mac.window-plain-transition")
+#endif
+
 // ----------------------------------------------------------------------------
 // wxTopLevelWindowMac
 // ----------------------------------------------------------------------------
 // ----------------------------------------------------------------------------
 // wxTopLevelWindowMac
 // ----------------------------------------------------------------------------
@@ -58,35 +62,48 @@ public:
     virtual void SetIcons(const wxIconBundle& icons) { SetIcon( icons.GetIcon( -1 ) ); }
     virtual void Restore();
 
     virtual void SetIcons(const wxIconBundle& icons) { SetIcon( icons.GetIcon( -1 ) ); }
     virtual void Restore();
 
-    virtual bool ShowFullScreen(bool show, long style = wxFULLSCREEN_ALL) { return FALSE; }
+    virtual bool SetShape(const wxRegion& region);
+
+    virtual bool ShowFullScreen(bool WXUNUSED(show), long WXUNUSED(style) = wxFULLSCREEN_ALL)
+    { return FALSE; }
     virtual bool IsFullScreen() const { return FALSE; }
 
     // implementation from now on
     // --------------------------
 
     virtual bool IsFullScreen() const { return FALSE; }
 
     // implementation from now on
     // --------------------------
 
-       virtual void MacCreateRealWindow( const wxString& title,
-           const wxPoint& pos,
-           const wxSize& size,
-           long style,
-           const wxString& name ) ;
-       static WXWindow MacGetWindowInUpdate() { return s_macWindowInUpdate ; }
-       virtual void MacGetPortParams(WXPOINTPTR localOrigin, WXRECTPTR clipRect, WXWindow *window , wxWindowMac** rootwin ) ;
-  virtual void Clear() ;
-  virtual WXWidget MacGetContainerForEmbedding() ;
-  WXWindow MacGetWindowRef() { return m_macWindow ; }
-       virtual void MacActivate( WXEVENTREF ev , bool inIsActivating ) ;
-       virtual void MacUpdate( long timestamp ) ;
-       virtual void MacMouseDown( WXEVENTREF ev , short windowPart ) ;
-       virtual void MacMouseUp( WXEVENTREF ev , short windowPart ) ;
-       virtual void MacMouseMoved( WXEVENTREF ev , short windowPart ) ;
-       virtual void MacKeyDown( WXEVENTREF ev ) ;
-       virtual void MacFireMouseEvent( WXEVENTREF ev ) ;
-  virtual void Raise();
-  virtual void Lower();
-  virtual void SetTitle( const wxString& title);
-  virtual bool Show( bool show = TRUE );
-  virtual void DoMoveWindow(int x, int y, int width, int height);
-  void MacInvalidate( const WXRECTPTR rect, bool eraseBackground ) ;
+    static void MacDelayedDeactivation(long timestamp);
+    virtual void MacCreateRealWindow( const wxString& title,
+                                      const wxPoint& pos,
+                                      const wxSize& size,
+                                      long style,
+                                      const wxString& name ) ;
+    static WXWindow MacGetWindowInUpdate() { return s_macWindowInUpdate ; }
+    virtual void MacGetPortParams(WXPOINTPTR localOrigin, WXRECTPTR clipRect, WXWindow *window , wxWindowMac** rootwin ) ;
+    virtual void ClearBackground() ;
+    virtual WXWidget MacGetContainerForEmbedding() ;
+    WXWindow MacGetWindowRef() { return m_macWindow ; }
+    virtual void MacActivate( long timestamp , bool inIsActivating ) ;
+    virtual void MacUpdate( long timestamp ) ;
+#if !TARGET_CARBON
+    virtual void MacMouseDown( WXEVENTREF ev , short windowPart ) ;
+    virtual void MacMouseUp( WXEVENTREF ev , short windowPart ) ;
+    virtual void MacMouseMoved( WXEVENTREF ev , short windowPart ) ;
+    virtual void MacKeyDown( WXEVENTREF ev ) ;
+#endif
+    virtual void MacFireMouseEvent( wxUint16 kind , wxInt32 x , wxInt32 y ,wxUint32 modifiers , long timestamp ) ;
+    virtual void Raise();
+    virtual void Lower();
+    virtual void SetTitle( const wxString& title);
+    virtual bool Show( bool show = TRUE );
+    virtual void DoMoveWindow(int x, int y, int width, int height);
+    void MacInvalidate( const WXRECTPTR rect, bool eraseBackground ) ;
+    short MacGetWindowBackgroundTheme() const { return m_macWindowBackgroundTheme ; }
+    static bool MacEnableCompositing( bool useCompositing ); 
+    bool MacUsesCompositing() { return m_macUsesCompositing; } 
+
+#if TARGET_CARBON
+    WXEVENTHANDLERREF    MacGetEventHandler() { return m_macEventHandler ; }
+#endif
 protected:
     // common part of all ctors
     void Init();
 protected:
     // common part of all ctors
     void Init();
@@ -97,6 +114,7 @@ protected:
     // should the frame be maximized when it will be shown? set by Maximize()
     // when it is called while the frame is hidden
     bool m_maximizeOnShow;
     // should the frame be maximized when it will be shown? set by Maximize()
     // when it is called while the frame is hidden
     bool m_maximizeOnShow;
+    bool m_macUsesCompositing ;
 
     short m_macWindowBackgroundTheme ;
     WXWindow m_macWindow ;
 
     short m_macWindowBackgroundTheme ;
     WXWindow m_macWindow ;
@@ -105,7 +123,13 @@ protected:
     WXHRGN m_macNoEraseUpdateRgn ;
     bool m_macNeedsErasing ;
 
     WXHRGN m_macNoEraseUpdateRgn ;
     bool m_macNeedsErasing ;
 
-         static WXWindow s_macWindowInUpdate ;
+    static WXWindow s_macWindowInUpdate ;
+    static wxTopLevelWindowMac *s_macDeactivateWindow;
+    static bool s_macWindowCompositing ;
+private :
+#if TARGET_CARBON
+    WXEVENTHANDLERREF    m_macEventHandler ;
+#endif
 };
 
 // list of all frames and modeless dialogs
 };
 
 // list of all frames and modeless dialogs