]> git.saurik.com Git - wxWidgets.git/blobdiff - include/wx/mac/control.h
As in 2.2.9, toolbars should not get the focus.
[wxWidgets.git] / include / wx / mac / control.h
index 3770d647f29097d4b78bbfa4f91a6bfcac043261..02f59ad05e409305c0a23dbf155b6f8a480c4344 100644 (file)
@@ -16,6 +16,8 @@
 #pragma interface "control.h"
 #endif
 
 #pragma interface "control.h"
 #endif
 
+WXDLLEXPORT_DATA(extern const wxChar*) wxControlNameStr;
+
 // General item class
 class WXDLLEXPORT wxControl : public wxControlBase
 {
 // General item class
 class WXDLLEXPORT wxControl : public wxControlBase
 {
@@ -23,6 +25,20 @@ class WXDLLEXPORT wxControl : public wxControlBase
 
 public:
    wxControl();
 
 public:
    wxControl();
+   wxControl(wxWindow *parent, wxWindowID id,
+             const wxPoint& pos = wxDefaultPosition,
+             const wxSize& size = wxDefaultSize, long style = 0,
+             const wxValidator& validator = wxDefaultValidator,
+             const wxString& name = wxControlNameStr)
+    {
+        Create(parent, id, pos, size, style, validator, name);
+    }
+
+    bool Create(wxWindow *parent, wxWindowID id,
+            const wxPoint& pos = wxDefaultPosition,
+            const wxSize& size = wxDefaultSize, long style = 0,
+            const wxValidator& validator = wxDefaultValidator,
+            const wxString& name = wxControlNameStr);
    virtual ~wxControl();
 
    // Simulates an event
    virtual ~wxControl();
 
    // Simulates an event
@@ -36,32 +52,35 @@ public:
    virtual void SetLabel(const wxString& title) ;
 
    wxList& GetSubcontrols() { return m_subControls; }
    virtual void SetLabel(const wxString& title) ;
 
    wxList& GetSubcontrols() { return m_subControls; }
-
+   
    void OnEraseBackground(wxEraseEvent& event);
    void OnEraseBackground(wxEraseEvent& event);
-
-               virtual bool                                            Enable(bool enabled) ;
-               virtual bool                                            Show(bool show) ;
-                               
-               virtual void                                            MacHandleControlClick( ControlHandle control , SInt16 controlpart ) ;
-               virtual void                                            MacPreControlCreate( wxWindow *parent, wxWindowID id, wxString label , 
-                                                                                const wxPoint& pos,
-                                                                                const wxSize& size, long style,
-                                                                                const wxValidator& validator,
-                                                                                const wxString& name , Rect *outBounds , StringPtr maclabel ) ;
-               virtual void                                            MacPostControlCreate() ;
-               virtual void                                            MacAdjustControlRect() ;
-               virtual ControlHandle   MacGetContainerForEmbedding() ;
-               virtual void                                            MacSuperChangedPosition() ;
-               virtual void                                            MacSuperEnabled( bool enabled ) ;
-               virtual void                                            MacSuperShown( bool show ) ;
-               virtual bool                                            MacCanFocus() const ;
-
-               virtual void                                                            DoSetSize(int x, int y,int width, int height,int sizeFlags ) ;
-               virtual void                                            OnKeyDown( wxKeyEvent &event ) ;
-               virtual void                                            OnMouseEvent( wxMouseEvent &event ) ;
-               virtual void                                    OnPaint(wxPaintEvent& event) ;
-               virtual void                                            Refresh(bool eraseBack = TRUE, const wxRect *rect = NULL) ;
-               ControlHandle                                   GetMacControl() { return m_macControl ;}
+   
+   virtual bool                 Enable(bool enable = TRUE) ;
+   virtual bool                 Show(bool show = TRUE) ;
+   
+   virtual void                 MacRedrawControl () ;
+   virtual void         MacHandleControlClick( WXWidget control , short controlpart ) ;
+   virtual void                 MacPreControlCreate( wxWindow *parent, wxWindowID id, wxString label , 
+                                             const wxPoint& pos,
+                                             const wxSize& size, long style,
+                                             const wxValidator& validator,
+                                             const wxString& name ,
+                                             WXRECTPTR outBounds ,
+                                             unsigned char* maclabel ) ;
+   virtual void                 MacPostControlCreate() ;
+   virtual void                 MacAdjustControlRect() ;
+   virtual WXWidget MacGetContainerForEmbedding() ;
+   virtual void         MacSuperChangedPosition() ;
+   virtual void         MacSuperEnabled( bool enabled ) ;
+   virtual void         MacSuperShown( bool show ) ;
+   virtual bool                 MacCanFocus() const ;
+   
+   virtual void         DoSetSize(int x, int y,int width, int height,int sizeFlags = wxSIZE_AUTO ) ;
+   virtual void         OnKeyDown( wxKeyEvent &event ) ;
+   virtual void                 OnMouseEvent( wxMouseEvent &event ) ;
+   virtual void         OnPaint(wxPaintEvent& event) ;
+   virtual void                 Refresh(bool eraseBack = TRUE, const wxRect *rect = NULL) ;
+   WXWidget     GetMacControl() { return m_macControl ;}
 
 #if WXWIN_COMPATIBILITY
    virtual void SetButtonColour(const wxColour& WXUNUSED(col)) { }
 
 #if WXWIN_COMPATIBILITY
    virtual void SetButtonColour(const wxColour& WXUNUSED(col)) { }
@@ -83,12 +102,13 @@ protected:
 
 protected:
    // For controls like radiobuttons which are really composite
 
 protected:
    // For controls like radiobuttons which are really composite
-               ControlHandle           m_macControl ;
-               int                                                     m_macHorizontalBorder ;
-               int                                                     m_macVerticalBorder ;
-   wxList m_subControls;
+       WXWidget                m_macControl ;
+       bool                            m_macControlIsShown ;
+       wxList m_subControls;
+       int                                                     m_macHorizontalBorder ;
+       int                                                     m_macVerticalBorder ;
 
 
-   virtual wxSize DoGetBestSize();
+   virtual wxSize DoGetBestSize() const;
 
 private:
    DECLARE_EVENT_TABLE()
 
 private:
    DECLARE_EVENT_TABLE()
@@ -103,8 +123,8 @@ private:
     inline void wxControl::SetButtonFont(const wxFont& font) { SetFont(font); }
 #endif // WXWIN_COMPATIBILITY
 
     inline void wxControl::SetButtonFont(const wxFont& font) { SetFont(font); }
 #endif // WXWIN_COMPATIBILITY
 
-wxControl *wxFindControlFromMacControl(ControlHandle inControl ) ;
-void wxAssociateControlWithMacControl(ControlHandle inControl, wxControl *control) ;
+wxControl *wxFindControlFromMacControl(WXWidget inControl ) ;
+void wxAssociateControlWithMacControl(WXWidget inControl, wxControl *control) ;
 void wxRemoveMacControlAssociation(wxControl *control) ;
 
 #endif
 void wxRemoveMacControlAssociation(wxControl *control) ;
 
 #endif