/////////////////////////////////////////////////////////////////////////////
// Name: window.h
-// Purpose: wxWindow class
-// Author: AUTHOR
+// Purpose: wxWindowMac class
+// Author: Stefan Csomor
// Modified by:
-// Created: ??/??/98
+// Created: 1998-01-01
// RCS-ID: $Id$
-// Copyright: (c) AUTHOR
-// Licence: wxWindows licence
+// Copyright: (c) Stefan Csomor
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
#ifndef _WX_WINDOW_H_
#define _WX_WINDOW_H_
-#ifdef __GNUG__
+#if defined(__GNUG__) && !defined(__APPLE__)
#pragma interface "window.h"
#endif
+#include "wx/brush.h"
+
// ---------------------------------------------------------------------------
// forward declarations
// ---------------------------------------------------------------------------
class WXDLLEXPORT wxButton;
+class WXDLLEXPORT wxScrollBar;
+class WXDLLEXPORT wxTopLevelWindowMac;
// ---------------------------------------------------------------------------
// constants
// ---------------------------------------------------------------------------
-// FIXME does anybody use those? they're unused by wxWindows...
-enum
-{
- wxKEY_SHIFT = 1,
- wxKEY_CTRL = 2
-};
-
-class WXDLLEXPORT wxWindow: public wxWindowBase
+class WXDLLEXPORT wxWindowMac: public wxWindowBase
{
- DECLARE_DYNAMIC_CLASS(wxWindow);
-
- friend class wxDC;
- friend class wxPaintDC;
-
+ DECLARE_DYNAMIC_CLASS(wxWindowMac)
+
+ friend class wxDC;
+ friend class wxPaintDC;
+
public:
- typedef struct MacWindowData
- {
- SInt16 m_macWindowBackgroundTheme ;
- WindowRef m_macWindow ;
- ControlHandle m_macRootControl ;
- wxWindow* m_macFocus ;
- } MacWindowData ;
-
-
- wxWindow() { Init(); }
-
- wxWindow(wxWindow *parent,
- wxWindowID id,
- const wxPoint& pos = wxDefaultPosition,
- const wxSize& size = wxDefaultSize,
- long style = 0,
- const wxString& name = wxPanelNameStr)
+
+ wxWindowMac()
+ : m_macBackgroundBrush()
+ , m_macVisibleRegion()
+ , m_x(0), m_y(0), m_width(0), m_height(0)
+ , m_hScrollBar(NULL), m_vScrollBar(NULL)
+ , m_label(wxEmptyString)
+ { Init(); }
+
+ wxWindowMac(wxWindowMac *parent,
+ wxWindowID id,
+ const wxPoint& pos = wxDefaultPosition,
+ const wxSize& size = wxDefaultSize,
+ long style = 0,
+ const wxString& name = wxPanelNameStr)
{
Init();
Create(parent, id, pos, size, style, name);
}
- virtual ~wxWindow();
+ virtual ~wxWindowMac();
- bool Create(wxWindow *parent,
+ bool Create(wxWindowMac *parent,
wxWindowID id,
const wxPoint& pos = wxDefaultPosition,
const wxSize& size = wxDefaultSize,
virtual void SetFocus();
- virtual bool Reparent( wxWindow *newParent );
-
virtual void WarpPointer(int x, int y);
- virtual void CaptureMouse();
- virtual void ReleaseMouse();
virtual void Refresh( bool eraseBackground = TRUE,
const wxRect *rect = (const wxRect *) NULL );
virtual void Clear();
virtual bool SetCursor( const wxCursor &cursor );
- virtual bool SetFont( const wxFont &font );
-
+ virtual bool SetFont(const wxFont& font)
+ { return wxWindowBase::SetFont(font); }
virtual int GetCharHeight() const;
virtual int GetCharWidth() const;
virtual void GetTextExtent(const wxString& string,
// event handlers
// Handle a control command
- virtual void OnCommand(wxWindow& win, wxCommandEvent& event);
+ virtual void OnCommand(wxWindowMac& win, wxCommandEvent& event);
// Override to define new behaviour for default action (e.g. double
// clicking on a listbox)
// Native resource loading (implemented in src/msw/nativdlg.cpp)
// FIXME: should they really be all virtual?
- virtual bool LoadNativeDialog(wxWindow* parent, wxWindowID& id);
- virtual bool LoadNativeDialog(wxWindow* parent, const wxString& name);
- wxWindow* GetWindowChild1(wxWindowID id);
- wxWindow* GetWindowChild(wxWindowID id);
+ wxWindowMac* GetWindowChild1(wxWindowID id);
+ wxWindowMac* GetWindowChild(wxWindowID id);
// implementation from now on
// --------------------------
- void MacClientToRootWindow( int *x , int *y ) const ;
- void MacRootWindowToClient( int *x , int *y ) const ;
-
+ void MacClientToRootWindow( int *x , int *y ) const ;
+ void MacRootWindowToClient( int *x , int *y ) const ;
+ void MacWindowToRootWindow( int *x , int *y ) const ;
+ void MacRootWindowToWindow( int *x , int *y ) const ;
+
+ virtual wxString MacGetToolTipString( wxPoint &where ) ;
// simple accessors
// ----------------
- WXHWND GetHWND() const { return m_hWnd; }
- void SetHWND(WXHWND hWnd) { m_hWnd = hWnd; }
- virtual WXWidget GetHandle() const { return (WXWidget) GetHWND(); }
+// WXHWND GetHWND() const { return m_hWnd; }
+// void SetHWND(WXHWND hWnd) { m_hWnd = hWnd; }
+ virtual WXWidget GetHandle() const { return (WXWidget) NULL ; }
bool GetUseCtl3D() const { return m_useCtl3D; }
bool GetTransparentBackground() const { return m_backgroundTransparent; }
// event handlers
// --------------
+ void OnSetFocus(wxFocusEvent& event) ;
+ void OnNcPaint(wxNcPaintEvent& event);
void OnEraseBackground(wxEraseEvent& event);
void OnIdle(wxIdleEvent& event);
+ void MacOnScroll(wxScrollEvent&event ) ;
+
+ bool AcceptsFocus() const ;
public:
// For implementation purposes - sometimes decorations make the client area
// smaller
virtual wxPoint GetClientAreaOrigin() const;
- // Makes an adjustment to the window position (for example, a frame that has
- // a toolbar that it manages itself).
- virtual void AdjustForParentClientOrigin(int& x, int& y, int sizeFlags);
-
- wxWindow *FindItem(long id) const;
- wxWindow *FindItemByHWND(WXHWND hWnd, bool controlOnly = FALSE) const;
+ wxWindowMac *FindItem(long id) const;
+ wxWindowMac *FindItemByHWND(WXHWND hWnd, bool controlOnly = FALSE) const;
// Make a Windows extended style from the given wxWindows window style
static WXDWORD MakeExtendedStyle(long style,
virtual void MSWDeviceToLogical(float *x, float *y) const;
#endif // WXWIN_COMPATIBILITY
- // Create an appropriate wxWindow from a HWND
- virtual wxWindow* CreateWindowFromHWND(wxWindow* parent, WXHWND hWnd);
-
- // Make sure the window style reflects the HWND style (roughly)
- virtual void AdoptAttributesFromHWND();
-
// Setup background and foreground colours correctly
virtual void SetupColours();
bool IsUserEnabled() const { return IsEnabled(); }
#endif // WXWIN_COMPATIBILITY
- // Responds to colour changes: passes event on to children.
- void OnSysColourChanged(wxSysColourChangedEvent& event);
-
+public:
+ static bool MacGetWindowFromPoint( const wxPoint &point , wxWindowMac** outWin ) ;
+ virtual bool MacGetWindowFromPointSub( const wxPoint &point , wxWindowMac** outWin ) ;
+ virtual void MacRedraw( WXHRGN updatergn , long time , bool erase) ;
+ virtual bool MacCanFocus() const { return true ; }
+
+ virtual bool MacDispatchMouseEvent(wxMouseEvent& event ) ;
+ // this should not be overriden in classes above wxWindowMac because it is called from its destructor via DeleteChildren
+ virtual void RemoveChild( wxWindowBase *child );
+ virtual void MacPaintBorders( int left , int top ) ;
+ WXWindow MacGetRootWindow() const ;
+ wxTopLevelWindowMac* MacGetTopLevelWindow() const ;
+
+ virtual WXWidget MacGetContainerForEmbedding() ;
+
+ virtual long MacGetLeftBorderSize() const ;
+ virtual long MacGetRightBorderSize() const ;
+ virtual long MacGetTopBorderSize() const ;
+ virtual long MacGetBottomBorderSize() const ;
+
+ static long MacRemoveBordersFromStyle( long style ) ;
+ virtual void MacSuperChangedPosition() ;
+ // the absolute coordinates of this item within the toplevel window may have changed
+ virtual void MacUpdateDimensions() {}
+ // the absolute coortinates of this window's root have changed
+ virtual void MacTopLevelWindowChangedPosition() ;
+ virtual void MacSuperShown( bool show ) ;
+ virtual void MacSuperEnabled( bool enable ) ;
+ bool MacIsReallyShown() const ;
+ virtual void Update() ;
+ // for compatibility
+ void MacUpdateImmediately() { Update() ; }
+ virtual bool MacSetupCursor( const wxPoint& pt ) ;
+
+// virtual bool MacSetPortDrawingParams( const Point & localOrigin, const Rect & clipRect, WindowRef window , wxWindowMac* rootwin ) ;
+// virtual void MacGetPortParams(Point* localOrigin, Rect* clipRect, WindowRef *window , wxWindowMac** rootwin ) ;
+// virtual void MacGetPortClientParams(Point* localOrigin, Rect* clipRect, WindowRef *window , wxWindowMac** rootwin) ;
+ const wxBrush& MacGetBackgroundBrush() ;
+ const wxRegion& MacGetVisibleRegion( bool respectChildrenAndSiblings = true ) ;
+ bool MacIsWindowScrollbar( const wxScrollBar* sb )
+ { return (m_hScrollBar == sb || m_vScrollBar == sb) ; }
+ static wxWindowMac* s_lastMouseWindow ;
+private:
protected:
- // the window handle
- WXHWND m_hWnd;
-
- // the old window proc (we subclass all windows)
- WXFARPROC m_oldWndProc;
+// RgnHandle m_macUpdateRgn ;
+// bool m_macEraseOnRedraw ;
+ wxBrush m_macBackgroundBrush ;
+ wxRegion m_macVisibleRegion ;
+ int m_x ;
+ int m_y ;
+ int m_width ;
+ int m_height ;
+
+ wxScrollBar* m_hScrollBar ;
+ wxScrollBar* m_vScrollBar ;
+ wxString m_label ;
+
+ void MacCreateScrollBars( long style ) ;
+ void MacRepositionScrollBars() ;
// additional (MSW specific) flags
- bool m_useCtl3D:1; // Using CTL3D for this control
- bool m_backgroundTransparent:1;
- bool m_mouseInWindow:1;
- bool m_doubleClickAllowed:1;
- bool m_winCaptured:1;
+ bool m_useCtl3D:1; // Using CTL3D for this control
+ bool m_backgroundTransparent:1;
+ bool m_mouseInWindow:1;
+ bool m_doubleClickAllowed:1;
+ bool m_winCaptured:1;
// the size of one page for scrolling
- int m_xThumbSize;
- int m_yThumbSize;
-
- WXHMENU m_hMenu; // Menu, if any
+ int m_xThumbSize;
+ int m_yThumbSize;
- // the return value of WM_GETDLGCODE handler
- long m_lDlgCode;
+// WXHMENU m_hMenu; // Menu, if any
// implement the base class pure virtuals
virtual void DoClientToScreen( int *x, int *y ) const;
int sizeFlags = wxSIZE_AUTO);
virtual void DoSetClientSize(int width, int height);
- // get the size which best suits the window: e.g., for a static text it
- // will be the width and height of the text
- virtual wxSize DoGetBestSize();
+ virtual void DoCaptureMouse();
+ virtual void DoReleaseMouse();
// move the window to the specified location and resize it: this is called
// from both DoSetSize() and DoSetClientSize() and would usually just call
// common part of all ctors
void Init();
- DECLARE_NO_COPY_CLASS(wxWindow);
+ DECLARE_NO_COPY_CLASS(wxWindowMac)
DECLARE_EVENT_TABLE()
};
-// associate mac windows with wx counterparts
-
-wxWindow* wxFindWinFromMacWindow( WindowRef inWindow ) ;
-void wxAssociateWinWithMacWindow(WindowRef inWindow, wxWindow *win) ;
-void wxRemoveMacWindowAssociation(wxWindow *win) ;
-
-class wxMacFocusHelper
-{
-public :
- wxMacFocusHelper( wxWindow * theWindow ) ;
- ~wxMacFocusHelper() ;
- bool Ok() { return m_ok ; }
-
-private :
- GrafPtr m_formerPort ;
- GrafPtr m_currentPort ;
- bool m_ok ;
-} ;
-
-class wxMacDrawingHelper
-{
-public :
- wxMacDrawingHelper( wxWindow * theWindow ) ;
- ~wxMacDrawingHelper() ;
- bool Ok() { return m_ok ; }
-
-private :
- GrafPtr m_formerPort ;
- GrafPtr m_currentPort ;
- PenState m_savedPenState ;
- bool m_ok ;
-} ;
-
-class wxMacFocusClientHelper
-{
-public :
- wxMacFocusClientHelper( wxWindow * theWindow ) ;
- ~wxMacFocusClientHelper() ;
- bool Ok() { return m_ok ; }
-
-private :
- GrafPtr m_formerPort ;
- GrafPtr m_currentPort ;
- bool m_ok ;
-} ;
-
-class wxMacDrawingClientHelper
-{
-public :
- wxMacDrawingClientHelper( wxWindow * theWindow ) ;
- ~wxMacDrawingClientHelper() ;
- bool Ok() { return m_ok ; }
-
-private :
- GrafPtr m_formerPort ;
- GrafPtr m_currentPort ;
- PenState m_savedPenState ;
- bool m_ok ;
-} ;
-
#endif
// _WX_WINDOW_H_