+class wxWindowMac;
+// to
+extern wxWindow* g_MacLastWindow;
+class wxNonOwnedWindow;
+
+class WXDLLIMPEXP_CORE wxWidgetImpl : public wxObject
+{
+public :
+ wxWidgetImpl( wxWindowMac* peer , bool isRootControl = false );
+ wxWidgetImpl();
+ virtual ~wxWidgetImpl();
+
+ void Init();
+
+ virtual void Destroy();
+
+ bool IsRootControl() const { return m_isRootControl; }
+
+ wxWindowMac* GetWXPeer() const { return m_wxPeer; }
+
+ bool IsOk() const { return GetWXWidget() != NULL; }
+
+ // not only the control itself, but also all its parents must be visible
+ // in order for this function to return true
+ virtual bool IsVisible() const = 0;
+ // set the visibility of this widget (maybe latent)
+ virtual void SetVisibility( bool visible ) = 0;
+
+ virtual void Raise() = 0;
+
+ virtual void Lower() = 0;
+
+ virtual void ScrollRect( const wxRect *rect, int dx, int dy ) = 0;
+
+ virtual WXWidget GetWXWidget() const = 0;
+
+ virtual void SetBackgroundColour( const wxColour& col ) = 0;
+
+ // all coordinates in native parent widget relative coordinates
+ virtual void GetContentArea( int &left , int &top , int &width , int &height ) const = 0;
+ virtual void Move(int x, int y, int width, int height) = 0;
+ virtual void GetPosition( int &x, int &y ) const = 0;
+ virtual void GetSize( int &width, int &height ) const = 0;
+
+ virtual void SetNeedsDisplay( const wxRect* where = NULL ) = 0;
+ virtual bool GetNeedsDisplay() const = 0;
+
+ virtual bool NeedsFocusRect() const;
+ virtual void SetNeedsFocusRect( bool needs );
+
+ virtual bool CanFocus() const = 0;
+ // return true if successful
+ virtual bool SetFocus() = 0;
+ virtual bool HasFocus() const = 0;
+
+ virtual void RemoveFromParent() = 0;
+ virtual void Embed( wxWidgetImpl *parent ) = 0;
+
+ // static creation methods, must be implemented by all toolkits
+
+ static wxWidgetImpl* CreateUserPane( wxWindowMac* wxpeer, const wxPoint& pos, const wxSize& size,
+ long style, long extraStyle, const wxString& name) ;
+ static wxWidgetImpl* CreateContentView( wxNonOwnedWindow* now ) ;
+
+ // converts from Toplevel-Content relative to local
+ static void Convert( wxPoint *pt , wxWidgetImpl *from , wxWidgetImpl *to );
+protected :
+ bool m_isRootControl;
+ wxWindowMac* m_wxPeer;
+ bool m_needsFocusRect;
+
+ DECLARE_ABSTRACT_CLASS(wxWidgetImpl)
+};
+
+class wxNonOwnedWindowImpl : public wxObject
+{
+public :
+ wxNonOwnedWindowImpl( wxNonOwnedWindow* nonownedwnd) : m_wxPeer(nonownedwnd)
+ {
+ }
+ wxNonOwnedWindowImpl()
+ {
+ }
+ virtual ~wxNonOwnedWindowImpl()
+ {
+ }
+
+ virtual void Destroy()
+ {
+ }
+
+ virtual void Create( wxWindow* parent, const wxPoint& pos, const wxSize& size,
+ long style, long extraStyle, const wxString& name ) = 0;
+
+
+ virtual WXWindow GetWXWindow() const = 0;
+
+ virtual void Raise()
+ {
+ }
+
+ virtual void Lower()
+ {
+ }
+
+ virtual bool Show(bool WXUNUSED(show))
+ {
+ return false;
+ }
+
+ virtual bool ShowWithEffect(bool show, wxShowEffect WXUNUSED(effect), unsigned WXUNUSED(timeout))
+ {
+ return Show(show);
+ }
+
+ virtual void Update()
+ {
+ }
+
+ virtual bool SetTransparent(wxByte WXUNUSED(alpha))
+ {
+ return false;
+ }
+
+ virtual bool SetBackgroundColour(const wxColour& WXUNUSED(col) )
+ {
+ return false;
+ }
+
+ virtual void SetExtraStyle( long WXUNUSED(exStyle) )
+ {
+ }
+
+ virtual bool SetBackgroundStyle(wxBackgroundStyle WXUNUSED(style))
+ {
+ return false ;
+ }
+
+ bool CanSetTransparent()
+ {
+ return false;
+ }
+
+ virtual void GetContentArea( int &left , int &top , int &width , int &height ) const = 0;
+ virtual void MoveWindow(int x, int y, int width, int height) = 0;
+ virtual void GetPosition( int &x, int &y ) const = 0;
+ virtual void GetSize( int &width, int &height ) const = 0;
+
+ virtual bool SetShape(const wxRegion& WXUNUSED(region))
+ {
+ return false;
+ }
+
+ virtual void SetTitle( const wxString& title, wxFontEncoding encoding ) = 0;
+
+ virtual bool IsMaximized() const = 0;
+
+ virtual bool IsIconized() const= 0;
+
+ virtual void Iconize( bool iconize )= 0;
+
+ virtual void Maximize(bool maximize) = 0;
+
+ virtual bool IsFullScreen() const= 0;
+
+ virtual bool ShowFullScreen(bool show, long style)= 0;
+
+ virtual void RequestUserAttention(int flags) = 0;
+
+ virtual void ScreenToWindow( int *x, int *y ) = 0;
+
+ virtual void WindowToScreen( int *x, int *y ) = 0;
+
+ wxNonOwnedWindow* GetWXPeer() { return m_wxPeer; }
+protected :
+ wxNonOwnedWindow* m_wxPeer;
+ DECLARE_ABSTRACT_CLASS(wxNonOwnedWindowImpl)
+};
+